Esta vez vamos a explicar cómo instalar PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish paso a paso, de forma que puedas trabajar con este potente motor de bases de datos relacionales sobre tu servidor o VPS Ubuntu, tanto en tus propios desarrollos como para preparar la base que necesitan aplicaciones de terceros.
Ubuntu 22.04 LTS Jammy Jellyfish no es la última versión de esta distribución. Si esta es la versión que te interesa puedes continuar con el tutorial, en caso contrario tal vez te interese consultar la guía de instalación de PostgreSQL en Ubuntu que sí cubre este proceso en la última versión. También dispones de versiones de este tutorial para lanzamientos anteriores de Ubuntu (y otros sistemas), que podrás encontrar fácilmente en nuestro buscador.
Contenido
Antes de instalar PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish
Si quieres seguir los pasos de esta guía de instalación de PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish sólo necesitas contar con el siguiente escenario:
- Un sistema Ubuntu 22.04 LTS Jammy Jellyfish actualizado.
- Un usuario con privilegios de sudo.
- Acceso a Internet.
Como seguramente ya dispones de todo el entorno necesario, es hora de ajustar la altura correcta de tu mesa y abrir una terminal de comandos.
Cómo instalar PostgreSQL en Ubuntu 22.04 LTS
Para instalar PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish usaremos los paquetes de la versión incluida en los repositorios de la distribución, la 14.11 en el momento de actualizar este tutorial, por lo que los actualizamos:
~$ sudo apt update
El paquete que instalaremos es postgresql:
~$ sudo apt install -y postgresql
Una vez descargado e instalado este paquete y sus dependencias disponemos de un nuevo servicio en Ubuntu 22.04 LTS, el servicio postgresql o postgresql.service, servicio que queda iniciado y listo para recibir conexiones, como podemos comprobar con el siguiente comando:
~$ systemctl status postgresql
Igualmente PostgreSQL queda habilitado para iniciar automáticamente con cada arranque de Ubuntu 22.04 LTS.
Cómo instalar el cliente de PostgreSQL en Ubuntu 22.04 LTS
Si sólo quieres instalar el cliente de PostgreSQL para Ubuntu 22.04 LTS el paquete que necesitas es postgresql-client:
~$ sudo apt install -y postgresql-client
Aunque si has instalado el servidor de bases de datos no será necesario instalar el cliente, ya que este forma parte de las dependencias.
En cualquier caso, ahora ya dispones del cliente de consola psql.
Cómo conectar al servicio PostgreSQL en Ubuntu 22.04 LTS
Para conectar al servicio PostgreSQL en Ubuntu 22.04 LTS disponemos del cliente de consola psql y el usuario administrador postgres. Este usuario no accede mediante contraseña, sino por socket de Unix, por lo que es necessario utilizar sudo:
~$ sudo -iu postgres psql psql (14.11 (Ubuntu 14.11-0ubuntu0.22.04.1)) Type "help" for help. postgres=#
Podemos cerrar la conexión con el comando exit:
# exit
Crea tu propio usuario de PostgreSQL
Para dejar de trabajar con el usuario postgres mediante sudo es interesante crear nuestro propio usuario o rol de PostgreSQL, con idéntico nombre que el usuario que usamos en Ubuntu 22.04 LTS si nos interesa utilizar la autenticación por socket.
Para ello usaremos el comando createuser con parámetros de creación de contraseña y comportamiento interactivo, además del nombre del nuevo rol:
~$ sudo -iu postgres createuser -P --interactive instalador Enter password for new role: Enter it again: Shall the new role be a superuser? (y/n) y
Se nos pedirá la contraseña y su confirmación, así como si queremos que el nuevo rol sea administrador.
Para poder usar el cliente de consola psql antes hay que crear una base de datos con el mismo nombre que el rol, ya que el cliente intenta conectar automáticamente a dicha base de datos.
Usaremos para esta tarea el comando createdb, que ahora sí podemos usar con nuestro rol administrador, indicando el nombre de la base de datos (el mismo que el del rol) y el rol al que pertenecerá:
~$ createdb instalador -O instalador
Ya tenemos lo necesario para probar el cliente psql con nuestro usuario y rol:
~$ psql psql (14.11 (Ubuntu 14.11-0ubuntu0.22.04.1)) Type "help" for help. instalador=#
Observa que no se nos pide contraseña, a pesar de haberla creado, porque la configuración por defecto es la de intentar usar un rol con el mismo nombre que el usuario de Ubuntu 22.04 LTS. Este comportamiento se puede cambiar para trabajar con contraseñas.
Cómo configurar PostgreSQL en Ubuntu 22.04 LTS
Vamos a aprender a configurar PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish trabajando sobre sus archivos de configuración alojados en la ruta /etc/postgresql/14/main/.
Activar el uso de contraseñas
Para trabajar con contraseñas, algo necesario cuando usamos las bases de datos PostgreSQL con aplicaciones de terceros, frontends, etc. editaremos el archivo pg_hba.conf:
~$ sudo nano /etc/postgresql/14/main/pg_hba.conf
Localizamos esta línea:
... local all all peer ...
Aquí se especifica que las conexiones locales se autentican mediante sockets de Unix, sin contraseñas. Es decir, se intenta conectar al servicio con un rol con el mismo nombre que el usuario del sistema que realiza la conexión. Para utilizar contraseñas cambiaremos el parámetro peer por scram-sha-256:
... local all all scram-sha-256 ...
Si te fijas, por encima de esta línea estaba esta otra:
... local all postgres peer ...
Esta línea configura el acceso para el usuario postgres y al figurar en el archivo de configuración antes que la línea que hemos modificado prevalecerá sobre esta, por lo que ahora todos los usuarios locales accederán por contraseña excepto postgres. Puedes modificar este comportamiento, pero ciertas tareas de mantenimiento trabajan con esta configuración.
Una vez guardados los cambios, reiniciamos el servicio:
~$ sudo systemctl restart postgresql
Si ahora probamos a conectar de nuevo con el cliente psql veremos que el comportamiento ha cambiado:
~$ psql Password for user instalador: psql (14.11 (Ubuntu 14.11-0ubuntu0.22.04.1)) Type "help" for help. instalador=#
Se intenta conectar con el rol con el mismo nombre que el usuario del sistema, pero esta vez se solicita la contraseña.
Acceso remoto
Por defecto PostgreSQL sólo admite conexiones locales en Ubuntu 22.04 LTS Jammy Jellyfish. Para modificar este comportamiento tendremos que trabajar sobre dos archivos de configuración, empezando por pg_hba.conf:
~$ sudo nano /etc/postgresql/14/main/pg_hba.conf
Localizamos esta sección:
... # IPv4 local connections: host all all 127.0.0.1/32 scram-sha-256 # IPv6 local connections: host all all ::1/128 scram-sha-256 ...
Las directivas host configuran el acceso vía TCP/IP, en este caso local, para IPv4 e IPv6. Si queremos permitir conexiones en red tendremos que añadir una directiva más:
... # IPv4 local connections: host all all 127.0.0.1/32 scram-sha-256 # IPv6 local connections: host all all ::1/128 scram-sha-256 # Acceso remoto host all all all scram-sha-256 ...
Ahora todas las conexiones TCP/IP, incluyendo las de red, requerirán contraseña.
Guardado este archivo, editamos también postgresql.conf:
~$ sudo nano /etc/postgresql/14/main/postgresql.conf
Buscamos la siguiente línea:
... #listen_addresses = 'localhost' # what IP address(es) to listen on; ...
La activamos eliminando el carácter # al inicio de línea y cambiamos su valor por un asterisco:
... listen_addresses = '*' # what IP address(es) to listen on; ...
Guardamos los cambios y reiniciamos el servicio:
~$ sudo systemctl restart postgresql
Firewall
En caso de tener activado el firewall UFW en Ubuntu 22.04 LTS habrá que añadir una regla para PostgreSQL:
~$ sudo ufw allow postgresql
Cómo probar la conexión remota
Desde otra máquina en red que cuente con un cliente de PostgreSQL, por ejemplo, otra máquina Ubuntu que disponga del cliente de consola psql, indicamos la dirección del servidor y el rol con el que queremos iniciar sesión:
~$ psql -h ubuntu2204.local.lan -U instalador
Se solicitará la contraseña y si es correcta se establecerá la conexión, mostrando información sobre las versiones de cliente y servidor y el cifrado de la conexión.
Conclusión
Ahora que sabes cómo instalar PostgreSQL en Ubuntu 22.04 LTS Jammy Jellyfish ya puedes trabajar con bases de datos relacionales sobre tu máquina, tanto para desarrollo como para establecer la base y requerimientos de otras aplicaciones.
Si quieres notificar algún error, realizar alguna sugerencia, etc. puedes dejar un comentario (están moderados para evitar el SPAM, pero se revisan prácticamente a diario).
¡Apoya comoinstalar.me!
¿Ya funciona este motor de bases de datos en tu sistema? Si es así y quieres agradecérnoslo cualquier mínima contribución al mantenimiento de este sitio y creación de más artículos es bienvenida.
Puedes ayudarnos dejando una propina a partir de 1 $ desde PayPal:
O, si te sientes especialmente agradecido, puedes invitarnos a un café:
¡Gracias!
Actualizado a la versión 14.11.