]> git.proxmox.com Git - ceph.git/blame - ceph/src/stop.sh
import quincy beta 17.1.0
[ceph.git] / ceph / src / stop.sh
CommitLineData
9f95a23c 1#!/usr/bin/env bash
20effc67
TL
2# -*- mode:sh; tab-width:4; sh-basic-offset:4; indent-tabs-mode:nil -*-
3# vim: softtabstop=4 shiftwidth=4 expandtab
7c673cae
FG
4#
5# Copyright (C) 2013 Inktank <info@inktank.com>
6# Copyright (C) 2013 Cloudwatt <libre.licensing@cloudwatt.com>
7#
8# Author: Loic Dachary <loic@dachary.org>
9#
10# This program is free software; you can redistribute it and/or modify
11# it under the terms of the GNU Library Public License as published by
12# the Free Software Foundation; either version 2, or (at your option)
13# any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU Library Public License for more details.
19#
20
21test -d dev/osd0/. && test -e dev/sudo && SUDO="sudo"
22
23if [ -e CMakeCache.txt ]; then
7c673cae
FG
24 [ -z "$CEPH_BIN" ] && CEPH_BIN=bin
25fi
26
11fdf7f2
TL
27if [ -n "$VSTART_DEST" ]; then
28 CEPH_CONF_PATH=$VSTART_DEST
29else
30 CEPH_CONF_PATH="$PWD"
31fi
32conf_fn="$CEPH_CONF_PATH/ceph.conf"
f6b5b4d7 33CEPHADM_DIR_PATH="$CEPH_CONF_PATH/../src/cephadm"
11fdf7f2 34
7c673cae
FG
35MYUID=$(id -u)
36MYNAME=$(id -nu)
37
38do_killall() {
9f95a23c
TL
39 local pname="ceph-run.*$1"
40 if [ $1 == "ganesha.nfsd" ]; then
41 pname=$1
42 fi
43 pg=`pgrep -u $MYUID -f $pname`
7c673cae
FG
44 [ -n "$pg" ] && kill $pg
45 $SUDO killall -u $MYNAME $1
46}
47
20effc67
TL
48maybe_kill() {
49 local p=$1
50 shift
51 local step=$1
52 shift
53 case $step in
54 0)
55 # killing processes
56 pkill -SIGTERM -u $MYUID $p
57 return 1
58 ;;
59 [1-5])
60 # wait for processes to stop
61 if pkill -0 -u $MYUID $p; then
62 # $p is still alive
63 return 1
64 fi
65 ;;
66 8)
67 # kill and print if some left
68 if pkill -0 -u $MYUID $p; then
69 echo "WARNING: $p did not orderly shutdown, killing it hard!" >&2
70 pkill -SIGKILL -u $MYUID $p
71 fi
72 ;;
73 esac
74}
75
f6b5b4d7
TL
76do_killcephadm() {
77 FSID=$($CEPH_BIN/ceph -c $conf_fn fsid)
78 sudo $CEPHADM_DIR_PATH/cephadm rm-cluster --fsid $FSID --force
79}
80
9f95a23c
TL
81do_umountall() {
82 #VSTART_IP_PORTS is of the format as below
83 #"[v[num]:IP:PORT/0,v[num]:IP:PORT/0][v[num]:IP:PORT/0,v[num]:IP:PORT/0]..."
84 VSTART_IP_PORTS=$("${CEPH_BIN}"/ceph -c $conf_fn mon metadata 2>/dev/null | jq -j '.[].addrs')
85
86 #SRC_MNT_ARRAY is of the format as below
87 #SRC_MNT_ARRAY[0] = IP:PORT,IP:PORT,IP:PORT:/
88 #SRC_MNT_ARRAY[1] = MNT_POINT1
89 #SRC_MNT_ARRAY[2] = IP:PORT:/ #Could be mounted using single mon IP
90 #SRC_MNT_ARRAY[3] = MNT_POINT2
91 #...
92 SRC_MNT_ARRAY=($(findmnt -t ceph -n --raw --output=source,target))
93 LEN_SRC_MNT_ARRAY=${#SRC_MNT_ARRAY[@]}
94
95 for (( i=0; i<${LEN_SRC_MNT_ARRAY}; i=$((i+2)) ))
96 do
97 # The first IP:PORT among the list is checked against vstart monitor IP:PORTS
98 IP_PORT1=$(echo ${SRC_MNT_ARRAY[$i]} | awk -F ':/' '{print $1}' | awk -F ',' '{print $1}')
99 if [[ "$VSTART_IP_PORTS" == *"$IP_PORT1"* ]]
100 then
101 CEPH_MNT=${SRC_MNT_ARRAY[$((i+1))]}
102 [ -n "$CEPH_MNT" ] && sudo umount -f $CEPH_MNT
103 fi
104 done
105
106 #Get fuse mounts of the cluster
107 CEPH_FUSE_MNTS=$("${CEPH_BIN}"/ceph -c $conf_fn tell mds.* client ls 2>/dev/null | grep mount_point | tr -d '",' | awk '{print $2}')
108 [ -n "$CEPH_FUSE_MNTS" ] && sudo umount -f $CEPH_FUSE_MNTS
109}
110
f6b5b4d7 111usage="usage: $0 [all] [mon] [mds] [osd] [rgw] [nfs] [--crimson] [--cephadm]\n"
7c673cae
FG
112
113stop_all=1
114stop_mon=0
115stop_mds=0
116stop_osd=0
117stop_mgr=0
118stop_rgw=0
9f95a23c
TL
119stop_ganesha=0
120ceph_osd=ceph-osd
f6b5b4d7 121stop_cephadm=0
7c673cae
FG
122
123while [ $# -ge 1 ]; do
124 case $1 in
125 all )
126 stop_all=1
127 ;;
128 mon | ceph-mon )
129 stop_mon=1
130 stop_all=0
131 ;;
132 mgr | ceph-mgr )
133 stop_mgr=1
134 stop_all=0
135 ;;
136 mds | ceph-mds )
137 stop_mds=1
138 stop_all=0
139 ;;
140 osd | ceph-osd )
141 stop_osd=1
142 stop_all=0
143 ;;
144 rgw | ceph-rgw )
145 stop_rgw=1
146 stop_all=0
147 ;;
f6b5b4d7 148 nfs | ganesha.nfsd )
9f95a23c
TL
149 stop_ganesha=1
150 stop_all=0
151 ;;
152 --crimson)
153 ceph_osd=crimson-osd
154 ;;
f6b5b4d7
TL
155 --cephadm)
156 stop_cephadm=1
157 stop_all=0
158 ;;
7c673cae
FG
159 * )
160 printf "$usage"
161 exit
162 esac
163 shift
164done
165
166if [ $stop_all -eq 1 ]; then
9f95a23c
TL
167 if "${CEPH_BIN}"/ceph -s --connect-timeout 1 -c $conf_fn >/dev/null 2>&1; then
168 # Umount mounted filesystems from vstart cluster
169 do_umountall
170 fi
171
11fdf7f2
TL
172 if "${CEPH_BIN}"/rbd device list -c $conf_fn >/dev/null 2>&1; then
173 "${CEPH_BIN}"/rbd device list -c $conf_fn | tail -n +2 |
7c673cae
FG
174 while read DEV; do
175 # While it is currently possible to create an rbd image with
176 # whitespace chars in its name, krbd will refuse mapping such
177 # an image, so we can safely split on whitespace here. (The
178 # same goes for whitespace chars in names of the pools that
179 # contain rbd images).
180 DEV="$(echo "${DEV}" | tr -s '[:space:]' | awk '{ print $5 }')"
11fdf7f2 181 sudo "${CEPH_BIN}"/rbd device unmap "${DEV}" -c $conf_fn
7c673cae
FG
182 done
183
11fdf7f2 184 if [ -n "$("${CEPH_BIN}"/rbd device list -c $conf_fn)" ]; then
7c673cae
FG
185 echo "WARNING: Some rbd images are still mapped!" >&2
186 fi
187 fi
188
f6b5b4d7
TL
189 daemons="$($CEPHADM_DIR_PATH/cephadm ls 2> /dev/null)"
190 if [ $? -eq 0 -a "$daemons" != "[]" ]; then
191 do_killcephadm
192 fi
193
20effc67
TL
194 # killing processes
195 to_kill="$ceph_osd ceph-mon ceph-mds ceph-mgr radosgw lt-radosgw apache2 ganesha.nfsd"
196 since_kill=0
197 for step in 0 1 1 2 3 5 8; do
198 sleep $step
199 since_kill=$((since_kill + step))
200 survivors=''
201 for p in $to_kill; do
202 if ! maybe_kill "$p" $step; then
203 survivors+=" $p"
7c673cae 204 fi
7c673cae 205 done
20effc67
TL
206 if [ -z "$survivors" ]; then
207 break
208 fi
209 to_kill=$survivors
210 if [ $since_kill -gt 0 ]; then
211 echo "WARNING: $to_kill still alive after $since_kill seconds" >&2
212 fi
7c673cae
FG
213 done
214
215 pkill -u $MYUID -f valgrind.bin.\*ceph-mon
9f95a23c 216 $SUDO pkill -u $MYUID -f valgrind.bin.\*$ceph_osd
7c673cae 217 pkill -u $MYUID -f valgrind.bin.\*ceph-mds
11fdf7f2 218 asok_dir=`dirname $("${CEPH_BIN}"/ceph-conf -c ${conf_fn} --show-config-value admin_socket)`
c07f9fc5 219 rm -rf "${asok_dir}"
7c673cae
FG
220else
221 [ $stop_mon -eq 1 ] && do_killall ceph-mon
222 [ $stop_mds -eq 1 ] && do_killall ceph-mds
9f95a23c 223 [ $stop_osd -eq 1 ] && do_killall $ceph_osd
7c673cae 224 [ $stop_mgr -eq 1 ] && do_killall ceph-mgr
9f95a23c 225 [ $stop_ganesha -eq 1 ] && do_killall ganesha.nfsd
7c673cae 226 [ $stop_rgw -eq 1 ] && do_killall radosgw lt-radosgw apache2
f6b5b4d7 227 [ $stop_cephadm -eq 1 ] && do_killcephadm
7c673cae 228fi