-
Notifications
You must be signed in to change notification settings - Fork 121
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
use pythonic way to read log #102
Comments
Thanks @kungfoome! I see you have some very specific suggestions that are more suitable for a PR. You can fork the repository and submit a PR towards the dev branch here directly from your fork. Then it'll be easier to review and test the changes. @pieterhelsen Check this out, maybe a fix for the Windows issues with log rotations. |
Definitely worth a try and would be nice if it worked cross-platform. It's tested on Linux local, Linux remote and Windows local, but I can't test Windows remote without setting up a dummy node |
@kungfoome I just implemented your solution and one other, but did not get either of them to work reliably on my test setup due to the fact that Now, it is possible that Chia uses another method that handles these rotations better, but I am currently unable to test this on my machine. Were you able to try this out further? |
Chia uses this: You can see how they use it here: |
I'll update my dummy logger to use this package and see if that alters behavior. From the description, it should! |
Yeah sorry. Haven't had time to follow up. I get the same behavior, although I don't think it's really because of open. That shouldn't create a lock on the file, but I think it's more so that it continues to read from the file and it doesn't have time to rotate. I think if you were to read x amount of bytes and set a timeout period, it would probably be ok. But im interested in seeing if that other library works as well, as that would be much easier than trying to implement something from scratch. |
When using the Concurrent Log Handler it doesn't produce any errors, but reading the logfile in a pythonic still locks up the file, and prevents log rotation. (at least on Windows) So it's a little more robust, but the issue persists. |
I was trying to run this with WSL to see if that would work. It seems like there is an issue where you can't follow a file in WSL without the
---disable-inotify
flag on tail. I tested this and added that option in the log consumer and it does work after that. I noticed there have been issues with Windows as well during log rotations. I'm not sure if switching over to a pythonic way of reading the debug file will solve this, but it seems like it would be better since you don't need differentiate between OSes either.Not sure if remote would work with this either, so it would require a bit of testing.
chiadog/src/chia_log/log_consumer.py
Lines 72 to 80 in da1a904
Maybe something like: https://stackoverflow.com/questions/12523044/how-can-i-tail-a-log-file-in-python/53121178#53121178
Edit:
Initially something like this appears to work with little resources:
I can run it for a bit and see what happens during rotations as well. This seems to work the same for windows.
The text was updated successfully, but these errors were encountered: