xenserver: Modify init scripts to use new configuration database
[openvswitch] / xenserver / etc_init.d_vswitch
1 #!/bin/bash
2 #
3 # vswitch
4 #
5 # chkconfig: 2345 09 91
6 # description: Manage vswitch kernel modules and user-space daemon
7
8 # Copyright (C) 2009 Nicira Networks, Inc.
9 #
10 # Licensed under the Apache License, Version 2.0 (the "License");
11 # you may not use this file except in compliance with the License.
12 # You may obtain a copy of the License at:
13 #
14 #     http://www.apache.org/licenses/LICENSE-2.0
15 #
16 # Unless required by applicable law or agreed to in writing, software
17 # distributed under the License is distributed on an "AS IS" BASIS,
18 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 # See the License for the specific language governing permissions and
20 # limitations under the License.
21
22 . /etc/init.d/functions
23
24 test -e /etc/sysconfig/vswitch && . /etc/sysconfig/vswitch
25
26 # General config variables in /etc/sysconfig/vswitch
27 : ${ENABLE_BRCOMPAT:=y}
28 : ${ENABLE_FAKE_PROC_NET:=y}
29 : ${FORCE_COREFILES:=y}
30
31 # Config variables specific to ovsdb-server
32 : ${OVSDB_SERVER_LISTEN:=punix:/var/run/ovsdb-server}
33 : ${OVSDB_SERVER_CONNECT:=}
34 : ${OVSDB_SERVER_DB:=/etc/ovs-vswitchd.conf.db}
35 : ${OVSDB_SERVER_PIDFILE:=/var/run/ovsdb-server.pid}
36 : ${OVSDB_SERVER_RUN_DIR:=/var/xen/vswitch}
37 : ${OVSDB_SERVER_PRIORITY:=-10}
38 : ${OVSDB_SERVER_LOGFILE:=/var/log/ovsdb-server.log}
39 : ${OVSDB_SERVER_FILE_LOGLEVEL:=INFO}
40 : ${OVSDB_SERVER_SYSLOG_LOGLEVEL:=ERR}
41 : ${OVSDB_SERVER_MEMLEAK_LOGFILE:=}
42 : ${OVSDB_SERVER_STRACE_LOG:=}
43 : ${OVSDB_SERVER_STRACE_OPT:=}
44 : ${OVSDB_SERVER_VALGRIND_LOG:=}
45 : ${OVSDB_SERVER_VALGRIND_OPT:=}
46
47 # Config variables specific to ovs-vswitchd
48 : ${VSWITCHD_OVSDB_SERVER:=unix:/var/run/ovsdb-server}
49 : ${VSWITCHD_OVSDB_SCHEMA:=/usr/share/vswitch/vswitch-idl.ovsschema}
50 : ${VSWITCHD_PIDFILE:=/var/run/ovs-vswitchd.pid}
51 : ${VSWITCHD_RUN_DIR:=/var/xen/vswitch}
52 : ${VSWITCHD_PRIORITY:=-10}
53 : ${VSWITCHD_LOGFILE:=/var/log/ovs-vswitchd.log}
54 : ${VSWITCHD_FILE_LOGLEVEL:=INFO}
55 : ${VSWITCHD_SYSLOG_LOGLEVEL:=ERR}
56 : ${VSWITCHD_MEMLEAK_LOGFILE:=}
57 : ${VSWITCHD_STRACE_LOG:=}
58 : ${VSWITCHD_STRACE_OPT:=}
59 : ${VSWITCHD_VALGRIND_LOG:=}
60 : ${VSWITCHD_VALGRIND_OPT:=}
61
62 # Config variables specific to ovs-brcompatd
63 : ${BRCOMPATD_PIDFILE:=/var/run/ovs-brcompatd.pid}
64 : ${BRCOMPATD_RUN_DIR:=/var/xen/vswitch}
65 : ${BRCOMPATD_PRIORITY:=-10}
66 : ${BRCOMPATD_LOGFILE:=/var/log/ovs-brcompatd.log}
67 : ${BRCOMPATD_FILE_LOGLEVEL:=INFO}
68 : ${BRCOMPATD_SYSLOG_LOGLEVEL:=ERR}
69 : ${BRCOMPATD_MEMLEAK_LOGFILE:=}
70 : ${BRCOMPATD_STRACE_LOG:=}
71 : ${BRCOMPATD_STRACE_OPT:=}
72 : ${BRCOMPATD_VALGRIND_LOG:=}
73 : ${BRCOMPATD_VALGRIND_OPT:=}
74
75 # Full paths to executables & modules
76 ovsdb_server="/usr/sbin/ovsdb-server"
77 ovsdb_tool="/usr/bin/ovsdb-tool"
78 vswitchd="/usr/sbin/ovs-vswitchd"
79 brcompatd="/usr/sbin/ovs-brcompatd"
80 dpctl="/usr/bin/ovs-dpctl"
81 appctl="/usr/bin/ovs-appctl"
82 ofctl="/usr/bin/ovs-ofctl"
83
84
85 if [ "$ENABLE_FAKE_PROC_NET" = "y" ]; then
86     if [ "$ENABLE_BRCOMPAT" != "y" ]; then
87         warning "FAKE_PROC_NET required BRCOMPAT which was disabled.  Force enabling."
88         ENABLE_BRCOMPAT="y"
89     fi
90 fi
91
92 function dp_list {
93     "$dpctl" show | grep '^dp[0-9]\+:' | cut -d':' -f 1
94 }
95
96 function turn_on_corefiles {
97     ulimit -Sc 67108864
98 }
99
100 function remove_all_dp {
101     for dp in $(dp_list); do
102         action "Removing datapath: $dp" "$dpctl" del-dp "$dp"
103     done
104 }
105
106 function insert_modules_if_required {
107     if ! lsmod | grep -q "openvswitch_mod"; then
108         action "Inserting llc module" modprobe llc
109         action "Inserting openvswitch module" modprobe openvswitch_mod
110     fi
111     if [ -n "$BRCOMPATD_PIDFILE" ] && ! lsmod | grep -q "brcompat_mod"; then
112         action "Inserting brcompat module" modprobe brcompat_mod
113     fi
114     if [ -f "/lib/modules/`uname -r`/kernel/net/vswitch/ip_gre_mod.ko" ] && ! lsmod | grep -q "ip_gre_mod"; then
115         action "Inserting ip_gre module" modprobe ip_gre_mod
116     fi
117 }
118
119 function remove_modules {
120     if lsmod | grep -q "brcompat_mod"; then
121         action "Removing brcompat module" rmmod brcompat_mod.ko
122     fi
123     if lsmod | grep -q "openvswitch_mod"; then
124         action "Removing openvswitch module" rmmod openvswitch_mod.ko
125     fi
126     if lsmod | grep -q "ip_gre_mod"; then
127         action "Removing ip_gre module" rmmod ip_gre_mod.ko
128     fi
129 }
130
131 function reload_vswitchd {
132     if [ -f "$VSWITCHD_PIDFILE" ]; then
133         "$appctl" --target=/var/run/ovs-vswitchd.`cat $VSWITCHD_PIDFILE`.ctl vswitchd/reload
134     fi
135 }
136
137 function reload_brcompatd {
138     if [ -f "$BRCOMPATD_PIDFILE" ]; then
139         "$appctl" --target=/var/run/ovs-brcompatd.`cat $BRCOMPATD_PIDFILE`.ctl vlog/reopen
140     fi
141 }
142
143 function start_ovsdb_server {
144     local syslog_opt="-vANY:SYSLOG:${OVSDB_SERVER_SYSLOG_LOGLEVEL}"
145     local logfile_file_opt=""
146     local logfile_level_opt=""
147     if [ ! -d "$OVSDB_SERVER_RUN_DIR" ]; then
148         mkdir -p "$OVSDB_SERVER_RUN_DIR"
149     fi
150     cd "$OVSDB_SERVER_RUN_DIR"
151     local listen_method=""
152     if [ -n "$OVSDB_SERVER_LISTEN" ]; then
153         listen_method="--listen=$OVSDB_SERVER_LISTEN"
154     fi
155     local connect_method=""
156     if [ -n "$OVSDB_SERVER_CONNECT" ]; then
157         connect_method="--connect=$OVSDB_SERVER_CONNECT"
158     fi
159     if [ -n "$OVSDB_SERVER_FILE_LOGLEVEL" ]; then
160         logfile_level_opt="-vANY:FILE:${OVSDB_SERVER_FILE_LOGLEVEL}"
161         logfile_file_opt="--log-file=$OVSDB_SERVER_LOGFILE"
162     fi
163     local leak_opt=""
164     if [ -n "$OVSDB_SERVER_MEMLEAK_LOGFILE" ]; then
165         leak_opt="--check-leaks=$OVSDB_SERVER_MEMLEAK_LOGFILE"
166         if [ -e "$OVSDB_SERVER_MEMLEAK_LOGFILE" ]; then
167             mv "$OVSDB_SERVER_MEMLEAK_LOGFILE" "$OVSDB_SERVER_MEMLEAK_LOGFILE.prev"
168         fi
169     fi
170     local strace_opt=""
171     local daemonize="y"
172     if [ -n "$OVSDB_SERVER_STRACE_LOG" ] && [ -n "$OVSDB_SERVER_VALGRIND_LOG" ]; then
173         printf "Can not start with both VALGRIND and STRACE\n"
174         exit 1
175     fi
176     if [ -n "$OVSDB_SERVER_STRACE_LOG" ]; then
177         strace_opt="strace -o $OVSDB_SERVER_STRACE_LOG $OVSDB_SERVER_STRACE_OPT"
178         daemonize="n"
179     fi
180     if [ -n "$OVSDB_SERVER_VALGRIND_LOG" ]; then
181         valgrind_opt="valgrind --log-file=$OVSDB_SERVER_VALGRIND_LOG $OVSDB_SERVER_VALGRIND_OPT"
182         daemonize="n"
183     fi
184     if [ "$daemonize" != "y" ]; then
185         # Start in background and force a "success" message
186         action "Starting ovsdb_server ($strace_opt$valgrind_opt)" true
187         (nice -n "$OVSDB_SERVER_PRIORITY" $strace_opt $valgrind_opt "$ovsdb_server" "$OVSDB_SERVER_DB" --pidfile="$OVSDB_SERVER_PIDFILE" --detach --no-chdir -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt $connect_method $listen_method) &
188     else
189         action "Starting ovsdb-server" nice -n "$OVSDB_SERVER_PRIORITY" "$ovsdb_server" "$OVSDB_SERVER_DB" --pidfile="$OVSDB_SERVER_PIDFILE" --detach --no-chdir -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt $connect_method $listen_method
190     fi
191 }
192
193 function start_vswitchd {
194     local syslog_opt="-vANY:SYSLOG:${VSWITCHD_SYSLOG_LOGLEVEL}"
195     local logfile_file_opt=""
196     local logfile_level_opt=""
197     if [ ! -d "$VSWITCHD_RUN_DIR" ]; then
198         mkdir -p "$VSWITCHD_RUN_DIR"
199     fi
200     cd "$VSWITCHD_RUN_DIR"
201     if [ -n "$VSWITCHD_FILE_LOGLEVEL" ]; then
202         logfile_level_opt="-vANY:FILE:${VSWITCHD_FILE_LOGLEVEL}"
203         logfile_file_opt="--log-file=$VSWITCHD_LOGFILE"
204     fi
205     local leak_opt=""
206     if [ -n "$VSWITCHD_MEMLEAK_LOGFILE" ]; then
207         leak_opt="--check-leaks=$VSWITCHD_MEMLEAK_LOGFILE"
208         if [ -e "$VSWITCHD_MEMLEAK_LOGFILE" ]; then
209             mv "$VSWITCHD_MEMLEAK_LOGFILE" "$VSWITCHD_MEMLEAK_LOGFILE.prev"
210         fi
211     fi
212     local strace_opt=""
213     local daemonize="y"
214     if [ -n "$VSWITCHD_STRACE_LOG" ] && [ -n "$VSWITCHD_VALGRIND_LOG" ]; then
215         printf "Can not start with both VALGRIND and STRACE\n"
216         exit 1
217     fi
218     if [ -n "$VSWITCHD_STRACE_LOG" ]; then
219         strace_opt="strace -o $VSWITCHD_STRACE_LOG $VSWITCHD_STRACE_OPT"
220         daemonize="n"
221     fi
222     if [ -n "$VSWITCHD_VALGRIND_LOG" ]; then
223         valgrind_opt="valgrind --log-file=$VSWITCHD_VALGRIND_LOG $VSWITCHD_VALGRIND_OPT"
224         daemonize="n"
225     fi
226     local fake_proc_net_opt=""
227     if [ "$ENABLE_FAKE_PROC_NET" = "y" ]; then
228         fake_proc_net_opt="--fake-proc-net"
229     fi
230     if [ "$daemonize" != "y" ]; then
231         # Start in background and force a "success" message
232         action "Starting ovs-vswitchd ($strace_opt$valgrind_opt)" true
233         (nice -n "$VSWITCHD_PRIORITY" $strace_opt $valgrind_opt "$vswitchd" --pidfile="$VSWITCHD_PIDFILE" --detach --no-chdir $fake_proc_net_opt -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt "$VSWITCHD_OVSDB_SERVER") &
234     else
235         action "Starting ovs-vswitchd" nice -n "$VSWITCHD_PRIORITY" "$vswitchd" --pidfile="$VSWITCHD_PIDFILE" --detach --no-chdir $fake_proc_net_opt -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt "$VSWITCHD_OVSDB_SERVER"
236     fi
237 }
238
239 function start_brcompatd {
240     local syslog_opt="-vANY:SYSLOG:${BRCOMPATD_SYSLOG_LOGLEVEL}"
241     local logfile_file_opt=""
242     local logfile_level_opt=""
243     if [ -d "$BRCOMPATD_RUN_DIR" ]; then
244         mkdir -p "$BRCOMPATD_RUN_DIR"
245     fi
246     cd "$BRCOMPATD_RUN_DIR"
247     if [ -n "$BRCOMPATD_FILE_LOGLEVEL" ]; then
248         logfile_level_opt="-vANY:FILE:${BRCOMPATD_FILE_LOGLEVEL}"
249         logfile_file_opt="--log-file=$BRCOMPATD_LOGFILE"
250     fi
251     local leak_opt=""
252     if [ -n "$BRCOMPATD_MEMLEAK_LOG" ]; then
253         leak_opt="--check-leaks=$BRCOMPATD_MEMLEAK_LOGFILE"
254         if [ -e "$BRCOMPATD_MEMLEAK_LOGFILE" ]; then
255             mv "$BRCOMPATD_MEMLEAK_LOGFILE" "$BRCOMPATD_MEMLEAK_LOGFILE.prev"
256         fi
257     fi
258     local strace_opt=""
259     local daemonize="y"
260     if [ -n "$BRCOMPATD_STRACE_LOG" ] && [ -n "$BRCOMPATD_VALGRIND_LOG" ]; then
261         printf "Can not start with both VALGRIND and STRACE\n"
262         exit 1
263     fi
264     if [ -n "$BRCOMPATD_STRACE_LOG" ]; then
265         strace_opt="strace -o $BRCOMPATD_STRACE_LOG $BRCOMPATD_STRACE_OPT"
266         daemonize="n"
267     fi
268     if [ -n "$VALGRIND_LOG" ]; then
269         valgrind_opt="valgrind --log-file=$BRCOMPATD_VALGRIND_LOG $BRCOMPATD_VALGRIND_OPT"
270         daemonize="n"
271     fi
272     appctl_cmd="$appctl --target=/var/run/ovs-vswitchd.\`cat $VSWITCHD_PIDFILE\`.ctl %s"
273     if [ "$daemonize" != "y" ]; then
274         # Start in background and force a "success" message
275         action "Starting ovs-brcompatd ($strace_opt$valgrind_opt)" true
276         (nice -n "$VSWITCHD_PRIORITY" $strace_opt $valgrind_opt "$brcompatd"--no-chdir --appctl-command="$appctl_cmd" --pidfile=$BRCOMPATD_PIDFILE -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt "$VSWITCHD_OVSDB_SERVER") &
277     else
278         action "Starting ovs-brcompatd" nice -n "$BRCOMPATD_PRIORITY" $strace_opt $valgrind_opt "$brcompatd" --no-chdir --appctl-command="$appctl_cmd" --pidfile=$BRCOMPATD_PIDFILE --detach -vANY:CONSOLE:EMER $syslog_opt $logfile_level_opt $logfile_file_opt $leak_opt "$VSWITCHD_OVSDB_SERVER"
279     fi
280 }
281
282 function stop_ovsdb_server {
283     if [ -f "$OVSDB_SERVER_PIDFILE" ]; then
284         local pid=$(cat "$OVSDB_SERVER_PIDFILE")
285         action "Killing ovsdb-server ($pid)" kill -TERM $pid
286         rm -f "$OVSDB_SERVER_PIDFILE"
287     fi
288 }
289
290 function stop_vswitchd {
291     if [ -f "$VSWITCHD_PIDFILE" ]; then
292         local pid=$(cat "$VSWITCHD_PIDFILE")
293         action "Killing ovs-vswitchd ($pid)" kill -TERM $pid
294         rm -f "$VSWITCHD_PIDFILE"
295     fi
296 }
297
298 function stop_brcompatd {
299     if [ -f "$BRCOMPATD_PIDFILE" ]; then
300         local pid=$(cat "$BRCOMPATD_PIDFILE")
301         action "Killing ovs-brcompatd ($pid)" kill -TERM $pid
302         rm -f "$BRCOMPATD_PIDFILE"
303     fi
304 }
305
306 function restart_approval {
307     if test ! -t 0; then
308         # Don't prompt if invoked non-interactively.
309         return 0
310     fi
311     cat <<EOF
312
313 WARNING!!!
314
315 Restarting vswitch on a live server is not guaranteed to work.  It is
316 provided as a convenience for those situations in which it does work.
317 If you just want to reload the configuration file, use "reload"
318 instead of restart.
319
320 EOF
321     read -s -r -n 1 -p "Countinue with restart (y/N): " response
322     printf "\n"
323     case "$response" in
324         y|Y)
325             return 0
326             ;;
327         *)
328             return 1
329             ;;
330     esac
331 }
332
333 function start {
334     if [ "$FORCE_COREFILES" = "y" ]; then
335         turn_on_corefiles
336     fi
337
338     insert_modules_if_required
339
340     # Increase the limit on the number of open file descriptors since
341     # ovs-vswitchd needs a few per bridge
342     ulimit -n 4096
343
344     # Allow GRE traffic.
345     iptables -I INPUT -p gre -j ACCEPT
346
347     if [ ! -e "$OVSDB_SERVER_DB" ]; then
348         warning "$OVSDB_SERVER_DB does not exist"
349         action "Creating empty $OVSDB_SERVER_DB" $ovsdb_tool create "$OVSDB_SERVER_DB" "$VSWITCHD_OVSDB_SCHEMA"
350         action "Creating initial table in $OVSDB_SERVER_DB" $ovsdb_tool transact "$OVSDB_SERVER_DB" '[{"op": "insert", "table": "Open_vSwitch", "row": {}}]'
351     #elif [ ! -e /var/run/vswitch.booted ]; then
352         #touch /var/run/vswitch.booted
353         #/usr/bin/ovs-cfg-mod '-vANY:console:emer' -F "$VSWITCHD_CONF" \
354             #'--del-match=bridge.*' \
355             #'--del-match=port.*' \
356             #'--del-match=bonding.*' \
357             #'--del-match=iface.*' \
358             #'--del-match=vlan.*.trunks=*' \
359             #'--del-match=vlan.*.tag=*'
360     fi
361
362     start_ovsdb_server
363     start_vswitchd
364     start_brcompatd
365     reload_vswitchd  # ensures ovs-vswitchd has fully read config.
366     touch /var/lock/subsys/vswitch
367 }
368
369 function stop {
370     stop_brcompatd
371     stop_vswitchd
372     stop_ovsdb_server
373     rm -f /var/lock/subsys/vswitch
374 }
375
376 function restart {
377     if restart_approval; then
378         stop
379         start
380     fi
381 }
382
383 case "$1" in
384     start)
385         start
386         ;;
387     stop)
388         stop
389         ;;
390     restart)
391         restart
392         ;;
393     reload)
394         reload_vswitchd
395         reload_brcompatd
396         ;;
397     strace-vswitchd)
398         shift
399         strace -p $(cat "$VSWITCHD_PIDFILE") "$@"
400         ;;
401     strace-brcompatd)
402         shift
403         strace -p $(cat "$BRCOMPATD_PIDFILE") "$@"
404         ;;
405     status)
406         status -p ovs-vswitchd.pid ovs-vswitchd
407         status -p ovs-brcompatd.pid ovs-brcompatd
408         ;;
409     version)
410         /usr/sbin/ovs-vswitchd -V
411         /usr/sbin/ovs-brcompatd -V
412         ;;
413     help)
414         printf "vswitch [start|stop|restart|reload|unload|status|version]\n"
415         ;;
416     *)
417         printf "Unknown command: $1\n"
418         exit 1
419         ;;
420 esac