Fix file descriptor inheritance in ceph.sh script
The ceph.sh script is called by the mtcClient process during the system start-up. This script will then start the Ceph processes. The mtcClient uses the UDP port 2119 to communicate with other hosts, and these Ceph processes inherit the UDP port from the mtcClient because the file descriptor is kept open when forking the application. When the mtcClient process restarts, the Ceph processes with the inherited file descriptor will automatically start using that UDP port, blocking the mtcClient from binding to that port. The solution is to call the ceph-init-wrapper script using the "systemd-run" command as a transient service with "--pipe" and "--wait" to isolate all the FDs except for the stdin/stdout/stderr. Test-Plan: PASS: Multi-node system - Unmanage and stop all Ceph processes on controller-0, and kill the mtcClient process twice. Check if only mtcClient is listed using UDP port 2119 by running 'sudo lsof -iUDP:2119'. PASS: Deploy AIO-SX and check if Ceph status is HEALTH_OK. The mtcClient will not bind UDP 2119 port in this configuration. PASS: Deploy AIO-DX and check if only mtcClient is listed using UDP port 2119 by running 'sudo lsof -iUDP:2119'. Closes-bug: 2090928 Signed-off-by: Felipe Sanches Zanoni <Felipe.SanchesZanoni@windriver.com> Change-Id: I5091953bc370ae60e972ef9f383aaab84f2781f0
This commit is contained in:
parent
c53d7e145f
commit
89ba3c0e88
@ -8,7 +8,10 @@ INITDIR=/etc/init.d
|
|||||||
LOGFILE=/var/log/ceph/ceph-init.log
|
LOGFILE=/var/log/ceph/ceph-init.log
|
||||||
CEPH_STARTED_FLAG=/var/run/.ceph_started
|
CEPH_STARTED_FLAG=/var/run/.ceph_started
|
||||||
CEPH_CONFIGURED_FLAG=/etc/platform/.node_ceph_configured
|
CEPH_CONFIGURED_FLAG=/etc/platform/.node_ceph_configured
|
||||||
CEPH_INIT="${INITDIR}/ceph-init-wrapper"
|
|
||||||
|
# Call ceph-init-wrapper script with systemd-run to avoid inheriting any
|
||||||
|
# unwanted file descriptor.
|
||||||
|
CEPH_INIT="systemd-run --pipe --wait ${INITDIR}/ceph-init-wrapper"
|
||||||
|
|
||||||
# Get system/node configuration
|
# Get system/node configuration
|
||||||
. /etc/platform/platform.conf
|
. /etc/platform/platform.conf
|
||||||
|
Loading…
Reference in New Issue
Block a user