Loading...

Watch: Create PostgreSQL Users/Roles with Ansible: A Simple Guide

Discover how to create and manage PostgreSQL users and roles with Ansible. Follow our guide for seamless user management on your PostgreSQL server.

How to Create a PostgreSQL User / Role with Ansible?

I'm going to show you a live Playbook with some simple Ansible code.

I'm Luca Berton and welcome to today's episode of Ansible Pilot.

Ansible Create a PostgreSQL User/Role

  • community.postgresql.postgresql_user
  • Create, alter, or remove a user (role) from a PostgreSQL server instance

Let's talk about the Ansible module postgresql_user.

The full name is community.postgresql.postgresql_user, which means that is part of the collection of modules "community.postgresql" maintained by the Ansible Community to interact with PostgreSQL.

The collection is tested with ansible-core version 2.11+, prior versions such as 2.9 or 2.10 are not supported.

The purpose of the module is to create, alter, or remove a user (role) from a PostgreSQL server instance.

This module uses psycopg2, a Python PostgreSQL User library. You must ensure that python3-psycopg2 is installed on the host before using this module.

Parameters

  • name _string_ - Name of User
  • state _string_ - present/absent - The user (role) state
  • password _string_ - Password cleartext or MD5-hashed
  • db _string_ - Grant user permission to the database

Let me summarize the main parameters of the module postgresql_user.

Ansible supposes that PostgreSQL is in the target node.

The only required parameter is name, the name of the user to interact with.

The parameter state specify the desired user (role) state. The option "present" means that the user/role should be created. The option absent means that the user/role should be deleted.

You could specify the desired password in the password parameter in cleartext or MD5-hashed format.

You could also specify a database parameter to specify the name of the database to connect to and where the user's permissions are granted. You could also perform the same operation using the postgresql_privs Ansible module.

Links

  • [community.postgresql.postgresql_user](https://docs.ansible.com/ansible/latest/collections/community/postgresql/postgresql_user_module.html)

## Playbook

Let's jump into a real-life Ansible Playbook to Create a PostgreSQL User now called Role.

I'm going to show you how to create the myuser user (role) in the current PostgreSQL server.

code

```yaml

---

  • name: postgresql Playbook

hosts: all

become: true

vars:

db_user: myuser

db_password: MySecretPassword123

tasks:

- name: Utility present

ansible.builtin.package:

name: p

Read the full tutorial: Create PostgreSQL Users/Roles with Ansible: A Simple Guide