blob: 25775d6a87ea9524f7704256251a3a4198a43b2e [file] [log] [blame]
tiernob3cda2e2018-10-30 17:26:59 +00001# Copyright 2018 Telefonica S.A.
2#
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
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
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
12# implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
calvinosanchd5916fd2020-01-09 17:19:53 +010016FROM ubuntu:18.04
tiernoc0e42e22018-05-11 11:36:10 +020017
18# Set the working directory to /app
tierno2b829912019-08-30 15:21:05 +000019WORKDIR /app/LCM
tiernoc0e42e22018-05-11 11:36:10 +020020
calvinosanchd5916fd2020-01-09 17:19:53 +010021RUN apt-get update && apt-get install -y curl xz-utils gnupg2 \
calvinosanch9f9c6f22019-11-04 13:37:39 +010022 && apt-get update && apt-get install -y apt-transport-https \
23 && curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | apt-key add - \
24 && echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | tee -a /etc/apt/sources.list.d/kubernetes.list \
25 && apt-get update && apt-get install -y kubectl
26
27RUN curl https://get.helm.sh/helm-v2.15.2-linux-amd64.tar.gz --output helm-v2.15.2.tar.gz \
28 && tar -zxvf helm-v2.15.2.tar.gz \
29 && mv linux-amd64/helm /usr/local/bin/helm \
30 && rm -r linux-amd64/
31
Adam Israelbaacc302019-12-01 12:41:39 -050032RUN curl -L https://launchpad.net/juju/2.7/2.7.0/+download/juju-2.7.0-k8s.tar.xz --output juju-2.7.0-k8s.tar.xz \
33 && tar -xvf juju-2.7.0-k8s.tar.xz \
34 && mv juju /usr/local/bin/juju
35
tiernob3cda2e2018-10-30 17:26:59 +000036RUN apt-get update && apt-get install -y git tox python3 \
calvinosanchd5916fd2020-01-09 17:19:53 +010037 python3-pip python3-jinja2 \
tierno62b2cd72019-11-21 12:25:34 +000038 && python3 -m pip install pip --upgrade \
calvinosanchd5916fd2020-01-09 17:19:53 +010039 && python3 -m pip install -U 'PyYAML' 'aiohttp>=2.3.10' flake8
tiernoc0e42e22018-05-11 11:36:10 +020040
tiernof7e0a642018-11-17 01:01:52 +010041RUN git -C /app clone https://osm.etsi.org/gerrit/osm/N2VC.git \
tierno62b2cd72019-11-21 12:25:34 +000042 && python3 -m pip install -e /app/N2VC \
43 && python3 -m pip install -U juju \
tiernof578e552018-11-08 19:07:20 +010044 && apt-get install -y libffi-dev libssl-dev openssh-client
tiernob3cda2e2018-10-30 17:26:59 +000045 # cd N2VC; python3 setup.py develop
46 # cd modules/libjuju; python3 setup.py develop
tiernoc0e42e22018-05-11 11:36:10 +020047
tiernof7e0a642018-11-17 01:01:52 +010048RUN git -C /app clone https://osm.etsi.org/gerrit/osm/common.git \
tierno62b2cd72019-11-21 12:25:34 +000049 && python3 -m pip install -e /app/common
tiernob3cda2e2018-10-30 17:26:59 +000050 # python3-pymongo python3-yaml pycrypto aiokafka
tiernoc0e42e22018-05-11 11:36:10 +020051
52RUN mkdir -p /app/storage/kafka && mkdir -p /app/log
53
54
55LABEL Maintainer="alfonso.tiernosepulveda@telefonica.com" \
tierno8d950012018-05-22 12:27:48 +020056 Description="This implements the Life Cicle Management module of OSM" \
tiernoc0e42e22018-05-11 11:36:10 +020057 Version="1.0" \
58 Author="Alfonso Tierno"
59
60# Used for local storage
61VOLUME /app/storage
62# Used for logs
63VOLUME /app/log
64
65# The following ENV can be added with "docker run -e xxx' to configure LCM
66ENV OSMLCM_RO_HOST ro
67ENV OSMLCM_RO_PORT 9090
68ENV OSMLCM_RO_TENANT osm
69
70# VCA
71ENV OSMLCM_VCA_HOST vca
garciadeblasee29bc72019-12-17 15:47:58 +010072ENV OSMLCM_VCA_PORT 17070
73ENV OSMLCM_VCA_USER admin
74ENV OSMLCM_VCA_SECRET secret
Dominik Fleischmann90fd5b32020-03-19 09:23:00 +010075ENV OSMLCM_VCA_CLOUD: localhost
garciadeblasee29bc72019-12-17 15:47:58 +010076# ENV OSMLCM_VCA_ENABLEOSUPGRADE false
77# ENV OSMLCM_VCA_APTMIRROR http://archive.ubuntu.com/ubuntu/
78# ENV OSMLCM_VCA_PUBKEY pubkey
79# ENV OSMLCM_VCA_CACERT cacert
tiernoc0e42e22018-05-11 11:36:10 +020080
tierno744303e2020-01-13 16:46:31 +000081# VCA - k8s
82ENV OSMLCM_VCA_HELMPATH /usr/local/bin/helm
83ENV OSMLCM_VCA_KUBECTLPATH /usr/bin/kubectl
84ENV OSMLCM_VCA_JUJUPATH /usr/local/bin/juju
85
tiernoc0e42e22018-05-11 11:36:10 +020086# database
87ENV OSMLCM_DATABASE_DRIVER mongo
tiernof7e0a642018-11-17 01:01:52 +010088ENV OSMLCM_DATABASE_URI mongodb://mongo:27017
89# ENV OSMLCM_DATABASE_COMMONKEY xxx
tierno17a612f2018-10-23 11:30:42 +020090# ENV OSMLCM_DATABASE_USER xxx
91# ENV OSMLCM_DATABASE_PASSWORD xxx
tierno17a612f2018-10-23 11:30:42 +020092
93#storage
Eduardo Sousa5899e082019-06-21 11:54:56 +010094ENV OSMLCM_STORAGE_DRIVER local
95ENV OSMLCM_STORAGE_PATH /app/storage
96#ENV OSMLCM_STORAGE_DRIVER mongo
97#ENV OSMNBI_STORAGE_URI mongodb://mongo:27017
98#ENV OSMLCM_STORAGE_COLLECTION files
tiernoc0e42e22018-05-11 11:36:10 +020099
100# message
101ENV OSMLCM_MESSAGE_DRIVER kafka
102ENV OSMLCM_MESSAGE_HOST kafka
103ENV OSMLCM_MESSAGE_PORT 9092
104
calvinosanch9f9c6f22019-11-04 13:37:39 +0100105
tierno275411e2018-05-16 14:33:32 +0200106# logs
tiernof7e0a642018-11-17 01:01:52 +0100107# ENV OSMLCM_GLOBAL_LOGFILE /app/log/lcm.log
tierno275411e2018-05-16 14:33:32 +0200108ENV OSMLCM_GLOBAL_LOGLEVEL DEBUG
109
tierno744303e2020-01-13 16:46:31 +0000110# timeouts
111# ENV OSMLCM_TIMEOUT_NS_DEPLOY 7200
112# ENV OSMLCM_TIMEOUT_NSI_DEPLOY 7200
113
tiernof7e0a642018-11-17 01:01:52 +0100114# Copy the current directory contents into the container at /app/LCM
115ADD . /app/LCM
Felipe Vicensc2033f22018-11-15 15:09:58 +0100116
tiernoc0e42e22018-05-11 11:36:10 +0200117# Run app.py when the container launches
tierno2b829912019-08-30 15:21:05 +0000118CMD python3 -m osm_lcm.lcm
tiernoa9843d82018-10-24 10:44:20 +0200119
tierno94f06112020-02-11 12:38:19 +0000120# HEALTHCHECK --start-period=120s --interval=30s --timeout=30s --retries=1 \
121# CMD python3 -m osm_lcm.lcm_hc || exit 1
122