X-Git-Url: https://osm.etsi.org/gitweb/?p=osm%2FNBI.git;a=blobdiff_plain;f=Dockerfile.local;h=2816d0a0996d9a4bd1b6f5e629b22fcf3e303465;hp=7ac60914a16e908bdbff9d4843baad3146b03320;hb=5758955b7b394517ff5caf5506a4400cdc5aa372;hpb=35ef2f7832eb995b700a882262305a0dfedbc4c1;ds=sidebyside diff --git a/Dockerfile.local b/Dockerfile.local index 7ac6091..2816d0a 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -1,54 +1,68 @@ -# Licensed under the Apache License, Version 2.0 (the "License"); -# you may not use this file except in compliance with the License. -# You may obtain a copy of the License at +## +# Copyright ETSI # -# http://www.apache.org/licenses/LICENSE-2.0 +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software -# distributed under the License is distributed on an "AS IS" BASIS, -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or -# implied. -# See the License for the specific language governing permissions and -# limitations under the License. - -# This creates osm/NBI docker from local NBI source code - -FROM ubuntu:16.04 - -# Set the working directory to /app -WORKDIR /app/NBI/osm_nbi - -RUN apt-get update && apt-get install -y git python3 python3-jsonschema \ - python3-pymongo python3-yaml python3-pip python3-keystoneclient \ - && pip3 install pip==9.0.3 \ - && pip3 install aiokafka aiohttp cherrypy==18.0.0 keystoneauth1 requests \ - && mkdir -p /app/storage/kafka && mkdir -p /app/log - -# OSM_COMMON -RUN git -C /app clone https://osm.etsi.org/gerrit/osm/common.git \ - && pip3 install -e /app/common -# && cd common && python3 setup.py develop && cd .. -# && pip3 install -U -r requirements.txt \ -# && cd .. - -# OSM_IM -RUN pip3 install pyang && mkdir -p /app && cd /app \ - && git -C /app clone https://github.com/robshakir/pyangbind \ - && pip3 install -e /app/pyangbind \ - && git -C /app clone https://osm.etsi.org/gerrit/osm/IM \ - && cd /app/IM/models/yang \ - && mkdir /app/IM/osm_im \ - && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/vnfd.py vnfd.yang \ - && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/nsd.py nsd.yang \ - && pyang --plugindir /app/pyangbind/pyangbind/plugin -f pybind -o /app/IM/osm_im/nst.py nst.yang \ - && pip3 install -e /app/IM +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +## + +######################################################################## + +FROM ubuntu:18.04 as INSTALL + +WORKDIR /build + +RUN DEBIAN_FRONTEND=noninteractive apt-get --yes update && \ + DEBIAN_FRONTEND=noninteractive apt-get --yes install \ + gcc git python3 python3-dev python3-venv python3-pip \ + python3-setuptools wget && \ + python3 -m pip install -U pip build + +COPY . /build + +RUN git clone https://osm.etsi.org/gerrit/osm/common.git +RUN git clone https://osm.etsi.org/gerrit/osm/IM.git + +RUN python3 -m pip install \ + -r requirements.txt \ + -r common/requirements.txt \ + -r IM/requirements.txt + +RUN python3 -m build /build/common && \ + python3 -m pip install /build/common/dist/*.whl + +RUN python3 -m build /build/IM && \ + python3 -m pip install /build/IM/dist/*.whl + +RUN python3 -m build /build && \ + python3 -m pip install /build/dist/*.whl + + +FROM ubuntu:18.04 as FINAL + +RUN DEBIAN_FRONTEND=noninteractive apt-get --yes update && \ + DEBIAN_FRONTEND=noninteractive apt-get --yes install python3-minimal + +COPY --from=INSTALL /usr/lib/python3/dist-packages /usr/lib/python3/dist-packages +COPY --from=INSTALL /usr/local/lib/python3.6/dist-packages /usr/local/lib/python3.6/dist-packages + +RUN mkdir -p /app/storage/kafka && mkdir -p /app/log + +WORKDIR /app/osm_nbi EXPOSE 9999 -LABEL Maintainer="alfonso.tiernosepulveda@telefonica.com" \ - Description="This implements a north bound interface for OSM" \ - Version="1.0" \ - Author="Alfonso Tierno" +RUN cp -R /usr/local/lib/python3.6/dist-packages/osm_nbi/html_public /app/osm_nbi/html_public +RUN cp /usr/local/lib/python3.6/dist-packages/osm_nbi/nbi.cfg /app/osm_nbi/ +RUN cp -R /usr/local/lib/python3.6/dist-packages/osm_nbi/http /app/osm_nbi/ # Used for local storage VOLUME /app/storage @@ -57,26 +71,32 @@ VOLUME /app/log # The following ENV can be added with "docker run -e xxx' to configure # server -ENV OSMNBI_SOCKET_HOST 0.0.0.0 -ENV OSMNBI_SOCKET_PORT 9999 +ENV OSMNBI_SOCKET_HOST 0.0.0.0 +ENV OSMNBI_SOCKET_PORT 9999 +ENV OSMNBI_SERVER_SSL_CERTIFICATE /app/osm_nbi/http/cert.pem +ENV OSMNBI_SERVER_SSL_PRIVATE_KEY /app/osm_nbi/http/privkey.pem + # storage -ENV OSMNBI_STORAGE_PATH /app/storage +ENV OSMNBI_STORAGE_PATH /app/storage + # database -ENV OSMNBI_DATABASE_DRIVER mongo -ENV OSMNBI_DATABASE_HOST mongo -ENV OSMNBI_DATABASE_PORT 27017 -# ENV OSMNBI_DATABASE_USER xxx -# ENV OSMNBI_DATABASE_PASSWORD xxx -# ENV OSMNBI_DATABASE_COMMONKEY xxx +ENV OSMNBI_DATABASE_DRIVER mongo +ENV OSMNBI_DATABASE_URI mongodb://mongo:27017 +#ENV OSMNBI_DATABASE_HOST mongo +#ENV OSMNBI_DATABASE_PORT 27017 + # web -ENV OSMNBI_STATIC_DIR /app/NBI/osm_nbi/html_public -# logs -# ENV OSMNBI_LOG_FILE /app/log/nbi.log -ENV OSMNBI_LOG_LEVEL DEBUG +ENV OSMNBI_STATIC_DIR /app/osm_nbi/html_public + # message -ENV OSMNBI_MESSAGE_DRIVER kafka -ENV OSMNBI_MESSAGE_HOST kafka -ENV OSMNBI_MESSAGE_PORT 9092 +ENV OSMNBI_MESSAGE_DRIVER kafka +ENV OSMNBI_MESSAGE_HOST kafka +ENV OSMNBI_MESSAGE_PORT 9092 + +# logs +ENV OSMNBI_LOG_FILE /app/log/nbi.log +ENV OSMNBI_LOG_LEVEL DEBUG + # authentication ENV OSMNBI_AUTHENTICATION_BACKEND internal #ENV OSMNBI_AUTHENTICATION_BACKEND keystone @@ -87,15 +107,10 @@ ENV OSMNBI_AUTHENTICATION_BACKEND internal #ENV OSMNBI_AUTHENTICATION_SERVICE_USERNAME nbi #ENV OSMNBI_AUTHENTICATION_SERVICE_PASSWORD nbi #ENV OSMNBI_AUTHENTICATION_SERVICE_PROJECT service -# RBAC -ENV OSMNBI_RBAC_RESOURCES_TO_OPERATIONS /app/NBI/osm_nbi/resources_to_operations.yml -ENV OSMNBI_RBAC_ROLES_TO_OPERATIONS /app/NBI/osm_nbi/roles_to_operations.yml -# prometheus + +#prometheus ENV OSMNBI_PROMETHEUS_HOST prometheus ENV OSMNBI_PROMETHEUS_PORT 9090 -# Copy the current directory contents into the container at /app -ADD . /app/NBI - # Run app.py when the container launches -CMD ["python3", "nbi.py"] +CMD ["python3", "-u", "-m", "osm_nbi.nbi"]