debian: Backup OVSDB db file before converting it.
[sliver-openvswitch.git] / debian / openvswitch-switch.init
1 #! /bin/sh
2 #
3 # /etc/init.d/openvswitch-switch
4 #
5 # Written by Miquel van Smoorenburg <miquels@cistron.nl>.
6 # Modified for Debian by Ian Murdock <imurdock@gnu.ai.mit.edu>.
7 # Further changes by Javier Fernandez-Sanguino <jfs@debian.org>
8 # Modified for openvswitch-switch.
9 #
10 # Version:      @(#)skeleton  1.9  26-Feb-2001  miquels@cistron.nl
11 #
12 ### BEGIN INIT INFO
13 # Provides:          openvswitch-switch
14 # Required-Start:    $network $named $remote_fs $syslog
15 # Required-Stop:     $remote_fs
16 # Default-Start:     2 3 4 5
17 # Default-Stop:      0 1 6
18 # Short-Description: Open vSwitch switch
19 ### END INIT INFO
20
21 PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
22 ovs_vswitchd=/usr/sbin/ovs-vswitchd
23 ovsdb_server=/usr/bin/ovsdb-server
24
25 (test -x $ovsdb_server && test -x $ovs_vswitchd) || exit 0
26
27 DODTIME=1                   # Time to wait for the server to die, in seconds
28                             # If this value is set too low you might not
29                             # let some servers to die gracefully and
30                             # 'restart' will not work
31
32 # Include openvswitch-switch defaults if available
33 unset OVSDB_SERVER_OPTS
34 unset OVS_VSWITCHD_OPTS
35 unset CORE_LIMIT
36 unset ENABLE_MONITOR
37 default=/etc/default/openvswitch-switch
38 if [ -f $default ] ; then
39     . $default
40 fi
41
42 : ${ENABLE_MONITOR:=y}
43
44 set -e
45
46 # running_pid pid name
47 #
48 # Check if 'pid' is a process named 'name'
49 running_pid()
50 {
51     local pid=$1 name=$2
52     [ -z "$pid" ] && return 1 
53     [ ! -d /proc/$pid ] &&  return 1
54     cmd=`cat /proc/$pid/cmdline | tr "\000" "\n"|head -n 1 |cut -d : -f 1`
55     # Is this the expected child?
56     case $cmd in
57         $name|*/$name)
58             return 0
59             ;;
60         *)
61             return 1
62             ;;
63     esac
64 }
65
66 # running name
67 #
68 # Checks for a running process named 'name' by looking for a pidfile
69 # named /var/run/openvswitch/${name}.pid
70 running()
71 {
72     local name=$1
73     local pidfile=/var/run/openvswitch/${name}.pid
74
75     # No pidfile, probably no daemon present
76     [ ! -f "$pidfile" ] && return 1
77
78     # Obtain the pid and check it against the binary name
79     pid=`cat $pidfile`
80     running_pid $pid $name || return 1
81     return 0
82 }
83
84 # force_stop name
85 #
86 # Checks for a running process named 'name', by looking for a pidfile
87 # named /var/run/openvswitch/${name}.pid, and then kills it and waits 
88 # for it to die.
89 force_stop() {
90     local name=$1
91     local pidfile=/var/run/openvswitch/${name}.pid
92
93     [ ! -f "$pidfile" ] && return
94     if running $name; then
95         kill $pid
96         [ -n "$DODTIME" ] && sleep "$DODTIME"
97         if running $name; then
98             kill -KILL $pid
99             [ -n "$DODTIME" ] && sleep "$DODTIME"
100             if running $name; then
101                 echo "Cannot kill $name (pid=$pid)!"
102                 exit 1
103             fi
104         fi
105     fi
106     rm -f $pidfile
107     return 0
108 }
109
110 must_succeed() {
111     echo -n "$1: "
112     shift
113     if "$@"; then
114         echo "success."
115     else
116         echo " ERROR."
117         exit 1
118     fi
119 }
120
121 check_op() {
122     echo -n "$1: "
123     shift
124     if "$@"; then
125         echo "success."
126     else
127         echo " ERROR."
128     fi
129 }
130
131 # is_module_loaded module
132 #
133 # Returns 0 if 'module' is loaded, 1 otherwise.
134
135 is_module_loaded() {
136     local module=$1
137     grep -q "^$module " /proc/modules
138 }
139
140 # load_module module
141 #
142 # Loads 'module' into the running kernel, if it is not already loaded.
143 load_module() {
144     local module=$1
145     echo -n "Loading $module: "
146     if is_module_loaded $module; then
147         echo "already loaded, nothing to do."
148     elif modprobe $module; then
149         echo "success."
150     else
151         echo "ERROR."
152         echo "$module has probably not been built for this kernel."
153         if ! test -d /usr/share/doc/openvswitch-datapath-source; then
154             echo "Install the openvswitch-datapath-source package, then read"
155             echo "/usr/share/doc/openvswitch-datapath-source/README.Debian"
156         else
157             echo "For instructions, read"
158             echo "/usr/share/doc/openvswitch-datapath-source/README.Debian"
159         fi
160         exit 0
161     fi
162 }
163
164 # unload_module module
165 #
166 # Unloads 'module' from the running kernel, if it is loaded.
167 unload_module() {
168     local module=$1
169     echo -n "Unloading $module: "
170     if is_module_loaded $module; then
171         if rmmod $module; then
172             echo "success."
173         else
174             echo "ERROR."
175             exit 1
176         fi
177     else
178         echo "not loaded, nothing to do."
179     fi
180 }
181
182 unload_modules() {
183     if is_module_loaded openvswitch_mod; then
184         for dp in $(ovs-dpctl dump-dps); do
185             echo -n "Deleting datapath $dp: "
186             if ovs-dpctl del-dp $dp; then
187                 echo "success."
188             else
189                 echo "ERROR."
190             fi
191         done
192     fi
193     unload_module openvswitch_mod
194 }
195
196 case "$1" in
197     start)
198         conf_file=/etc/openvswitch/conf.db
199         schema_file=/usr/share/openvswitch/vswitch.ovsschema
200         schema_ver=`ovsdb-tool schema-version "$schema_file"`
201
202         load_module openvswitch_mod
203
204         if test -n "$CORE_LIMIT"; then
205             check_op "Setting core limit to $CORE_LIMIT" ulimit -c "$CORE_LIMIT"
206         fi
207
208         # Create an empty configuration database if it doesn't exist.
209         if test ! -e $conf_file; then
210             # Create configuration database.
211             ovsdb-tool -vANY:console:emer create $conf_file $schema_file
212         else
213             # If schema version changed, then back up the old version.
214             old_ver=`ovsdb-tool db-version "$conf_file"`
215             if test "X$old_ver" != "X$schema_ver"; then
216                 cp "$conf_file" "$conf_file.backup$old_ver"
217             fi
218             
219             # Upgrade or downgrade schema and compact database.
220             ovsdb-tool -vANY:console:emer convert $conf_file $schema_file
221         fi
222
223         if test "$ENABLE_MONITOR" = y; then
224             monitor_opt=--monitor
225         else
226             monitor_opt=
227         fi
228
229         if [ ! -d /var/run/openvswitch ]; then
230             install -d -m 755 -o root -g root /var/run/openvswitch
231         fi
232
233         if [ ! -d /var/log/openvswitch ]; then
234             install -d -m 755 -o root -g root /var/log/openvswitch
235         fi
236
237         if [ ! -d /var/log/openvswitch/cores ]; then
238             install -d -m 755 -o root -g root /var/log/openvswitch/cores
239         fi
240
241         # Start ovsdb-server.
242         set --
243         set -- "$@" $conf_file
244         set -- "$@" --verbose=ANY:console:emer --verbose=ANY:syslog:err
245         set -- "$@" --log-file=/var/log/openvswitch/ovsdb-server.log
246         set -- "$@" --detach --no-chdir --pidfile $monitor_opt
247         set -- "$@" --remote punix:/var/run/openvswitch/db.sock
248         set -- "$@" --remote db:Open_vSwitch,managers
249         set -- "$@" --remote db:Open_vSwitch,manager_options
250         set -- "$@" --private-key=db:SSL,private_key
251         set -- "$@" --certificate=db:SSL,certificate
252         set -- "$@" --bootstrap-ca-cert=db:SSL,ca_cert
253         set -- "$@" $OVSDB_SERVER_OPTS
254         echo -n "Starting ovsdb-server: "
255         start-stop-daemon --start --quiet --oknodo \
256             --pidfile /var/run/openvswitch/ovsdb-server.pid \
257             --chdir /var/log/openvswitch/cores              \
258             --exec $ovsdb_server -- "$@"
259         if running ovsdb-server; then
260             echo "ovsdb-server."
261         else
262             echo " ERROR."
263         fi
264
265         ovs-vsctl --no-wait --timeout=5 init -- set Open_vSwitch . db-version="$schema_ver"
266
267         # Start ovs-vswitchd.
268         set --
269         set -- "$@" --verbose=ANY:console:emer --verbose=ANY:syslog:err
270         set -- "$@" --log-file=/var/log/openvswitch/ovs-vswitchd.log
271         set -- "$@" --detach --no-chdir --pidfile $monitor_opt
272         set -- "$@" unix:/var/run/openvswitch/db.sock
273         set -- "$@" $OVS_VSWITCHD_OPTS
274         echo -n "Starting ovs-vswitchd: "
275         start-stop-daemon --start --quiet --oknodo \
276             --pidfile /var/run/openvswitch/ovs-vswitchd.pid \
277             --chdir /var/log/openvswitch/cores              \
278             --exec $ovs_vswitchd -- "$@"
279         if running ovs-vswitchd; then
280             echo "ovs-vswitchd."
281         else
282             echo " ERROR."
283         fi
284         ;;
285     stop)
286         echo -n "Stopping ovs-vswitchd: "
287         start-stop-daemon --stop --quiet --oknodo --retry 5 \
288             --pidfile /var/run/openvswitch/ovs-vswitchd.pid \
289             --chdir /var/log/openvswitch/cores              \
290             --exec $ovs_vswitchd
291         echo "ovs-vswitchd."
292
293         echo -n "Stopping ovsdb-server: "
294         start-stop-daemon --stop --quiet --oknodo --retry 5 \
295             --pidfile /var/run/openvswitch/ovsdb-server.pid \
296             --chdir /var/log/openvswitch/cores              \
297             --exec $ovsdb_server
298         echo "ovsdb-server."
299         ;;
300     force-stop)
301         echo -n "Forcefully stopping ovs-vswitchd: "
302         force_stop ovs-vswitchd
303         if ! running ovs-vswitchd; then
304             echo "ovs-vswitchd."
305         else
306             echo " ERROR."
307         fi
308
309         echo -n "Forcefully stopping ovsdb-server: "
310         force_stop ovsdb-server
311         if ! running ovsdb-server; then
312             echo "ovsdb-server."
313         else
314             echo " ERROR."
315         fi
316         ;;
317     unload)
318         unload_modules
319         ;;
320     reload)
321         ;;
322     force-reload)
323         # Nothing to do, since ovs-vswitchd automatically reloads
324         # whenever its configuration changes, and ovsdb-server doesn't
325         # have anything to reload.
326         ;;
327     restart)
328         $0 stop || true
329         $0 start
330         ;;
331     status)
332         for daemon in ovs-vswitchd ovsdb-server; do
333             echo -n "$daemon is "
334             if running $daemon;  then
335                 echo "running"
336             else
337                 echo "not running."
338                 exit 1
339             fi
340         done
341         ;;
342     *)
343         N=/etc/init.d/openvswitch-switch
344         echo "Usage: $N {start|stop|restart|force-reload|status|force-stop|unload}" >&2
345         exit 1
346         ;;
347 esac
348
349 exit 0