Systemdのジャーナルログを使用して特定のログのログメッセージをプルできるかどうか疑問に思いました。たとえば、Cでログを開くと、openlog('slog', LOG_CONS | LOG_PID, LOG_LOCAL1)
、 'slog
'またはLOCAL1
の下に記録されたメッセージだけをプルしますか?
journalctl -u slog
やjournalctl -u LOG_LOCAL1
のようなことをすると、実際のログメッセージではなく、ログの開始と終了を通知するだけです。
はい、可能ですが、間違ったスイッチをjournalctl
に渡しました。
journalctl(1) のマニュアルページによると:
特定のsyslog識別子(「foo」など)を持つメッセージを読み取るには、journalctl -t foo
またはjournalctl SYSLOG_IDENTIFIER=foo
を発行します。
特定のsyslogファシリティでメッセージを読み取るには、journalctl SYSLOG_FACILITY=1
を発行します(ファシリティは格納され、数値を使用して照合されることに注意してください)。
より一般的には、syslog識別子と機能は別々のフィールド(SYSLOG_IDENTIFIER
とSYSLOG_FACILITY
)としてジャーナルに保存されます。たとえば、C APIからジャーナルにアクセスする必要がある場合は、これらのフィールドに直接一致を追加する必要があります。
journalctl -u
スイッチは、メッセージを生成したプロセスを所有するsystemdユニットの名前に一致を追加するために使用されます。したがって、これは使用するのに間違ったスイッチです。
正しい。それはそれをします。 journalctlをスクリプト化する時間です。
#!/bin/bash
# Provide a simple command-line interface for systemd "journalctl"
# See /usr/include/sys/syslog.h for syslog integer ids
# Example usage: "./syslog/bin/syslogga.sh --local0 --tail" to tail local0
set -o nounset
declare -a OPTIONS
declare -a MATCHES
OPTIONS=()
MATCHES=()
function processOptions {
local UNKNOWN=
local HELP=
local SYSLOGSEL=0
for P in "$@"; do
if [[ $P == --kernel || $P == --kern || $P == -0 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=0")
continue
fi
if [[ $P == --user || $P == -1 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=1")
continue
fi
if [[ $P == --mail || $P == -2 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=2")
continue
fi
if [[ $P == --daemon || $P == -3 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=3")
continue
fi
if [[ $P == --auth || $P == -4 || $P == --selinux ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=4")
continue
fi
if [[ $P == --syslog || $P == -5 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=5")
continue
fi
if [[ $P == --lpr || $P == -6 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=6")
continue
fi
if [[ $P =~ --news || $P == -7 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=7")
continue
fi
if [[ $P == --uucp || $P == -8 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=8")
continue
fi
if [[ $P == --cron || $P == -9 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=9")
continue
fi
if [[ $P == --authpriv || $P == -10 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=10")
continue
fi
if [[ $P == --ftp || $P == -11 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=11")
continue
fi
if [[ $P == --local0 || $P == -16 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=16")
continue
fi
if [[ $P == --local1 || $P == -17 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=17")
continue
fi
# In our system, local2 is sshd log
if [[ $P == --local2 || $P == -18 || $P == --ssh ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=18")
continue
fi
# In our system, local3 is pdns-recursor log
if [[ $P == --local3 || $P == -19 || $P == --dns ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=19")
continue
fi
if [[ $P == --local4 || $P == -20 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=20")
continue
fi
if [[ $P == --local5 || $P == -21 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=21")
continue
fi
if [[ $P == --local6 || $P == -22 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=22")
continue
fi
if [[ $P == --local7 || $P == -23 ]]; then
(( SYSLOGSEL += 1 )); if [[ $SYSLOGSEL -gt 1 ]]; then break; fi
MATCHES+=("SYSLOG_FACILITY=23")
continue
fi
# Additional options
if [[ $P =~ ^(--tail|-t|--follow|-f) ]]; then
OPTIONS+=("--follow") # yup, "journalctl" uses "follow" instead of "tail"
continue
fi
if [[ $P =~ ^(--pager-end|-e|--bottom|--btm|--end) ]]; then
OPTIONS+=("--pager-end")
continue
fi
if [[ $P =~ ^(--help|-h) ]]; then
HELP=1
break
fi
# if we are here, we encountered something unknown in P
# if UNKNOWN is already set, add a comma for separation
if [[ -n $UNKNOWN ]]; then
UNKNOWN="$UNKNOWN,"
fi
UNKNOWN="${UNKNOWN}${P}"
done
if [[ $SYSLOGSEL -gt 1 ]]; then
echo "More than one facility selected" >&2
HELP=1
fi
if [[ -n $UNKNOWN ]]; then
echo "Unknown parameters '$UNKNOWN'" >&2
HELP=1
fi
if [[ -n $HELP ]]; then
# Only in our setup:
SPECIAL_16
cat >&2 <<HERE
Facilities:
--kern[el] , -0
--user , -1
--mail , -2
--daemon , -3
--auth , -4 , --selinux
--syslog , -5
--lpr , -6
--news , -7
--uucp , -8
--cron , -9
--authpriv , -10
--ftp , -11
--local0 , -16
--local1 , -17
--local2 , -18 , --ssh
--local3 , -19 , --dns
--local4 , -20
--local5 , -21
--local6 , -22
--local7 , -23
Options:
--tail , --follow , -t , -f
--pager-end, --btm, --bottom, --end, -e
HERE
exit 1
fi
}
processOptions "$@"
declare -a ALL
ALL=()
if [[ -n ${OPTIONS[@]:-""} ]]; then
ALL+=(${OPTIONS[@]})
fi
if [[ -n ${MATCHES[@]:-""} ]]; then
ALL+=(${MATCHES[@]})
fi
if [[ -n ${ALL[@]:-""} ]]; then
echo Running journalctl "${ALL[@]}" >&2
journalctl "${ALL[@]}"
else
echo "Nothing set"
fi