You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
xtb (the underlying library) does not close file descriptors after writing logs to them. This causes multiple issues with logs. If you are performing a large volume of calculations you will get an OS error when you have performed more calculations that the ulimit -n number of calclutions. ulimit is communicating the maximum number of file descriptors a process can have open.
Additionally, depending on how xtb is run, it appears xtb has some internal logic that attempts to circumvent this bug with strange behavior. xtb will only write up to ulimit - a few calculations to log files, then it stops opening file descriptors, even if calculator.set_output(f"logfile-{i}") is passed and starts dumping output to the console instead of writing output to disk. Also, if you run a calculation and then time.sleep(10) after the calculation and check the log file, you will see that it is empty--in fact a whole series of log files will be empty until the whole program exits and the OS flushes the logs to disk.
xtb needs to close the file it opens here. Calling calculator.release_output() does not fix this problem.
To Reproduce
To show logs getting dumped to console instead of written to disk and to show that logs are not written after a calculation (only flushed when the whole process exists):
Most systems set ulimit -n 1024 by default. Run this script. Calling it script.py.
Now look at the number of log files (there should be 2000), there will only be 1021. Notice how the output started dumping to the terminal instead of being written to log files at the end. This should not happen.
ls -1 xtb-data | wc -l
Remove all the files
rm -r xtb-data/*.txt
Set a new ulimit and run the script again.
ulimit -n 75
python script.py
Count the log files. Note that much more output dumped to the console instead of being written to log files. Should be 2000 log files, there are only 71 but there should be 2000.
ls -1 xtb-data | wc -l
xtb appears to be introspecting ulimit declarations and limiting file handle opens so it doesn't get terminated by the operating system. However, it should just close the file handles after it opens then and writes logs to them. It should flush the log writing to disk after a calculation. You can see the log flushing/writing is not happening properly by uncommenting the time.sleep(10) in scripts.py. Then look at log-0.txt after the calculation. It is empty. It will remain empty until all calculations are complete and then the OS flushes data to the log files. This is not good and is a result of xtb not closing its file handles properly after writing logs.
If you are running xtb calculations inside of a process the opens temporary directories using python, you'll get a OSError: [Errno 24] Too many open files:. Here is an alternative script that shows how xtb causes this issue:
Describe the bug
xtb (the underlying library) does not close file descriptors after writing logs to them. This causes multiple issues with logs. If you are performing a large volume of calculations you will get an OS error when you have performed more calculations that the
ulimit -n
number of calclutions.ulimit
is communicating the maximum number of file descriptors a process can have open.Additionally, depending on how xtb is run, it appears xtb has some internal logic that attempts to circumvent this bug with strange behavior. xtb will only write up to
ulimit - a few
calculations to log files, then it stops opening file descriptors, even ifcalculator.set_output(f"logfile-{i}")
is passed and starts dumping output to the console instead of writing output to disk. Also, if you run a calculation and thentime.sleep(10)
after the calculation and check the log file, you will see that it is empty--in fact a whole series of log files will be empty until the whole program exits and the OS flushes the logs to disk.xtb needs to close the file it opens here. Calling
calculator.release_output()
does not fix this problem.To Reproduce
To show logs getting dumped to console instead of written to disk and to show that logs are not written after a calculation (only flushed when the whole process exists):
Most systems set
ulimit -n 1024
by default. Run this script. Calling itscript.py
.Now look at the number of log files (there should be 2000), there will only be 1021. Notice how the output started dumping to the terminal instead of being written to log files at the end. This should not happen.
ls -1 xtb-data | wc -l
Remove all the files
rm -r xtb-data/*.txt
Set a new
ulimit
and run the script again.ulimit -n 75 python script.py
Count the log files. Note that much more output dumped to the console instead of being written to log files. Should be 2000 log files, there are only 71 but there should be 2000.
ls -1 xtb-data | wc -l
xtb
appears to be introspectingulimit
declarations and limiting file handle opens so it doesn't get terminated by the operating system. However, it should just close the file handles after it opens then and writes logs to them. It should flush the log writing to disk after a calculation. You can see the log flushing/writing is not happening properly by uncommenting the time.sleep(10) inscripts.py
. Then look atlog-0.txt
after the calculation. It is empty. It will remain empty until all calculations are complete and then the OS flushes data to the log files. This is not good and is a result of xtb not closing its file handles properly after writing logs.If you are running xtb calculations inside of a process the opens temporary directories using python, you'll get a
OSError: [Errno 24] Too many open files:
. Here is an alternative script that shows howxtb
causes this issue:All of these issues go away if you do not
.set_output(filepath)
asxtb
just writes output to the console.Please provide all input and output file such that we confirm your report.-->
Expected behaviour
xtb properly opens, writes to, and closes the file passed into
.set_output()
The text was updated successfully, but these errors were encountered: