Add dynamic lookup for tcpdump binary
Currently the check will use /usr/bin/tcpdump only for Ubuntu 22.04 (jammy) but it will try to use the old /usr/sbin/tcpdump path for newer versions of Ubuntu such as 24.04 (noble) which causes the br-ex-tcpdump service to fail to start in jobs that enable it (like multinode): systemd[1]: devstack@br-ex-tcpdump.service: Main process exited, code=exited, status=203/EXEC This uses 'which' to find the path and if it is not found, use the current check in case there is anything relying on it. Change-Id: I034e8ca87909521c7e4f3e49996144f9c80d416d
This commit is contained in:
parent
2ce9ca6cdf
commit
6be68a4158
@ -117,10 +117,13 @@ if [[ "$1" == "stack" ]]; then
|
|||||||
if is_service_enabled br-ex-tcpdump ; then
|
if is_service_enabled br-ex-tcpdump ; then
|
||||||
# tcpdump monitor on br-ex for ARP, reverse ARP and ICMP v4 / v6 packets
|
# tcpdump monitor on br-ex for ARP, reverse ARP and ICMP v4 / v6 packets
|
||||||
sudo ip link set dev $PUBLIC_BRIDGE up
|
sudo ip link set dev $PUBLIC_BRIDGE up
|
||||||
if [[ "$os_CODENAME" == "jammy" ]]; then
|
TCPDUMP=$(which tcpdump)
|
||||||
TCPDUMP=/usr/bin/tcpdump
|
if [[ ! $TCPDUMP ]]; then
|
||||||
else
|
if [[ "$os_CODENAME" == "jammy" ]]; then
|
||||||
TCPDUMP=/usr/sbin/tcpdump
|
TCPDUMP=/usr/bin/tcpdump
|
||||||
|
else
|
||||||
|
TCPDUMP=/usr/sbin/tcpdump
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
run_process br-ex-tcpdump "$TCPDUMP -i $PUBLIC_BRIDGE arp or rarp or icmp or icmp6 -enlX" "$STACK_GROUP" root
|
run_process br-ex-tcpdump "$TCPDUMP -i $PUBLIC_BRIDGE arp or rarp or icmp or icmp6 -enlX" "$STACK_GROUP" root
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user