offline-packaging: Package offline deployment dependencies for k8s
This change implements functionality to package the dependencies
needed to provision nodes and install kubernetes on them in an
offline/air gapped environment. Only bifrost and kubespray are
supported and the work to introduce support for heat based deployments
is pending. Support for OpenStack/Kolla will be introduced
depending on need. ONAP offline packaging will be developed
based on this packaging as well.
A new script named package.sh is introduced to be able to run
packaging process separately from the deployment so one can run
the packaging and then take the produced archive file to use
for offline deployment.
The packaged dependencies are
- operating system packages (only apt supported for the timebeing)
- python packages
- git repositories
- images to provision target nodes
- kubernetes and related binaries and container images
In order to package the correct versions of the open source artifacts,
versions of them are pinned in engine/inventory/group_vars/all/versions.yaml
file.
Some other cosmetic changes are also done as well.
- move conditionals to functions themselves to clean main deployment
script
- stop using ansible with_items for package installations since it
will be removed in future releases
- align Info and Error messages
Change-Id: Idd153e1d8032aa07b2ccc94ea074ff1b0ff0fa8c
diff --git a/install.sh b/install.sh
index be19ae6..1288055 100755
--- a/install.sh
+++ b/install.sh
@@ -27,7 +27,7 @@
# configure target hosts
echo "-------------------------------------------------------------------------"
-echo "Info: Configure target hosts"
+echo "Info : Configure target hosts"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
@@ -36,7 +36,7 @@
# configure installer
echo "-------------------------------------------------------------------------"
-echo "Info: Configure installer"
+echo "Info : Configure installer"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
@@ -45,7 +45,7 @@
# bootstrap scenario
echo "-------------------------------------------------------------------------"
-echo "Info: Execute scenario pre deployment tasks"
+echo "Info : Execute scenario pre deployment tasks"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
@@ -54,7 +54,7 @@
# install scenario
echo "-------------------------------------------------------------------------"
-echo "Info: Install scenario ${DEPLOY_SCENARIO}"
+echo "Info : Install scenario ${DEPLOY_SCENARIO}"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_CACHE}/repos/kubespray"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
@@ -65,7 +65,7 @@
# run post-deployment tasks
echo "-------------------------------------------------------------------------"
-echo "Info: Execute scenario and common post deployment tasks"
+echo "Info : Execute scenario and common post deployment tasks"
echo "-------------------------------------------------------------------------"
cd "${ENGINE_PATH}"
ansible-playbook "${ENGINE_ANSIBLE_PARAMS[@]}" \
diff --git a/playbooks/roles/configure-installer/tasks/main.yml b/playbooks/roles/configure-installer/tasks/main.yml
index b754e24..f7c97f8 100644
--- a/playbooks/roles/configure-installer/tasks/main.yml
+++ b/playbooks/roles/configure-installer/tasks/main.yml
@@ -160,7 +160,7 @@
path: "{{ engine_cache }}/repos/kubespray/roles/download/defaults/main.yml"
regexp: "^download_run_once:.*"
line: "download_run_once: true"
- when: offline_dependencies|bool
+ when: offline_deployment|bool
# Use a fake docker repository to overcome apt-cacher-ng limitation with https
- name: Configure docker repo to use jumphost apt proxy
diff --git a/playbooks/roles/configure-targethosts/tasks/install-packages-Debian.yml b/playbooks/roles/configure-targethosts/tasks/install-packages-Debian.yml
index 9abd870..7af2fae 100644
--- a/playbooks/roles/configure-targethosts/tasks/install-packages-Debian.yml
+++ b/playbooks/roles/configure-targethosts/tasks/install-packages-Debian.yml
@@ -17,18 +17,13 @@
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
+- name: Load distribution variables
+ include_vars: '{{ ansible_os_family }}.yml'
+
- name: Install packages
apt:
- name: "{{ item }}"
+ name: "{{ packages }}"
state: present
update_cache: true
- with_items:
- - "apt-transport-https"
- - "ca-certificates"
- - "curl"
- - "gnupg-agent"
- - "software-properties-common"
- - "chrony"
- - "dbus"
# vim: set ts=2 sw=2 expandtab:
diff --git a/playbooks/roles/configure-targethosts/tasks/sync-time.yml b/playbooks/roles/configure-targethosts/tasks/sync-time.yml
index 60d8bef..85ddd8b 100644
--- a/playbooks/roles/configure-targethosts/tasks/sync-time.yml
+++ b/playbooks/roles/configure-targethosts/tasks/sync-time.yml
@@ -17,7 +17,7 @@
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
-- name: Add the OS specific variables
+- name: Load distribution variables
include_vars: '{{ ansible_os_family }}.yml'
- name: Remove NTP if installed
diff --git a/playbooks/roles/configure-targethosts/vars/Debian.yml b/playbooks/roles/configure-targethosts/vars/Debian.yml
index fa38673..2d8f431 100644
--- a/playbooks/roles/configure-targethosts/vars/Debian.yml
+++ b/playbooks/roles/configure-targethosts/vars/Debian.yml
@@ -16,10 +16,20 @@
#
# SPDX-License-Identifier: Apache-2.0
# ============LICENSE_END=========================================================
+
chrony_service_name: chrony
chrony_config_location: /etc/chrony/chrony.conf
chrony_config_driftfile: /var/lib/chrony/chrony.drift
chrony_config_keyfile: /etc/chrony/chrony.keys
chrony_config_logdir: /var/log/chrony
+packages:
+ - apt-transport-https
+ - ca-certificates
+ - curl
+ - gnupg-agent
+ - software-properties-common
+ - chrony
+ - dbus
+
# vim: set ts=2 sw=2 expandtab: