From 1bc5690a09462237d48e5ed409e985597681898f Mon Sep 17 00:00:00 2001 From: Sylvain Desbureaux Date: Wed, 30 Jan 2019 14:36:14 +0100 Subject: reduce ccsdk-ansible-server image footprint Project "CIA" scope is to provide smaller and multi architecture docker images. This proposition aims to do that for ccsdk-ansible-server. The current size of this proposal is 139mb compared to the 618Mb image proposed before (and before actual ansible installation). Principles used are the following: 1. a "basic" `docker build .` should provide a working image; 2. use the smallest (and multi arch) base image possibe; 3. install necessary stuff only; 4. leverage python best practices for installation; 5. remove installation stuff occuring at run level and move them to build level. * Dockerfile is now at the root part; * ansible configuration file `ansible.cfg` is created and put in `configuration` folder; * ansible configuration file `ansible.cfg` is pushed during the build part with a reproductible process; * `python` files are on `ansible-server" folder so copying during build works out of the box; * yml files are put directly on `ansible-server/Playbooks` so copying during build works out the box; * Dockerfile base image is now alpine:3.8; * `timeout` executable being now from busybox, change in the command-line call has been made (`--signal` is now `-s` and `-t` is set before setting the timeout value). * Only install python and python-pip as alpine package and remove build dependencies package after use. * put all python requirements in `requirements.txt` package and launch pip installation command with this file. * call directly python main script (`RestServer.py`) as entrypoint and do the python installation stuff at build time. - [x] change pom.xml so building parts works - [ ] consider changing destination folder (`/opt/ansible-server/`) to the ancient one (`/opt/onap/ccsdk/`) if this is problematic Change-Id: I5c66f29ca40d9224aef3d230593735b8e0aa1f3b Issue-ID: INT-816 Signed-off-by: Sylvain Desbureaux --- ansible-server/src/main/scripts/startAnsibleServer.sh | 15 --------------- 1 file changed, 15 deletions(-) delete mode 100644 ansible-server/src/main/scripts/startAnsibleServer.sh (limited to 'ansible-server/src/main/scripts/startAnsibleServer.sh') diff --git a/ansible-server/src/main/scripts/startAnsibleServer.sh b/ansible-server/src/main/scripts/startAnsibleServer.sh deleted file mode 100644 index 966a29a1..00000000 --- a/ansible-server/src/main/scripts/startAnsibleServer.sh +++ /dev/null @@ -1,15 +0,0 @@ -#!/bin/bash -exec &> >(tee -a "/var/log/ansible-server.log") - -if [ ! -f /tmp/.ansible-server-installed ] -then - pip install 'cherrypy<18.0.0' - pip install requests - - cp /etc/ansible/ansible.cfg /etc/ansible/ansible.cfg.orig - cat /etc/ansible/ansible.cfg.orig | sed -e 's/#host_key_checking/host_key_checking/' > /etc/ansible/ansible.cfg - date > /tmp/.ansible-server-installed 2>&1 -fi - -cd /opt/onap/ccsdk -exec /usr/bin/python RestServer.py -- cgit 1.2.3-korg