From 03fc4375a73bee29a44165e6db51c763ef0b8939 Mon Sep 17 00:00:00 2001 From: Marco Platania Date: Fri, 21 Apr 2017 15:11:27 -0400 Subject: vFW install scripts Change-Id: I15f3fb3fe9fa5e44bf014e08f07b5a10cf79d320 Signed-off-by: Marco Platania --- vnfs/vFW/scripts/v_firewall_install.sh | 80 +++++++++++++++++++++++++++++++++ vnfs/vFW/scripts/v_packetgen_install.sh | 65 +++++++++++++++++++++++++++ vnfs/vFW/scripts/v_sink_install.sh | 46 +++++++++++++++++++ 3 files changed, 191 insertions(+) create mode 100644 vnfs/vFW/scripts/v_firewall_install.sh create mode 100644 vnfs/vFW/scripts/v_packetgen_install.sh create mode 100644 vnfs/vFW/scripts/v_sink_install.sh (limited to 'vnfs/vFW') diff --git a/vnfs/vFW/scripts/v_firewall_install.sh b/vnfs/vFW/scripts/v_firewall_install.sh new file mode 100644 index 00000000..7d178719 --- /dev/null +++ b/vnfs/vFW/scripts/v_firewall_install.sh @@ -0,0 +1,80 @@ +#!/bin/bash + +DCAE_COLLECTOR_IP=$(cat /opt/config/dcae_collector_ip.txt) +DCAE_COLLECTOR_PORT=$(cat /opt/config/dcae_collector_port.txt) +REPO_URL_BLOB=$(cat /opt/config/repo_url_blob.txt) +REPO_URL_ARTIFACTS=$(cat /opt/config/repo_url_artifacts.txt) +DEMO_ARTIFACTS_VERSION=$(cat /opt/config/demo_artifacts_version.txt) +VFW_PRIVATE_IP_O=$(cat /opt/config/vfw_private_ip_0.txt) +VFW_PRIVATE_IP_1=$(cat /opt/config/vfw_private_ip_1.txt) +VFW_PRIVATE_IP_2=$(cat /opt/config/vfw_private_ip_2.txt) +CLOUD_ENV=$(cat /opt/config/cloud_env.txt) + +# OpenStack network configuration +if [[ $CLOUD_ENV == "openstack" ]] +then + echo 127.0.0.1 $(hostname) >> /etc/hosts + + echo "auto eth1" >> /etc/network/interfaces + echo "iface eth1 inet static" >> /etc/network/interfaces + echo " address $VFW_PRIVATE_IP_O" >> /etc/network/interfaces + echo " netmask 255.255.255.0" >> /etc/network/interfaces + + echo "auto eth2" >> /etc/network/interfaces + echo "iface eth2 inet static" >> /etc/network/interfaces + echo " address $VFW_PRIVATE_IP_1" >> /etc/network/interfaces + echo " netmask 255.255.255.0" >> /etc/network/interfaces + + ifup eth1 + ifup eth2 +fi + +# Download required dependencies +add-apt-repository -y ppa:openjdk-r/ppa +apt-get update +apt-get install -y make wget openjdk-8-jdk gcc libcurl4-openssl-dev python-pip bridge-utils apt-transport-https ca-certificates +apt-get install -y maven +pip install jsonschema + +# Download artifacts for virtual firewall +mkdir /opt/honeycomb +cd /opt + +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/v_firewall_init.sh +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/vfirewall.sh +wget $REPO_URL_ARTIFACTS/org/openecomp/demo/vnf/sample-distribution/$DEMO_ARTIFACTS_VERSION/sample-distribution-$DEMO_ARTIFACTS_VERSION-hc.tar.gz +wget $REPO_URL_ARTIFACTS/org/openecomp/demo/vnf/ves/ves/$DEMO_ARTIFACTS_VERSION/ves-$DEMO_ARTIFACTS_VERSION-demo.tar.gz +wget $REPO_URL_ARTIFACTS/org/openecomp/demo/vnf/ves/ves_vfw_reporting/$DEMO_ARTIFACTS_VERSION/ves_vfw_reporting-$DEMO_ARTIFACTS_VERSION-demo.tar.gz + +tar -zxvf ves-$DEMO_ARTIFACTS_VERSION-demo.tar.gz +mv ves-$DEMO_ARTIFACTS_VERSION VES +tar -zxvf ves_vfw_reporting-$DEMO_ARTIFACTS_VERSION-demo.tar.gz +mv ves_vfw_reporting-$DEMO_ARTIFACTS_VERSION VESreporting_vFW +tar -zxvf sample-distribution-$DEMO_ARTIFACTS_VERSION-hc.tar.gz +mv sample-distribution-$DEMO_ARTIFACTS_VERSION honeycomb +sed -i 's/"restconf-binding-address": "127.0.0.1",/"restconf-binding-address": "0.0.0.0",/g' honeycomb/sample-distribution-$DEMO_ARTIFACTS_VERSION/config/honeycomb.json +mv VESreporting_vFW /opt/VES/code/evel_training/VESreporting +rm *.tar.gz +chmod +x v_firewall_init.sh +chmod +x vfirewall.sh + +# Install VPP +export UBUNTU="trusty" +export RELEASE=".stable.1609" +rm /etc/apt/sources.list.d/99fd.io.list +echo "deb [trusted=yes] https://nexus.fd.io/content/repositories/fd.io$RELEASE.ubuntu.$UBUNTU.main/ ./" | sudo tee -a /etc/apt/sources.list.d/99fd.io.list +apt-get update +apt-get install -y vpp vpp-dpdk-dkms vpp-lib vpp-dbg vpp-plugins vpp-dev +sleep 1 + +# Install VES +cd /opt/VES/bldjobs/ +make clean +make +sleep 1 + +# Run instantiation script +cd /opt +mv vfirewall.sh /etc/init.d +update-rc.d vfirewall.sh defaults +./v_firewall_init.sh \ No newline at end of file diff --git a/vnfs/vFW/scripts/v_packetgen_install.sh b/vnfs/vFW/scripts/v_packetgen_install.sh new file mode 100644 index 00000000..840e7bf8 --- /dev/null +++ b/vnfs/vFW/scripts/v_packetgen_install.sh @@ -0,0 +1,65 @@ +#!/bin/bash + +FW_IPADDR=$(cat /opt/config/fw_ipaddr.txt) +PROTECTED_NET_CIDR=$(cat /opt/config/protected_net_cidr.txt) +SINK_IPADDR=$(cat /opt/config/sink_ipaddr.txt) +REPO_URL_BLOB=$(cat /opt/config/repo_url_blob.txt) +REPO_URL_ARTIFACTS=$(cat /opt/config/repo_url_artifacts.txt) +DEMO_ARTIFACTS_VERSION=$(cat /opt/config/demo_artifacts_version.txt) +VPG_PRIVATE_IP_O=$(cat /opt/config/vpg_private_ip_0.txt) +VPG_PRIVATE_IP_1=$(cat /opt/config/vpg_private_ip_1.txt) +CLOUD_ENV=$(cat /opt/config/cloud_env.txt) + +# Network configuration +if [[ $CLOUD_ENV == "openstack" ]] +then + echo 127.0.0.1 $(hostname) >> /etc/hosts + + echo "auto eth1" >> /etc/network/interfaces + echo "iface eth1 inet static" >> /etc/network/interfaces + echo " address $VPG_PRIVATE_IP_O" >> /etc/network/interfaces + echo " netmask 255.255.255.0" >> /etc/network/interfaces + + ifup eth1 +fi + +# Download required dependencies +add-apt-repository -y ppa:openjdk-r/ppa +apt-get update +apt-get install -y make wget openjdk-8-jdk gcc libcurl4-openssl-dev python-pip bridge-utils apt-transport-https ca-certificates +apt-get install -y maven +pip install jsonschema + +# Download code for packet generator +mkdir /opt/honeycomb +cd /opt + +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/v_packetgen_init.sh +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/vpacketgen.sh +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/run_traffic_fw_demo.sh +wget $REPO_URL_ARTIFACTS/org/openecomp/demo/vnf/sample-distribution/$DEMO_ARTIFACTS_VERSION/sample-distribution-$DEMO_ARTIFACTS_VERSION-hc.tar.gz +wget $REPO_URL_ARTIFACTS/org/openecomp/demo/vnf/vfw/vfw_pg_streams/$DEMO_ARTIFACTS_VERSION/vfw_pg_streams-$DEMO_ARTIFACTS_VERSION-demo.tar.gz + +tar -zxvf sample-distribution-$DEMO_ARTIFACTS_VERSION-hc.tar.gz +tar -zxvf vfw_pg_streams-$DEMO_ARTIFACTS_VERSION-demo.tar.gz +mv vfw_pg_streams-$DEMO_ARTIFACTS_VERSION pg_streams +mv sample-distribution-$DEMO_ARTIFACTS_VERSION honeycomb +sed -i 's/"restconf-binding-address": "127.0.0.1",/"restconf-binding-address": "0.0.0.0",/g' honeycomb/sample-distribution-$DEMO_ARTIFACTS_VERSION/config/honeycomb.json +rm *.tar.gz +chmod +x v_packetgen_init.sh +chmod +x vpacketgen.sh + +# Install VPP +export UBUNTU="trusty" +export RELEASE=".stable.1609" +rm /etc/apt/sources.list.d/99fd.io.list +echo "deb [trusted=yes] https://nexus.fd.io/content/repositories/fd.io$RELEASE.ubuntu.$UBUNTU.main/ ./" | sudo tee -a /etc/apt/sources.list.d/99fd.io.list +apt-get update +apt-get install -y vpp vpp-dpdk-dkms vpp-lib vpp-dbg vpp-plugins vpp-dev +sleep 1 + +# Run instantiation script +cd /opt +mv vpacketgen.sh /etc/init.d +update-rc.d vpacketgen.sh defaults +./v_packetgen_init.sh \ No newline at end of file diff --git a/vnfs/vFW/scripts/v_sink_install.sh b/vnfs/vFW/scripts/v_sink_install.sh new file mode 100644 index 00000000..c5eb120e --- /dev/null +++ b/vnfs/vFW/scripts/v_sink_install.sh @@ -0,0 +1,46 @@ +#!/bin/bash + +PROTECTED_NET_GW=$(cat /opt/config/protected_net_gw.txt) +UNPROTECTED_NET=$(cat /opt/config/unprotected_net.txt | cut -d'/' -f1) +REPO_URL_BLOB=$(cat /opt/config/repo_url_blob.txt) +REPO_URL_ARTIFACTS=$(cat /opt/config/repo_url_artifacts.txt) +DEMO_ARTIFACTS_VERSION=$(cat /opt/config/demo_artifacts_version.txt) +VSN_PRIVATE_IP_O=$(cat /opt/config/vsn_private_ip_0.txt) +VSN_PRIVATE_IP_1=$(cat /opt/config/vsn_private_ip_1.txt) +CLOUD_ENV=$(cat /opt/config/cloud_env.txt) + + +# Network configuration +if [[ $CLOUD_ENV == "openstack" ]] +then + echo 127.0.0.1 $(hostname) >> /etc/hosts + + echo "auto eth1" >> /etc/network/interfaces + echo "iface eth1 inet static" >> /etc/network/interfaces + echo " address $VSN_PRIVATE_IP_O" >> /etc/network/interfaces + echo " netmask 255.255.255.0" >> /etc/network/interfaces + + ifup eth1 +fi + +# Download required dependencies +add-apt-repository -y ppa:openjdk-r/ppa +apt-get update +apt-get install -y make wget openjdk-8-jdk apt-transport-https ca-certificates darkstat + +# Configure and run darkstat +sed -i "s/START_DARKSTAT=.*/START_DARKSTAT=yes/g" /etc/darkstat/init.cfg +sed -i "s/INTERFACE=.*/INTERFACE=\"-i eth1\"/g" /etc/darkstat/init.cfg +/etc/init.d/darkstat start + +# Download code for virtual sink +cd /opt +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/v_sink_init.sh +wget $REPO_URL_BLOB/org.openecomp.demo/vnfs/vfw/$DEMO_ARTIFACTS_VERSION/vsink.sh +chmod +x v_sink_init.sh +chmod +x vsink.sh + +# Run instantiation script +mv vsink.sh /etc/init.d +update-rc.d vsink.sh defaults +./v_sink_init.sh \ No newline at end of file -- cgit 1.2.3-korg