-
Notifications
You must be signed in to change notification settings - Fork 345
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
gcc-8 incompatibility - One of the threads gets stuck #8
Comments
Hello eucristian, I don't have access to a RHEL machine, but I was able to reproduce the problem in CentOS and Debian. It appears that there's some bad interaction between gcc-8 and POSIX AIO. In particular, the thread that you see exit under gdb is the POSIX AIO thread, not one of the NanoLog threads. I'm not sure what's causing the bad interaction, but the problem seems to go away when I use gcc-7 and earlier. Could you try compiling with an earlier version of gcc and see if the problem occurs? Internally, we develop on gcc 6.4.0. |
Unfortunately we need to use gcc-8 . I have looked on their website and could not find a bug regarding POSIX AIO. I have also tested with gcc-7 and it seems that the problem is gone but this is not somehting i can use in the production environment. |
I think I've found the root cause. It appears gcc8 is optimizing out a variable read within the StagingBuffer class, causing it to misreport free space. I'll try to have a fix up in the next day or so. Also, it appears that the POSIX AIO thread was exiting due to inactivity through the aio_* api and was an indicator of inactivity with my background thread rather than gcc8+aio incompatibility. It was a red herring; sorry about that. |
This problem should be fixed in commit e969124. Give it a try and let me know if you encounter any more issues. |
Hello, will do this tonight and come back with my results. Thank you for this! |
Hello,
I might be doing something wrong but i have tried this on 3 different machines, 2 of them freshly installed.
Running the benchmark on a fresh installed Red Hat Enterprise Linux Server release 7.6 (Maipo) with devtoolset-8 and one of the threads gets stuck on RuntimeLogger::StagingBuffer::reserveSpaceInternal.
Have the same problem also on self-compiled gcc 8.2 install with ABI=1. (bin-utils =the ones from the devtoolset-8)
I also think that one of the threads crashes as there are only 2 live threads. Below the gdb bt and thread info. This is also a bit peculiar as it doesn't always happen, but it happens consistently enough (one every 4 runs let's say)
Thank you very much. will also keep an eye to provide more info if needed.
The text was updated successfully, but these errors were encountered: