Background
In this post, I will walk you through the complete end-to-end procedure for setting up an Ansible controller node and setting up the connection for managing RHEL and Windows Server nodes.
Azure setup
I have created 3 servers and placed them in a simple network configuration.
Infra:
10.0.3.4 ansiblecontrol (RHEL 8.7)
App:
10.0.5.4 linuxnode1 (RHEL 8.7)
10.0.5.5 windowsnode1 (Windows Server 2019)
OS preparation
Ensure all hosts are configured with the correct FQDN and IP configurations. This is more so important when dealing with domain-joined nodes.
ex:
- run hostnamectl set-hostname ansiblecontrol.local.vanguard.com to set the hostname for RHEL
- add DNS suffix to computer name on System Settings on Windows Server
Make sure the control node can reach the managed nodes in the absence of DNS by adding entries in /etc/hosts
Setting up Ansible on Control node
- Install ansible sudo yum install ansible
2. Generate SSH key pair for ansible user ssh-keygen
3. Copy public key to linuxnode1 ssh-copy-id linuxnode1.local.vanguard.com
4. Install pywinrm for managing Windows nodes pip3 install "pywinrm>=0.3.0"
5. Import windows module collection ansible-galaxy collection install ansible.windows
Setting up Linux managed node
- Add ansible user on linuxnode1 sudo useradd ansible
- Add ansible user in the sudoers file for password-less authentication for all elevated commands using sudo visudo
Setting up Windows managed node
1. Ensure PowerShell version is 5.0 and above using $PSVersionTable command. Also make sure .NET version is later than 4.0. However, with newer Windows Servers, this shouldnt be an issue.
2.
Set up WinRM listener on port 5986 for HTTPS transport. This requires the creation of a self-signed certificate. Ansible has provided a script for this task which is
available to download on GitHub
2. Additionally, make sure Windows Firewall is switched off
Sample Ansible directory setup
- Create inventory file by grouping the 2 managed nodes by operating system
2. Define group_vars.
Create a new file called windows.yml in group_vars. The contents of the file defines the connection parameters that will be used by ansible to connect with hosts under the windows group of the inventory file. This will also work for any dynamic inventory as long as those hosts are also added to the windows group during playbook runtime.
For domain-joined windows servers, it is advised to use the more secure kerberos instead of ntlm. In such cases, kerberos packages must be installed and krb5.conf configured on the ansible control node to obtain kerberos tickets from the AD domain.
3. Encrypt windows group_vars using ansible-vault to protect sensitive information
ansible-vault encrypt windows.yml
4. Perform a ping to verify connectivity using ad-hoc ping command. Make sure to use --ask-vault-pass for windows nodes
Sample playbook
1. The following playbook will install webserver on both nodes depending on their OS
2. Execute the playbook first by doing a dry-run
ansible-playbook installwebserver.yml -i testservers --check --ask-vault-pass
3. Run the playbook
ansible-playbook installwebserver.yml -i testservers --ask-vault-pass