Fix path to docker in Policy
[demo.git] / boot / asdc_install.sh
1 #!/bin/bash
2
3 # Read configuration files
4 NEXUS_REPO=$(cat /opt/config/nexus_repo.txt)
5 ARTIFACTS_VERSION=$(cat /opt/config/artifacts_version.txt)
6 DNS_IP_ADDR=$(cat /opt/config/dns_ip_addr.txt)
7 CLOUD_ENV=$(cat /opt/config/cloud_env.txt)
8 GERRIT_BRANCH=$(cat /opt/config/gerrit_branch.txt)
9
10 # Add host name to /etc/host to avoid warnings in openstack images
11 if [[ $CLOUD_ENV == "openstack" ]]
12 then
13         echo 127.0.0.1 $(hostname) >> /etc/hosts
14 fi
15
16 # Download dependencies
17 add-apt-repository -y ppa:openjdk-r/ppa
18 apt-get update
19 apt-get install -y apt-transport-https ca-certificates wget openjdk-8-jdk git ntp ntpdate
20
21 # Download scripts from Nexus
22 curl -k $NEXUS_REPO/org.openecomp.demo/boot/$ARTIFACTS_VERSION/asdc_vm_init.sh -o /opt/asdc_vm_init.sh
23 curl -k $NEXUS_REPO/org.openecomp.demo/boot/$ARTIFACTS_VERSION/asdc_serv.sh -o /opt/asdc_serv.sh
24 chmod +x /opt/asdc_vm_init.sh
25 chmod +x /opt/asdc_serv.sh
26 mv /opt/asdc_serv.sh /etc/init.d
27 update-rc.d asdc_serv.sh defaults
28
29 # Download and install docker-engine and docker-compose
30 echo "deb https://apt.dockerproject.org/repo ubuntu-xenial main" | sudo tee /etc/apt/sources.list.d/docker.list
31 apt-get update
32 apt-get install -y linux-image-extra-$(uname -r) linux-image-extra-virtual
33 apt-get install -y --allow-unauthenticated docker-engine
34
35 mkdir /opt/docker
36 curl -L https://github.com/docker/compose/releases/download/1.9.0/docker-compose-`uname -s`-`uname -m` > /opt/docker/docker-compose
37 chmod +x /opt/docker/docker-compose
38
39 # Create partition and mount the external volume
40 curl -k $NEXUS_REPO/org.openecomp.demo/boot/$ARTIFACTS_VERSION/asdc_ext_volume_partitions.txt -o /opt/asdc_ext_volume_partitions.txt
41
42 if [[ $CLOUD_ENV == "rackspace" ]]
43 then
44         DISK="xvdb"
45 else
46         DISK="vdb"
47         sed -i "s/xvdb/vdb/g" /opt/asdc_ext_volume_partitions.txt
48 fi
49
50 sfdisk /dev/$DISK < /opt/asdc_ext_volume_partitions.txt
51 mkfs -t ext4 /dev/$DISK"1"
52 mkdir -p /data
53 mount /dev/$DISK"1" /data
54 echo "/dev/"$DISK"1  /data           ext4    errors=remount-ro,noatime,barrier=0 0       1" >> /etc/fstab
55
56 # DNS IP address configuration
57 echo "nameserver "$DNS_IP_ADDR >> /etc/resolvconf/resolv.conf.d/head
58 resolvconf -u
59
60 # Clone Gerrit repository
61 cd /opt
62 mkdir -p /data/environments
63 mkdir -p /data/scripts
64 mkdir -p /data/logs/BE
65 mkdir -p /data/logs/FE
66 chmod 777 /data
67 chmod 777 /data/logs/BE
68 chmod 777 /data/logs/FE
69
70 git clone -b $GERRIT_BRANCH --single-branch http://gerrit.onap.org/r/sdc.git
71
72 cat > /root/.bash_aliases << EOF
73 alias dcls='/data/scripts/docker_clean.sh \$1'
74 alias dlog='/data/scripts/docker_login.sh \$1'
75 alias rund='/data/scripts/docker_run.sh'
76 alias health='/data/scripts/docker_health.sh'
77 EOF
78
79 # Rename network interface in openstack Ubuntu 16.04 images. Then, reboot the VM to pick up changes
80 if [[ $CLOUD_ENV == "openstack" ]]
81 then
82         sed -i "s/GRUB_CMDLINE_LINUX=.*/GRUB_CMDLINE_LINUX=\"net.ifnames=0 biosdevname=0\"/g" /etc/default/grub
83         grub-mkconfig -o /boot/grub/grub.cfg
84         sed -i "s/ens[0-9]*/eth0/g" /etc/network/interfaces.d/*.cfg
85         echo 'network: {config: disabled}' >> /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
86         echo "APT::Periodic::Unattended-Upgrade \"0\";" >> /etc/apt/apt.conf.d/10periodic
87         reboot
88 fi
89
90 # Run docker containers. For openstack Ubuntu 16.04 images this will run as a service after the VM has restarted
91 ./asdc_vm_init.sh