Managing Virtual Environments with Pipenv for Ansible Projects

When it comes to Python development, managing dependencies and creating a clean development environment are crucial aspects of maintaining a project. One popular tool that simplifies this process is Pipenv. It not only helps in managing virtual environments but also streamlines the process of adding and removing packages, making it an excellent choice for Python developers. In this article, we will explore how to use Pipenv to manage virtual environments specifically for Ansible projects.

What is Pipenv?

Pipenv is a versatile tool that brings together the best aspects of various packaging tools from different programming languages (such as bundler, composer, npm, cargo, yarn, etc.) and tailors them to the Python ecosystem. Its primary functions include automatic creation and management of virtual environments for projects and the addition/removal of packages from the Pipfile as packages are installed or uninstalled. Additionally, Pipenv generates the essential Pipfile.lock, which is crucial for ensuring deterministic builds.

Installation and Setup

To begin using Pipenv for an Ansible project, follow these steps:

  1. Create a Project Directory:

    $ mkdir ansible-project
    $ cd ansible-project
    
  2. Initialize Pipenv:

    $ pipenv --python 3
    

    This command initializes a new virtual environment with Python version 3. In this example, we use Python 3.11.2.

  3. Install Ansible:

    $ pipenv install ansible
    

    Here, we use the pipenv install command to install Ansible within the virtual environment.

Join 50+ hours of courses in our exclusive community

Checking Ansible Version

After the installation is complete, you can check the Ansible version within the Pipenv virtual environment:

  1. Start the Pipenv Shell:

    $ pipenv shell
    

    This command activates the virtual environment.

  2. Check Ansible Version:

    $ ansible --version
    

    The output will display information about the installed Ansible version, configuration file location, module search path, Python module location, and other relevant details.

    Sample Output:

    ansible [core 2.15.1]
      config file = /etc/ansible/ansible.cfg
      configured module search path = ['/home/sysadmin/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
      ansible python module location = /home/sysadmin/.local/share/virtualenvs/ansible-project-3Z1Z2Z2z/lib/python3.11/site-packages/ansible
      ansible collection location = /home/sysadmin/.ansible/collections:/usr/share/ansible/collections
      executable location = /home/sysadmin/.local/share/virtualenvs/ansible-project-3Z1Z2Z2z/bin/ansible
      python version = 3.11.2 (main, Mar 13 2023, 12:18:29) [GCC 12.2.0] (/home/sysadmin/.local/share/virtualenvs/ansible-project-3Z1Z2Z2z/bin/python)
      jinja version = 3.1.2
      libyaml = True
    

Conclusion

Pipenv simplifies the management of virtual environments for Ansible projects, ensuring a clean and reproducible development environment. By following the steps outlined in this article, you can seamlessly set up and manage your Python and Ansible dependencies, fostering a more efficient and organized development workflow. Subscribe to the YouTube channel, Medium, and Website, X (formerly Twitter) to not miss the next episode of the Ansible Pilot.

Academy

Learn the Ansible automation technology with some real-life examples in my Udemy 300+ Lessons Video Course.

BUY the Complete Udemy 300+ Lessons Video Course

My book Ansible By Examples: 200+ Automation Examples For Linux and Windows System Administrator and DevOps

BUY the Complete PDF BOOK to easily Copy and Paste the 250+ Ansible code

Want to keep this project going? Please donate

Patreon Buy me a Pizza