diff options
author | FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> | 2014-12-24 21:07:57 +0900 |
---|---|---|
committer | FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> | 2014-12-24 21:07:57 +0900 |
commit | 42454bd8d72ed77fd2b98ab431b14dba20f4c5ee (patch) | |
tree | 95d5e7680a4a68cb82ce471100f51c71363d6906 /tools/route-server/route-server-docker.sh | |
parent | 2b38ca65ba529bbc0da17318e3b7d8fba9e7c29a (diff) |
tools: config/route-server-docker.sh -> route-server/route-server-docker.sh
more appropriate
Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Diffstat (limited to 'tools/route-server/route-server-docker.sh')
-rwxr-xr-x | tools/route-server/route-server-docker.sh | 99 |
1 files changed, 99 insertions, 0 deletions
diff --git a/tools/route-server/route-server-docker.sh b/tools/route-server/route-server-docker.sh new file mode 100755 index 00000000..b7b17f5d --- /dev/null +++ b/tools/route-server/route-server-docker.sh @@ -0,0 +1,99 @@ +#!/bin/sh + +NR_PEERS=8 +BRIDGE_NAME=br0 +CONFIG_DIR=/usr/local/gobgp +GOBGP_DOCKER_NAME=gobgp + +check_user() { + if [ `whoami` = "root" ]; then + echo "Super user cannot execute! Please execute as non super user" + exit 2 + fi +} + +run_quagga() { + local docker_name=q$1 + docker run --privileged=true -v $CONFIG_DIR/$docker_name:/etc/quagga --name $docker_name -id osrg/quagga + sudo pipework $BRIDGE_NAME $docker_name 10.0.0.$1/16 +} + +stop_quagga() { + local docker_name=q$1 + docker rm -f $docker_name +} + +delete_bridge() { + local name=$1 + local sysfs_name=/sys/class/net/$name + if [ -e $sysfs_name ]; then + sudo ifconfig $name down + sudo brctl delbr $name + fi +} + +while getopts c:n: OPT +do + case $OPT in + c) CONFIG_DIR="$OPTARG" + ;; + n) NR_PEERS="$OPTARG" + ;; + *) echo "Unknown option" + exit 1 + ;; + esac +done + +shift $((OPTIND - 1)) + +case "$1" in + start) + i=1 + while [ $i -le $NR_PEERS ] + do + run_quagga $i + i=$(( i+1 )) + done + docker run --privileged=true -v $CONFIG_DIR:/mnt --name $GOBGP_DOCKER_NAME -id osrg/gobgp + sudo pipework $BRIDGE_NAME $GOBGP_DOCKER_NAME 10.0.255.1/16 + ;; + stop) + i=1 + while [ $i -le $NR_PEERS ] + do + stop_quagga $i + i=$(( i+1 )) + done + delete_bridge $BRIDGE_NAME + docker rm -f $GOBGP_DOCKER_NAME + ;; + install) + sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 36A1D7869245C8950F966E92D8576A8BA88D21E9 + sudo sh -c "echo deb https://get.docker.io/ubuntu docker main > /etc/apt/sources.list.d/docker.list" + sudo apt-get update + sudo apt-get install -y --force-yes lxc-docker-1.3.2 + sudo ln -sf /usr/bin/docker.io /usr/local/bin/docker + sudo gpasswd -a `whoami` docker + sudo apt-get install -y --force-yes emacs23-nox + sudo apt-get install -y --force-yes wireshark + sudo apt-get install -y --force-yes iputils-arping + sudo apt-get install -y --force-yes bridge-utils + sudo apt-get install -y --force-yes tcpdump + sudo apt-get install -y --force-yes lv + sudo wget https://raw.github.com/jpetazzo/pipework/master/pipework -O /usr/local/bin/pipework + sudo chmod 755 /usr/local/bin/pipework + sudo docker pull osrg/ryu + sudo docker pull osrg/gobgp + mkdir /usr/local/gobgp + sudo docker run --privileged=true --name gobgp -id osrg/gobgp -v /usr/local/gobgp:/mnt go run /root/gobgp/tools/route-server/quagga-rsconfig.go -c /mnt + docker rm -f gobgp + ;; + *) + echo $1 + echo "Usage: root-server-docker {start|stop}" + exit 2 + ;; +esac + + |