Automation

Ansible Software Patching for Beginners

Ansible Software Patching for Beginners. If you have never used Ansible before, you need to start now to patch your systems!

Ansible is a well-known configuration management solution that can be used for automating many different things. One thing you can do very well with Ansible is using it for updates and software patching. Let’s see how.

Setting up Ansible patching

Before diving into Ansible software patching, setting up your environment is important. You’ll need to have Ansible installed, along with access to your Linux servers and the necessary packages.

Installing Ansible on Ubuntu

Before you can use Ansible for patching, you’ll need to install it on your system. If you’re using Ubuntu, follow these steps to install Ansible:

  1. Update the package list and install required dependencies:

sudo apt-get update sudo apt-get install software-properties-common
  1. Add the Ansible repository to your system:

sudo apt-add-repository --yes --update ppa:ansible/ansible
  1. Install Ansible:

sudo apt-get install ansible

Now that Ansible is installed on your Ubuntu system, you can create playbooks for patching.

Basic Ansible Software Patching Code for Linux and Windows

To demonstrate basic Ansible software patching, we’ll create two simple playbooks: one for Linux and one for Windows. These can be executed as shell scripts using Ansible open-source tool.

For Linux (using the apt module):

---
- name: Update Linux packages using apt
  hosts: debian_servers
  become: yes
  tasks:
    - name: Update package cache
      apt:
        update_cache: yes
        cache_valid_time: 3600

    - name: Upgrade all packages to their latest version
      apt:
        name: '*'
        state: latest
        force_apt_get: yes

    - name: Reboot the server if necessary
      reboot:
        test_command: uptime
        reboot_timeout: 300

For Linux (using the Yum module):

---
- name: Update Linux packages
  hosts: linux_servers
  become: yes
  tasks:
    - name: Update all packages
      yum:
        name: '*'
        state: latest

    - name: Reboot the server if necessary
      reboot:
        test_command: uptime
        reboot_timeout: 300

For Windows (using the Win_updates module):

---
- name: Update Windows packages
  hosts: windows_servers
  tasks:
    - name: Install all updates
      win_updates:
        category_names: ['CriticalUpdates', 'SecurityUpdates', 'UpdateRollups']
        state: installed

    - name: Reboot the server if necessary
      win_reboot:
        reboot_timeout: 300

These playbooks will update packages on your Linux and Windows systems, and reboot the servers if required. To run the playbooks, save them as separate files (e.g., patch_linux.yml and patch_windows.yml) and execute the following commands:

ansible-playbook -i inventory.ini patch_linux.yml ansible-playbook -i inventory.ini patch_windows.yml

Make sure to replace inventory.ini with your inventory file that lists your Linux and Windows servers.

Ansible Software Patching FAQs

  1. Make sure of update and patching windows

You can schedule your Ansible playbooks to run at set times tool like cron for Linux or Task Scheduler for Windows or you can use something like Ansible Semaphore. Here’s an example of a cron entry that runs a playbook at 2 AM every Sunday:

0 2  0 /usr/bin/ansible-playbook -i /path/to/inventory.ini /path/to/patch_playbook.yml

Remember to replace the paths with the actual locations of your inventory file and patch playbook.

  1. Make sure of update status

Gathering info about installed packages and their versions can help you verify that your systems are up-to-date. For example, on a Linux system using the apt module, you could use the following task:

- name: Get the list of installed packages and their versions
  apt:
    list: installed
  register: apt_packages

Then, you can use the debug module to display the list of installed packages and their versions:

- name: Display installed packages and their versions
  debug:
    var: apt_packages.stdout_lines
  1. Can I use Ansible to apply patches only to specific systems or packages?

Yes, you can use Ansible to patch specific systems or packages selectively. To target specific systems, you can define groups in your inventory file and then specify the group name in the hosts field of your playbook. For example:

[web_servers]
web1.example.com
web2.example.com

In your playbook, use hosts: web_servers to apply the patch only to the systems in the web_servers group.

To apply patches only to specific packages, you can modify the name parameter in the appropriate Ansible module (e.g., yum, apt, or win_updates). For instance, using the apt module, you could update only the ‘nginx’ package by setting name: nginx:

- name: Update the nginx package
  apt:
    name: nginx
    state: latest
    force_apt_get: yes

Wrapping up

Ansible software patching is a great way to keep your critical systems or home lab servers up-to-date. It streamlines this process and takes the possibilities of errors or just simply missing things out of the question. It is a great skill and tool to learn.

Subscribe to VirtualizationHowto via Email ๐Ÿ””

Enter your email address to subscribe to this blog and receive notifications of new posts by email.



Brandon Lee

Brandon Lee is the Senior Writer, Engineer and owner at Virtualizationhowto.com, and a 7-time VMware vExpert, with over two decades of experience in Information Technology. Having worked for numerous Fortune 500 companies as well as in various industries, He has extensive experience in various IT segments and is a strong advocate for open source technologies. Brandon holds many industry certifications, loves the outdoors and spending time with family. Also, he goes through the effort of testing and troubleshooting issues, so you don't have to.

Related Articles

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.