summaryrefslogtreecommitdiffhomepage
path: root/tools/route-server/route-server-docker.sh
diff options
context:
space:
mode:
authorFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2014-12-24 21:07:57 +0900
committerFUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>2014-12-24 21:07:57 +0900
commit42454bd8d72ed77fd2b98ab431b14dba20f4c5ee (patch)
tree95d5e7680a4a68cb82ce471100f51c71363d6906 /tools/route-server/route-server-docker.sh
parent2b38ca65ba529bbc0da17318e3b7d8fba9e7c29a (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-xtools/route-server/route-server-docker.sh99
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
+
+