3 # Licensed under the Apache License, Version 2.0 (the "License");
4 # you may not use this file except in compliance with the License.
5 # You may obtain a copy of the License at
7 # http://www.apache.org/licenses/LICENSE-2.0
9 # Unless required by applicable law or agreed to in writing, software
10 # distributed under the License is distributed on an "AS IS" BASIS,
11 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 # See the License for the specific language governing permissions and
13 # limitations under the License.
15 REPOSITORY_BASE
=https
://osm-download.etsi.org
/repository
/osm
/debian
21 echo -e "usage: $0 [OPTIONS]"
22 echo -e "Install OSM from binaries or source code (by default, from binaries)"
24 echo -e " -r <repo>: use specified repository name for osm packages"
25 echo -e " -R <release>: use specified release for osm binaries (deb packages, lxd images, ...)"
26 echo -e " -u <repo base>: use specified repository url for osm packages"
27 echo -e " -k <repo key>: use specified repository public key url"
28 echo -e " -b <refspec>: install OSM from source code using a specific branch (master, v2.0, ...) or tag"
29 echo -e " -b master (main dev branch)"
30 echo -e " -b v2.0 (v2.0 branch)"
31 echo -e " -b tags/v1.1.0 (a specific tag)"
33 echo -e " -s <stack name> user defined stack name, default is osm"
34 echo -e " -H <VCA host> use specific juju host controller IP"
35 echo -e " -S <VCA secret> use VCA/juju secret key"
36 echo -e " -P <VCA pubkey> use VCA/juju public key file"
37 echo -e " -C <VCA cacert> use VCA/juju CA certificate file"
38 echo -e " -A <VCA apiproxy> use VCA/juju API proxy"
39 echo -e " --vimemu: additionally deploy the VIM emulator as a docker container"
40 echo -e " --elk_stack: additionally deploy an ELK docker stack for event logging"
41 echo -e " --pm_stack: additionally deploy a Prometheus+Grafana stack for performance monitoring (PM)"
42 echo -e " -m <MODULE>: install OSM but only rebuild the specified docker images (LW-UI, NBI, LCM, RO, MON, POL, KAFKA, MONGO, PROMETHEUS, KEYSTONE-DB, NONE)"
43 echo -e " -o <ADDON>: ONLY (un)installs one of the addons (vimemu, elk_stack, pm_stack)"
44 echo -e " -D <devops path> use local devops installation path"
45 echo -e " -w <work dir> Location to store runtime installation"
46 echo -e " -t <docker tag> specify osm docker tag (default is latest)"
47 echo -e " --nolxd: do not install and configure LXD, allowing unattended installations (assumes LXD is already installed and confifured)"
48 echo -e " --nodocker: do not install docker, do not initialize a swarm (assumes docker is already installed and a swarm has been initialized)"
49 echo -e " --nojuju: do not juju, assumes already installed"
50 echo -e " --nodockerbuild:do not build docker images (use existing locally cached images)"
51 echo -e " --nohostports: do not expose docker ports to host (useful for creating multiple instances of osm on the same host)"
52 echo -e " --nohostclient: do not install the osmclient"
53 echo -e " --uninstall: uninstall OSM: remove the containers and delete NAT rules"
54 echo -e " --source: install OSM from source code using the latest stable tag"
55 echo -e " --develop: (deprecated, use '-b master') install OSM from source code using the master branch"
56 echo -e " --soui: install classic build of OSM (Rel THREE v3.1, based on LXD containers, with SO and UI)"
57 echo -e " --lxdimages: (only for Rel THREE with --soui) download lxd images from OSM repository instead of creating them from scratch"
58 echo -e " --pullimages: pull/run osm images from docker.io/opensourcemano"
59 echo -e " -l <lxd_repo>: (only for Rel THREE with --soui) use specified repository url for lxd images"
60 echo -e " -p <path>: (only for Rel THREE with --soui) use specified repository path for lxd images"
61 echo -e " --nat: (only for Rel THREE with --soui) install only NAT rules"
62 echo -e " --noconfigure: (only for Rel THREE with --soui) DO NOT install osmclient, DO NOT install NAT rules, DO NOT configure modules"
63 echo -e " --showopts: print chosen options and exit (only for debugging)"
64 #echo -e " --clean_volumes To clear all the mounted volumes from docker swarm"
65 echo -e " -y: do not prompt for confirmation, assumes yes"
66 echo -e " -h / --help: print this help"
71 grep "${REPO_CHECK/\[arch=amd64\]/\\[arch=amd64\\]}" /etc
/apt
/sources.list
> /dev
/null
2>&1
74 need_packages_lw
="software-properties-common apt-transport-https"
75 echo -e "Checking required packages: $need_packages_lw"
76 dpkg
-l $need_packages_lw &>/dev
/null \
77 ||
! echo -e "One or several required packages are not installed. Updating apt cache requires root privileges." \
78 || sudo apt-get
-q update \
79 ||
! echo "failed to run apt-get update" \
81 dpkg
-l $need_packages_lw &>/dev
/null \
82 ||
! echo -e "Installing $need_packages_lw requires root privileges." \
83 || sudo apt-get
install -y $need_packages_lw \
84 ||
! echo "failed to install $need_packages_lw" \
86 wget
-qO - $REPOSITORY_BASE/$RELEASE/OSM
%20ETSI
%20Release
%20Key.gpg | sudo apt-key add
-
87 sudo DEBIAN_FRONTEND
=noninteractive add-apt-repository
-y "$1" && sudo DEBIAN_FRONTEND
=noninteractive apt-get update
95 dpkg
-s 'osm-devops' &> /dev
/null
97 # Clean the previous repos that might exist
98 sudo
sed -i "/osm-download.etsi.org/d" /etc
/apt
/sources.list
102 while getopts ":b:r:c:k:u:R:l:p:D:o:m:H:S:s:w:t:U:P:A:-: hy" o
; do
105 REPOSITORY
="${OPTARG}"
111 REPOSITORY_BASE
="${OPTARG}"
114 DOCKER_TAG
="${OPTARG}"
117 [ "${OPTARG}" == "help" ] && usage
&& exit 0
120 echo "Option -$OPTARG requires an argument" >&2
124 echo -e "Invalid option: '-$OPTARG'\n" >&2
137 add_repo
"deb [arch=amd64] $REPOSITORY_BASE/$RELEASE $REPOSITORY devops"
138 sudo DEBIAN_FRONTEND
=noninteractive apt-get
-q update
139 sudo DEBIAN_FRONTEND
=noninteractive apt-get
install osm-devops
140 #FIXME: sudo DEBIAN_FRONTEND=noninteractive apt-get install -y osm-devops
142 #--- FIXME: Workaround until patch for unattended install comes with default installer
143 sudo wget
-O /usr
/share
/osm-devops
/installers
/full_install_osm.sh
"https://osm.etsi.org/gitweb/?p=osm/devops.git;a=blob_plain;f=installers/full_install_osm.sh;hb=4205c192a9b6c2e30459987491e02a44ca3695d6"
144 sudo
chmod +x
/usr
/share
/osm-devops
/installers
/full_install_osm.sh
145 #--- End of workaround
147 /usr
/share
/osm-devops
/installers
/full_install_osm.sh
-R $RELEASE -r $REPOSITORY -u $REPOSITORY_BASE -D /usr
/share
/osm-devops
-t $DOCKER_TAG "$@"
149 ############################################
150 # OSM Install without workarounds
151 ############################################
152 #wget https://osm-download.etsi.org/ftp/osm-7.0-seven/install_osm.sh
153 #chmod +x install_osm.sh
154 ##./install_osm.sh -c k8s --k8s_monitor --elk_stack 2>&1 | tee osm_install_log.txt
155 ##./install_osm.sh -c k8s --k8s_monitor 2>&1 | tee osm_install_log.txt
156 #./install_osm.sh 2>&1 | tee osm_install_log.txt
157 ############################################
159 # Saves the IP address used during install, in case the VM needed to be reinstantiated later with a different IP address
160 sudo mkdir
-p ${STATE_FOLDER}
161 sudo
chmod a
+r
${STATE_FOLDER}
162 DEFAULT_IF
=$
(route
-n |
awk '$1~/^0.0.0.0/ {print $8}')
163 DEFAULT_IP
=$
(ip
-o -4 a |
grep ${DEFAULT_IF}|
awk '{split($4,a,"/"); print a[1]}')
164 sudo su
- -c "echo ${DEFAULT_IP} > ${STATE_FOLDER}/oldIPaddress.txt"