sys_use - sk4zuzu/one-deploy GitHub Wiki
Using the Playbooks
To use the playbooks, you'll need to:
- Download the playbooks.
- Install the requirements.
- Create and edit your inventory file.
- Execute the provisioning.
Downloading the Playbooks
The easiest and recommended way to use the playbooks is by cloning the GitHub project.
$ git clone --recursive https://github.com/OpenNebula/one-deploy.git
This will clone the playbooks in the one-deploy
directory.
[!NOTE] You will need to use this method if you plan to deploy Ceph clusters with OneDeploy.
If you have Ansible already installed, you can also use ansible-galaxy
to install directly from the GitHub repo:
$ ansible-galaxy collection install --upgrade [email protected]:OpenNebula/one-deploy.git,release-1.2.0
[!NOTE] Although pre-release
0.1.0
was initially pushed to the Ansible Galaxy community site, this is no longer being maintained. Cloning or installing from the GitHub repo is a much cleaner method, as described in the Ansible documentation.
Installing the Requirements
To download and install the requirements, you can use Ansible commands or the included Makefile.
Using the Makefile: From the one-deploy
directory, run:
make requirements
Using Ansible: From the one-deploy
directory, run:
ansible-galaxy collection install -r requirements.yml
Executing the Provisioning
At the root of the one-deploy
directory, the ansible.cfg
file contains:
[defaults]
collections_paths = ./ansible_collections/
The ansible_collections/opennebula/deploy
directory is in fact a symlink to the repo's root directory:
one-deploy$ file ansible_collections/opennebula/deploy
ansible_collections/opennebula/deploy: symbolic link to ../../
This allows you to use files cloned from git as a "local" Galaxy collection.
You will need to create your inventory file in the inventory
folder, or alternatively adapt one of the provided files to your needs.
Creating and Configuring the Inventory File
For your inventory file you can adapt one of the files provided in the one-deploy/inventory
directory, or create your own.
Main Inventory File Global Parameters
Below are some of the main parameters for the whole deployment:
Parameter | Description |
---|---|
one_version |
OpenNebula version to deploy |
one_pass |
Password for the oneadmin user |
ansible_user |
System user that will run the ansible playbooks (specify if other than root) |
Example Inventory File
In this example we will create an inventory folder, place the Ansible configuration file and inventory file in it, and execute the playbooks from there.
Create your inventory folder, then navigate to it:
mkdir ~/my-one/ && cd ~/my-one/
Create the inventory file, in this case example.yml
:
$ cat > example.yml <<'EOF'
---
all:
vars:
ansible_user: root
one_version: '6.10'
one_pass: opennebulapass
vn:
admin_net:
managed: true
template:
VN_MAD: bridge
PHYDEV: eth0
BRIDGE: br0
AR:
TYPE: IP4
IP: 172.20.0.100
SIZE: 48
NETWORK_ADDRESS: 172.20.0.0
NETWORK_MASK: 255.255.255.0
GATEWAY: 172.20.0.1
DNS: 1.1.1.1
frontend:
hosts:
f1: { ansible_host: 172.20.0.6 }
node:
hosts:
n1: { ansible_host: 172.20.0.7 }
n2: { ansible_host: 172.20.0.8 }
EOF
[!NOTE] You will probably need to adapt this sample file to your infrastructure, e.g. IP addresses, etc.
Create the ansible.cfg
file:
$ cat > ansible.cfg <<'EOF'
[defaults]
inventory=./example.yml
gathering=explicit
host_key_checking=false
display_skipped_hosts=true
retry_files_enabled=false
any_errors_fatal=true
stdout_callback=yaml
timeout=30
collections_paths=/home/user/one-deploy/ansible_collections
[ssh_connection]
pipelining=true
ssh_args=-q -o ControlMaster=auto -o ControlPersist=60s
EOF
[!NOTE] Ensure to replace
collections_paths
with the path to the Ansible collection.
Executing the Provisioning
From the my-one
directory you can run:
ansible-playbook -v opennebula.deploy.main
You can also execute from the one-deploy
directory, using the included Makefile or entering ansible-playbook
commands directly.
make I=inventory/my_inventory.yml
Or alternatively:
ansible-playbook -i inventory/my_inventory.yml opennebula.deploy.main
Executing Only Specific Tasks
You can execute only specific tasks by using tags:
make I=inventory/my_inventory.yml T=bastion,preinstall
Or alternatively:
$ ansible-playbook -i inventory/example.yml opennebula.deploy.main -t bastion,preinstall
For a list of tags please see below.
Customizing the Playbooks
You can also compose your own playbook, or embed opennebula.deploy.*
roles into an existing automation. For example, to run only SSH key provisioning from the my-one
directory:
ansible-playbook -v keys.yml
Where keys.yml
contains:
---
- hosts: frontend:node
roles:
- role: opennebula.deploy.helper.key
For a complete list of playbooks and roles please refer to the Playbook Reference.
Available Tags
Tag | Description |
---|---|
bastion |
Render local SSH jump-host configs |
ceph |
Manage Ceph on the OpenNebula's side |
datastore |
Manage datastores |
flow |
Manage the OneFlow service |
frontend |
Run all tasks needed for Front-end deployment |
gate |
Manage OneGate Server and Proxy services |
grafana |
Manage Grafana |
gui |
Manage Sunstone and FireEdge services |
keys |
Generate and provision SSH keys (password-less login) |
libvirt |
Apply various Libvirt-related fixes on OpenNebula Nodes |
network |
Manage networking |
node |
Run all tasks needed for Node deployment |
preinstall |
Download and install (only) all software packages |
prometheus |
Manage Prometheus Server and exporters |