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
I have a pod which is running a python application with uwsgi service. The uwsgi service writes the logs to pod's /tmp/logs folder.
I have mounted the GCS bucket mapped with /tmp/logs folder so that every log file could go to GCS bucket.
Everything working as expected, but the log files are not visible when I jump to GCS bucket storage pages. However, if i created something manually (like touch a.txt) , it gets visible instantly on web page of GCS buckets.
I entered into POD and I updated the logs by writing something manually and it got reflected on GCS bucket page, with logs till that time. but newer lines in the logs are are again not visible in buckets page. even after refreshing the page.
It appears that the issue is the application not flushing the log file since the file is still open as logs are being added to it. Data in log file will be uploaded to GCS bucket only when flushFile or syncFile is called from kernel/application writing to the file. Flush/Sync file occurs when the file is closed or when applications explicitly trigger sync/flush calls using os.Sync().
It can be verified by analyzing the gcsfuse logs. Follow these two steps to obtain and analyze the gcsfuse logs:
Turn on trace logs in gcsfuse config(see reference).
Look for FlushFile call in the logs similar to the one shown below, till this call is issued to gcsfuse, data will not be written to gcs, it will remain at temporary location on the machine.
{"timestamp":{"seconds":1722921973,"nanos":83035525},"severity":"TRACE","message":"fuse_debug: Op 0x00000292 connection.go:513] -> OK ()"}
{"timestamp":{"seconds":1722921973,"nanos":239823811},"severity":"TRACE","message":"fuse_debug: Op 0x00000294 connection.go:420] <- FlushFile (inode 8, PID 208049)"}
This is the intended behaviour, its upto application to trigger flush/sync, GCSFuse cannot sync without external trigger. One option can be to add log rotation in application with a shorter threshold. Log rotation frameworks automatically close old log files and create new ones after reaching threshold, thereby triggering the flush call to GCSFuse for closed files.
@raviprakash007 Just wanted to check in on this issue. I know you mentioned you were looking into the logs after enabling debug. Any updates on that? Are you still running into the same problem?
I have a pod which is running a python application with uwsgi service. The uwsgi service writes the logs to pod's /tmp/logs folder.
I have mounted the GCS bucket mapped with /tmp/logs folder so that every log file could go to GCS bucket.
Everything working as expected, but the log files are not visible when I jump to GCS bucket storage pages. However, if i created something manually (like touch a.txt) , it gets visible instantly on web page of GCS buckets.
I entered into POD and I updated the logs by writing something manually and it got reflected on GCS bucket page, with logs till that time. but newer lines in the logs are are again not visible in buckets page. even after refreshing the page.
Can someone assist.?
The configs are as follows:
PV
PVC
Deployment Snippet
Expected Result: the logs files created , should be reflecting automatically , if something created manaully is reflecting to GCS buckets web page.
The text was updated successfully, but these errors were encountered: