The main objective of this Ansible project is to automate the configuration of the DCM component to be deployed in 5G EVE from scratch, with differents steps to be executed, all gathered in main_playbook.yml. It also serves for the site broker plugins that interact with the DCM in the IWL.
Be sure of using this Ansible in a server which is able to reach the server through a SSH connection.
Note: be aware of having Internet connection and DNS resolution in the server to be updated. For that purpose, include nameserver 8.8.8.8 in /etc/resolv.conf in case it has not been included in that file or in /etc/network/interfaces file with the clause dns-nameservers 8.8.8.8. Moreover, it is desirable to exchange SSH keys between the DCM server and the server in which Ansible will be executed.
$ sudo apt-get update -y
$ sudo apt-get install software-properties-common -y
$ sudo apt-add-repository --yes --update ppa:ansible/ansible
$ sudo apt-get install ansible -y
$ export ANSIBLE_HOST_KEY_CHECKING=False
$ sudo apt-get update -y
$ sudo apt-get install git -y
It is contained in the 5geve-wp3-dcm-deployment Ansible project:
$ cd /tmp
$ git clone [email protected]:5GEVE/5geve-wp3-dcm-deployment.git
$ cd 5geve-wp3-dcm-deployment
$ git checkout v0.2 # if exists - if not, use master branch or whatever
In this Ansible project, there are some configuration files that must be completed with all the necessary information in order to reflect the infrastructure to be uploaded with all the steps included here. The configuration files with their description are the following:
- hosts: here, you have to include the DCM server which will be configured within this Ansible project. The format of each line (PLEASE FOLLOW THIS FORMAT) should be the following: dcm_hostname ansible_host=<DCM_IP> ansible_user= ansible_ssh_pass=<SSH_PASS> ansible_become_pass=<SUDO_PASS>
- group_vars: includes useful variables for the servers defined in the hosts file.
- all: applies to all servers. Nothing to change here at the beginning. Only if you want to be stopped with each Ansible role execution, set prompt_when_finishes_tasks to true, or false otherwise. Other variables that may require a change are kafka_version, which must be set to the Kafka version to be used, update_module, which specifies if it is an update (true) or an installation from scratch (false), site, which specifies the location of the server to be updated, choosing between the following values: iwl (default), spain, italy, france and greece, kafka_topics_script_route, which specifies, for the site brokers, the route in which the kafka-topics.sh script is located, {spanish|italian|french|greek}_site_ip_port, which contains the IP:Kafka port in the site broker (must be the one in the VPN), {spanish|italian|french|greek}_plugin_ip_port, which contains the IP:plugin port in the site broker (must be the one in the VPN), {spanish|italian|french|greek}_plugin_port, which only specifies the plugin port, and {spanish|italian|french|greek}_vpn_ip, which refers to the IP address used for each Kafka brokers in the VPN.
$ cd /tmp
$ git clone [email protected]:5GEVE/5geve-wp3-dcm-handler.git
$ cd 5geve-wp3-dcm-handler
$ git checkout v0.2 # if exists - if not, use master branch or whatever
6. Compress 5geve-wp3-dcm-handler project and put it in this Ansible project as file (only if Kafka broker is the one from IWL)
The easiest way to transfer the 5geve-wp3-dcm-handler project to the DCM server without having to exchange private keys or related (and confidential) information is to compress the 5geve-wp3-dcm-handler project and send it to the DCM server, where it would be decompressed and executed afterwards.
$ cd /tmp
$ mv 5geve-wp3-dcm-handler dcm-python
$ tar czf dcm-python.tar.gz dcm-python
$ mv dcm-python.tar.gz 5geve-wp3-dcm-deployment/roles/preparation/files
7. Download 5geve-wp3-dcm-site-plugin repository from Github (only if Kafka broker is from a specific site facility)
$ cd /tmp
$ git clone [email protected]:5GEVE/5geve-wp3-dcm-site-plugin.git
$ cd 5geve-wp3-dcm-site-plugin
$ git checkout v0.1 # if exists - if not, use master branch or whatever
8. Compress 5geve-wp3-dcm-site-plugin project and put it in this Ansible project as file (only if Kafka broker is from a specific site facility)
The easiest way to transfer the 5geve-wp3-dcm-site-plugin project to the server without having to exchange private keys or related (and confidential) information is to compress the 5geve-wp3-dcm-site-plugin project and send it to the server, where it would be decompressed and executed afterwards.
$ cd /tmp
$ mv 5geve-wp3-dcm-site-plugin dcm-site-plugin
$ tar czf dcm-site-plugin.tar.gz dcm-site-plugin
$ mv dcm-site-plugin.tar.gz 5geve-wp3-dcm-deployment/roles/preparation/files
$ cd /tmp/automated-infrastructure-scripts/ansible-dcm
$ ansible-playbook -i hosts main_playbook.yml
- In case you want to monitor how much time is spent in each task, you have to modify the file /etc/ansible/ansible.cfg by uncommenting the callback_whitelist variable (line 83 of the file, "probably"), putting the following value: callback_whitelist = profile_tasks
This work has been done by Telcaria Ideas S.L. for the 5G EVE European project under the Apache 2.0 License.