我写了下面的systemd服务tcpdumpd.service
来启动持久的tcpdump录制。
[Unit]
Description=TCPDumpd
After=multi-user.target network.target
[Service]
Type=simple
ExecStart=/usr/sbin/tcpdump -pni eth0 -s65535 -G 3600 -w '/var/log/tcpdump/trace_%Y-%m-%d_%H:%M:%S.pcap' -z gzip
Restart=on-abort
[Install]
WantedBy=multi-user.target
tcpdump允许strftime-placeholder如%H表示小时,%M表示分钟等等,允许您创建带时间戳的文件。
但是,systemd具有可以在其中使用的特殊说明符,例如(%n,%N,%p,%i,%U,%u,%m,%H,%b,%v)所以任何说明符重叠,如%m和%H传递来自systemd的信息,并且不允许占位符传递给tcpdump来制作时间戳。
有谁知道是否有办法逃脱systemd中的说明符所以我可以将%m和%H传递给tcpdump?
我试图逃避特殊说明,如%%m
,\%m
没有运气。
但是,如果您需要完成工作,这里有解决方法:
创建包含TCPDUMP_FORMAT变量定义的文件tcpdumpd.environment
。
TCPDUMP_FORMAT=%Y-%m-%d_%H:%M:%S
修改tcpdumpd.service
:添加EnvironmentFile=
选项并用${TCPDUMP_FORMAT}
替换格式字符串。
[Unit]
Description=TCPDumpd
After=multi-user.target network.target
[Service]
Type=simple
EnvironmentFile=tcpdumpd.environment
ExecStart=/usr/sbin/tcpdump -pni eth0 -s65535 -G 3600 -w '/var/log/tcpdump/trace_${TCPDUMP_FORMAT}.pcap' -z gzip
Restart=on-abort
[Install]
WantedBy=multi-user.target
有谁知道是否有办法逃脱systemd中的说明符所以我可以将%m和%H传递给tcpdump?
是的:%%m
和%%H
。
“%%”|单百分号|使用“%%”代替“%”来指定单个百分号。