3 # Copyright (C) 2013 Inktank <info@inktank.com>
4 # Copyright (C) 2013 Cloudwatt <libre.licensing@cloudwatt.com>
6 # Author: Loic Dachary <loic@dachary.org>
8 # This program is free software; you can redistribute it and/or modify
9 # it under the terms of the GNU Library Public License as published by
10 # the Free Software Foundation; either version 2, or (at your option)
13 # This program is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 # GNU Library Public License for more details.
19 test -d dev
/osd
0/.
&& test -e dev
/sudo
&& SUDO
="sudo"
21 if [ -e CMakeCache.txt
]; then
22 [ -z "$CEPH_BIN" ] && CEPH_BIN
=bin
25 if [ -n "$VSTART_DEST" ]; then
26 CEPH_CONF_PATH
=$VSTART_DEST
30 conf_fn
="$CEPH_CONF_PATH/ceph.conf"
31 CEPHADM_DIR_PATH
="$CEPH_CONF_PATH/../src/cephadm"
37 local pname
="ceph-run.*$1"
38 if [ $1 == "ganesha.nfsd" ]; then
41 pg
=`pgrep -u $MYUID -f $pname`
42 [ -n "$pg" ] && kill $pg
43 $SUDO killall
-u $MYNAME $1
47 FSID
=$
($CEPH_BIN/ceph
-c $conf_fn fsid
)
48 sudo
$CEPHADM_DIR_PATH/cephadm rm-cluster
--fsid $FSID --force
52 #VSTART_IP_PORTS is of the format as below
53 #"[v[num]:IP:PORT/0,v[num]:IP:PORT/0][v[num]:IP:PORT/0,v[num]:IP:PORT/0]..."
54 VSTART_IP_PORTS
=$
("${CEPH_BIN}"/ceph
-c $conf_fn mon metadata
2>/dev
/null | jq
-j '.[].addrs')
56 #SRC_MNT_ARRAY is of the format as below
57 #SRC_MNT_ARRAY[0] = IP:PORT,IP:PORT,IP:PORT:/
58 #SRC_MNT_ARRAY[1] = MNT_POINT1
59 #SRC_MNT_ARRAY[2] = IP:PORT:/ #Could be mounted using single mon IP
60 #SRC_MNT_ARRAY[3] = MNT_POINT2
62 SRC_MNT_ARRAY
=($
(findmnt
-t ceph
-n --raw --output=source,target
))
63 LEN_SRC_MNT_ARRAY
=${#SRC_MNT_ARRAY[@]}
65 for (( i
=0; i
<${LEN_SRC_MNT_ARRAY}; i
=$
((i
+2)) ))
67 # The first IP:PORT among the list is checked against vstart monitor IP:PORTS
68 IP_PORT1
=$
(echo ${SRC_MNT_ARRAY[$i]} |
awk -F ':/' '{print $1}' |
awk -F ',' '{print $1}')
69 if [[ "$VSTART_IP_PORTS" == *"$IP_PORT1"* ]]
71 CEPH_MNT
=${SRC_MNT_ARRAY[$((i+1))]}
72 [ -n "$CEPH_MNT" ] && sudo umount
-f $CEPH_MNT
76 #Get fuse mounts of the cluster
77 CEPH_FUSE_MNTS
=$
("${CEPH_BIN}"/ceph
-c $conf_fn tell mds.
* client
ls 2>/dev
/null |
grep mount_point |
tr -d '",' |
awk '{print $2}')
78 [ -n "$CEPH_FUSE_MNTS" ] && sudo umount
-f $CEPH_FUSE_MNTS
81 usage
="usage: $0 [all] [mon] [mds] [osd] [rgw] [nfs] [--crimson] [--cephadm]\n"
93 while [ $# -ge 1 ]; do
136 if [ $stop_all -eq 1 ]; then
137 if "${CEPH_BIN}"/ceph
-s --connect-timeout 1 -c $conf_fn >/dev
/null
2>&1; then
138 # Umount mounted filesystems from vstart cluster
142 if "${CEPH_BIN}"/rbd device list
-c $conf_fn >/dev
/null
2>&1; then
143 "${CEPH_BIN}"/rbd device list
-c $conf_fn |
tail -n +2 |
145 # While it is currently possible to create an rbd image with
146 # whitespace chars in its name, krbd will refuse mapping such
147 # an image, so we can safely split on whitespace here. (The
148 # same goes for whitespace chars in names of the pools that
149 # contain rbd images).
150 DEV
="$(echo "${DEV}" | tr -s '[:space:]' | awk '{ print $5 }')"
151 sudo
"${CEPH_BIN}"/rbd device unmap
"${DEV}" -c $conf_fn
154 if [ -n "$("${CEPH_BIN}"/rbd device list -c $conf_fn)" ]; then
155 echo "WARNING: Some rbd images are still mapped!" >&2
159 daemons
="$($CEPHADM_DIR_PATH/cephadm ls 2> /dev/null)"
160 if [ $?
-eq 0 -a "$daemons" != "[]" ]; then
164 for p
in $ceph_osd ceph-mon ceph-mds ceph-mgr radosgw lt-radosgw apache2 ganesha.nfsd
; do
165 for try
in 0 1 1 1 1 ; do
166 if ! pkill
-u $MYUID $p ; then
173 pkill
-u $MYUID -f valgrind.bin.\
*ceph-mon
174 $SUDO pkill
-u $MYUID -f valgrind.bin.\
*$ceph_osd
175 pkill
-u $MYUID -f valgrind.bin.\
*ceph-mds
176 asok_dir
=`dirname $("${CEPH_BIN}"/ceph-conf -c ${conf_fn} --show-config-value admin_socket)`
179 [ $stop_mon -eq 1 ] && do_killall ceph-mon
180 [ $stop_mds -eq 1 ] && do_killall ceph-mds
181 [ $stop_osd -eq 1 ] && do_killall
$ceph_osd
182 [ $stop_mgr -eq 1 ] && do_killall ceph-mgr
183 [ $stop_ganesha -eq 1 ] && do_killall ganesha.nfsd
184 [ $stop_rgw -eq 1 ] && do_killall radosgw lt-radosgw apache2
185 [ $stop_cephadm -eq 1 ] && do_killcephadm