How do your syslog/journalctl entries look like?
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Hello, can someone show me an example of a syslog and/or journalctl entries related to Back In Time please? I want to be sure that I'm not the problem here before opening an Issue. ;) Thanks Christian
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Thanks Hakan, this helps. I'm not experienced with logging in the unix world. Maybe someone explain me the following. I did "backintime backup" in a terminal. This is one of the "syslog" entries I can see via "journalctl". Jul 19 08:57:13 quark python3[2796]: backintime (user/1): INFO: Unlock It seems that "python3[2796]" is the identifier of this syslog entry. But I'm not sure. Then I used "journalctl -o json-pretty" to identify the fields used. Please have a look at "MESSAGE" and "_SYSTEMD_UNIT". { "_HOSTNAME" : "quark", "_SYSTEMD_SLICE" : "user-1000.slice", "_SYSTEMD_UNIT" : "session-4.scope", "_AUDIT_SESSION" : "4", "_BOOT_ID" : "11130cdbf5ef4f978996e5141ea02c08", "__CURSOR" : "s=d810a315c1904023a90d28c39f2c29cb;i=636;b=11130cdbf5ef4f978996e5141ea02c08;m=217b11c9;t=600d18a977d65;x=d26305f2057e735d", "_MACHINE_ID" : "bb7f774ca75c426fad9008668d88a2ae", "__MONOTONIC_TIMESTAMP" : "561713609", "_SYSTEMD_OWNER_UID" : "1000", "_PID" : "2796", "_COMM" : "python3", "_CMDLINE" : "python3 -Es /usr/share/backintime/common/backintime.py backup", "SYSLOG_FACILITY" : "1", "_SYSTEMD_USER_SLICE" : "-.slice", "_SYSTEMD_SESSION" : "4", "_CAP_EFFECTIVE" : "0", "SYSLOG_TIMESTAMP" : "Jul 19 08:57:13 ", "__REALTIME_TIMESTAMP" : "1689749833612645", "_SYSTEMD_INVOCATION_ID" : "aef81fe893b44b11a78c64c7f60f6d7b", "_SOURCE_REALTIME_TIMESTAMP" : "1689749833612597", "MESSAGE" : "backintime (user/1): INFO: Unlock", "_AUDIT_LOGINUID" : "1000", "_EXE" : "/usr/bin/python3.9", "_SELINUX_CONTEXT" : "unconfined\n", "_TRANSPORT" : "syslog", "_UID" : "1000", "_SYSTEMD_CGROUP" : "/user.slice/user-1000.slice/session-4.scope", "_GID" : "1000", "PRIORITY" : "6" } Here I can not find the "python3[2796]" as identifier. The field "SYSLOG_IDENTIFIER" is missing. The first part of the MESSAGE ("backintime (user/1)" is the identifier used by backintime itself [1]. def openlog(): name = os.getenv('LOGNAME', 'unknown') syslog.openlog("%s (%s/1)" %(APP_NAME, name)) atexit.register(closelog) def changeProfile(profile_id): name = os.getenv('LOGNAME', 'unknown') syslog.openlog("%s (%s/%s)" %(APP_NAME, name, profile_id)) It confuse me that the ident value used by BIT in code becomes part of the MESSAGE. I would expect that it would become an extra field in the journalctl json output. In the end I ask myself how to read logs related to BackInTime when I'm not able to do something like "journalctl -u backintime*". I'm confused. Shouldn't it be easier and more reliable as "journalctl | grep backintime" to get all related BIT log entries? [1] -- <https://github.com/bit-team/backintime/blob/71c9657324c0e08dd3288dbff830dd90...>
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Please let me add something. Am 19.07.2023 09:12 schrieb c.buhtz@posteo.jp:
BIT itself do set the syslog identifier to "backintime (user/1)". But somehow this is ignored or overwritten and inserted to the message itself. And the journalctl entry then even do not have a SYSLOG_IDENTIFIER field. I'm not an admin in the unix world. Maybe they find journalctl/syslog helpfull but I don't. We have one "simple" userspace application using syslog and it is not possible to reliable find all its entries in the logs. Using "grep" is not reliable but just a workaround. Maybe some BIT users do use that logs. So I won't remove that behavior. But I really think about if it would help BIT to have an application specific log-file. For thous who are not able to use journalctl or don't trust it such a plain log file would help doing diagnosis especially for us as developers. Implementing this is not a big deal. Python offer nice features about it. Even having multiple BIT instances (e.g. backintime-qt and backintime) logging the same time is no problem. I do have a solution in my mind. ;) Am I the only one having problems with journalctl/syslog?
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Talking to myself.... :D I think I got it. The problem might be that BIT do use not allowed characters in its "ident" argument when calling syslog.openlog(). That is why the SYSLOG_IDENTIFIER is missing in the journalctl. This is the relevant code line in BIT: syslog.openlog("%s (%s/1)" %(APP_NAME, name)) The blank is not allowed but don't raise an error. The brackets and the slash is allowed.
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
I opened an Issue about the topic, describing the problem and offering approaches for a solution. https://github.com/bit-team/backintime/issues/1483
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
I opened an Issue about the syslog problem. https://github.com/bit-team/backintime/issues/1483
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Thanks Hakan, this helps. I'm not experienced with logging in the unix world. Maybe someone explain me the following. I did "backintime backup" in a terminal. This is one of the "syslog" entries I can see via "journalctl". Jul 19 08:57:13 quark python3[2796]: backintime (user/1): INFO: Unlock It seems that "python3[2796]" is the identifier of this syslog entry. But I'm not sure. Then I used "journalctl -o json-pretty" to identify the fields used. Please have a look at "MESSAGE" and "_SYSTEMD_UNIT". { "_HOSTNAME" : "quark", "_SYSTEMD_SLICE" : "user-1000.slice", "_SYSTEMD_UNIT" : "session-4.scope", "_AUDIT_SESSION" : "4", "_BOOT_ID" : "11130cdbf5ef4f978996e5141ea02c08", "__CURSOR" : "s=d810a315c1904023a90d28c39f2c29cb;i=636;b=11130cdbf5ef4f978996e5141ea02c08;m=217b11c9;t=600d18a977d65;x=d26305f2057e735d", "_MACHINE_ID" : "bb7f774ca75c426fad9008668d88a2ae", "__MONOTONIC_TIMESTAMP" : "561713609", "_SYSTEMD_OWNER_UID" : "1000", "_PID" : "2796", "_COMM" : "python3", "_CMDLINE" : "python3 -Es /usr/share/backintime/common/backintime.py backup", "SYSLOG_FACILITY" : "1", "_SYSTEMD_USER_SLICE" : "-.slice", "_SYSTEMD_SESSION" : "4", "_CAP_EFFECTIVE" : "0", "SYSLOG_TIMESTAMP" : "Jul 19 08:57:13 ", "__REALTIME_TIMESTAMP" : "1689749833612645", "_SYSTEMD_INVOCATION_ID" : "aef81fe893b44b11a78c64c7f60f6d7b", "_SOURCE_REALTIME_TIMESTAMP" : "1689749833612597", "MESSAGE" : "backintime (user/1): INFO: Unlock", "_AUDIT_LOGINUID" : "1000", "_EXE" : "/usr/bin/python3.9", "_SELINUX_CONTEXT" : "unconfined\n", "_TRANSPORT" : "syslog", "_UID" : "1000", "_SYSTEMD_CGROUP" : "/user.slice/user-1000.slice/session-4.scope", "_GID" : "1000", "PRIORITY" : "6" } Here I can not find the "python3[2796]" as identifier. The field "SYSLOG_IDENTIFIER" is missing. The first part of the MESSAGE ("backintime (user/1)" is the identifier used by backintime itself [1]. def openlog(): name = os.getenv('LOGNAME', 'unknown') syslog.openlog("%s (%s/1)" %(APP_NAME, name)) atexit.register(closelog) def changeProfile(profile_id): name = os.getenv('LOGNAME', 'unknown') syslog.openlog("%s (%s/%s)" %(APP_NAME, name, profile_id)) It confuse me that the ident value used by BIT in code becomes part of the MESSAGE. I would expect that it would become an extra field in the journalctl json output. In the end I ask myself how to read logs related to BackInTime when I'm not able to do something like "journalctl -u backintime*". I'm confused. Shouldn't it be easier and more reliable as "journalctl | grep backintime" to get all related BIT log entries? [1] -- <https://github.com/bit-team/backintime/blob/71c9657324c0e08dd3288dbff830dd90...>
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Please let me add something. Am 19.07.2023 09:12 schrieb c.buhtz@posteo.jp:
BIT itself do set the syslog identifier to "backintime (user/1)". But somehow this is ignored or overwritten and inserted to the message itself. And the journalctl entry then even do not have a SYSLOG_IDENTIFIER field. I'm not an admin in the unix world. Maybe they find journalctl/syslog helpfull but I don't. We have one "simple" userspace application using syslog and it is not possible to reliable find all its entries in the logs. Using "grep" is not reliable but just a workaround. Maybe some BIT users do use that logs. So I won't remove that behavior. But I really think about if it would help BIT to have an application specific log-file. For thous who are not able to use journalctl or don't trust it such a plain log file would help doing diagnosis especially for us as developers. Implementing this is not a big deal. Python offer nice features about it. Even having multiple BIT instances (e.g. backintime-qt and backintime) logging the same time is no problem. I do have a solution in my mind. ;) Am I the only one having problems with journalctl/syslog?
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
Talking to myself.... :D I think I got it. The problem might be that BIT do use not allowed characters in its "ident" argument when calling syslog.openlog(). That is why the SYSLOG_IDENTIFIER is missing in the journalctl. This is the relevant code line in BIT: syslog.openlog("%s (%s/1)" %(APP_NAME, name)) The blank is not allowed but don't raise an error. The brackets and the slash is allowed.
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
I opened an Issue about the topic, describing the problem and offering approaches for a solution. https://github.com/bit-team/backintime/issues/1483
data:image/s3,"s3://crabby-images/412c7/412c7c65d20285155f529c2cd0e5b65d66121701" alt=""
I opened an Issue about the syslog problem. https://github.com/bit-team/backintime/issues/1483
participants (2)
-
c.buhtz@posteo.jp
-
Hakan Bayındır