GNU/Linux >> Znalost Linux >  >> Debian

Jak nainstalovat a nakonfigurovat Postgres 14 na Debian 11

Postgresql je open source objektově relační databázový systém s více než 30 lety aktivního vývoje, který mu vynesl silnou pověst díky spolehlivosti, robustnosti funkcí a výkonu. Postgres je bezplatný a otevřený systém pro správu relačních databází, který klade důraz na rozšiřitelnost a shodu s SQL. Původně se jmenovala POSTGRES, odkazující na svůj původ jako nástupce databáze Ingres vyvinuté na Kalifornské univerzitě v Berkeley. PostgreSQL se používá jako primární datové úložiště nebo datové skladiště pro mnoho webových, mobilních, geoprostorových a analytických aplikací. PostgreSQL může ukládat strukturovaná i nestrukturovaná data v jediném produktu.

Zkontrolujte také:

  • Jak používat Ansible k instalaci a konfiguraci Postgres 14 na Debian 11
  • Jak nainstalovat a nakonfigurovat Postgres 14 na FreeBSD 13
  • Oprávnění Postgres – vytvářet, aktualizovat, mazat uživatele databáze
  • Jak nainstalovat a nakonfigurovat Postgres 13 na Centos 8
  • Spuštění Postgresql 14 pomocí Docker a Docker-Compose
  • Jak nainstalovat a nakonfigurovat Postgres 13 Ubuntu 20.04
  • Jak nainstalovat a nakonfigurovat Postgres 14 na Centos 8
  • Jak nainstalovat a nakonfigurovat Postgres 14 Ubuntu 20.04
  • Jak nainstalovat a nakonfigurovat Postgres 14 na Fedoře 34
  • Jak nainstalovat a nakonfigurovat Postgres 14 na OpenSUSE Leap 15.3

Předpoklady

Chcete-li pokračovat, ujistěte se, že máte následující:

  1. Server Debian 11
  2. Přístup uživatele root k serveru nebo uživateli s přístupem root
  3. Přístup k internetu ze serveru
  4. Základní znalost terminálu Linux

Obsah

  1. Ujistěte se, že je server aktuální
  2. Instalace a spuštění serveru Postgres
  3. Role PostgreSQL a metody ověřování databází
  4. Připojování k databázi postgres
  5. Konfigurace instance postgres 14 pro vzdálený přístup
  6. Správa uživatelů

1. Ujistěte se, že vaše systémové balíčky jsou aktuální

Obnovme místní index balíčků vašeho serveru pomocí tohoto příkazu:

sudo apt update

Pak upgradujeme balíčky v našem systému tímto:

sudo apt -y upgrade

Dovolte nám také nainstalovat potřebné balíčky nástrojů, které budeme používat

sudo apt -y install gnupg2 wget

2. Instalace Postgres 14

Postgres je poskytován ve výchozích repozitářích Debianu. Chcete-li zkontrolovat verzi, kterou poskytuje, použijte tento příkaz:

sudo apt-cache search postgresql | grep postgresql

Výchozí balíčky poskytované výchozími repozitáři jsou postgres 12. Pokud máte zájem o Postgres 12, můžete nainstalovat pomocí následujících příkazů. -contrib balíček, který přidává některé další nástroje a funkce:

sudo apt install postgresql postgresql-contrib

Protože se chystáme nainstalovat Postgres 14, budeme muset přidat další úložiště, které poskytuje balíčky. Vytvořte konfiguraci úložiště souborů

sudo sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'

Poté importujte podpisový klíč úložiště:

wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -

Nyní aktualizujme seznamy balíčků pro nová úložiště, aby odrážely:

sudo apt -y update

Nakonec nainstalujeme nejnovější verzi Postgres:

sudo apt -y install postgresql

Jakmile bude instalace úspěšná, spustí se Postgres 14.

Tento příkaz použijte ke kontrole stavu služby:

$ sudo systemctl status postgresql
● postgresql.service - PostgreSQL RDBMS
     Loaded: loaded (/lib/systemd/system/postgresql.service; enabled; vendor preset: enabled)
     Active: active (exited) since Mon 2021-10-18 04:33:26 UTC; 33s ago
    Process: 4788 ExecStart=/bin/true (code=exited, status=0/SUCCESS)
   Main PID: 4788 (code=exited, status=0/SUCCESS)
        CPU: 877us

Oct 18 04:33:26 ip-10-2-40-246 systemd[1]: Starting PostgreSQL RDBMS...
Oct 18 04:33:26 ip-10-2-40-246 systemd[1]: Finished PostgreSQL RDBMS.

Dále ověřte instalaci připojením k databázovému serveru PostgreSQL a kontrolou jeho verze. Použijte tento příkaz:

sudo -u postgres psql -c "SELECT version();"

Výstup

$ sudo -u postgres psql -c "SELECT version();"
                                                           version
-----------------------------------------------------------------------------------------------------------------------------
 PostgreSQL 14.0 (Debian 14.0-1.pgdg110+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 10.2.1-6) 10.2.1 20210110, 64-bit
(1 row)

3. PostgreSQL role a metody autentizace databází

PostgreSQL používá koncept zvaný roles pro zpracování autentizace a autorizace klienta. Ve výchozím nastavení je Postgres nastaven na používání ident authentication , což znamená, že přidružuje role Postgres k odpovídajícímu systémovému účtu Unix/Linux. Pokud role v Postgresu existuje, může se pomocí této role přihlásit uživatelské jméno Unix/Linux se stejným jménem.

Instalační procedura vytvořila uživatelský účet s názvem postgres  který je spojen s výchozím postgres role. Chcete-li používat PostgreSQL, můžete se přihlásit k tomuto účtu.

PostgreSQL podporuje více metod ověřování. Nejčastěji používané metody jsou:

  • Trust – Role se může připojit bez hesla, pokud jsou splněny podmínky definované v pg_hba.conf jsou splněny.
  • Password – Role se může připojit zadáním hesla. Hesla lze uložit jako scram-sha-256md5password (clear-text ).
  • Ident – Podporováno pouze u připojení TCP/IP. Funguje tak, že získá uživatelské jméno operačního systému klienta s volitelným mapováním uživatelského jména.
  • Peer – Stejné jako Ident, ale je podporováno pouze u místních připojení.

4. Připojování k databázi postgres

  1. Přepnutím na postres uživatel

Přepněte se na účet postgres na vašem serveru zadáním tohoto do terminálu;:

sudo -i -u postgres

Nyní můžete okamžitě otevřít výzvu Postgres zadáním:

$ psql
psql (14.0 (Debian 14.0-1.pgdg110+1))
Type "help" for help.

postgres=#

Tím se přihlásíte do příkazového řádku PostgreSQL a odtud můžete okamžitě pracovat se systémem správy databáze.

2. Spuštěním příkazu jako postgres uživatel

Použijte toto ke spuštění příkazu přímo jako postgres uživatel pomocí sudo

sudo -u postgres psql

Výstup:

$ sudo -u postgres psql
psql (14.0 (Debian 14.0-1.pgdg110+1))
Type "help" for help.

postgres=#

5. Konfigurace instance postgres 14 pro vzdálený přístup

Abychom toho dosáhli, upravíme konfigurační soubory postgres. Musíme otevřít soubory a upravit požadované konfigurace. Hlavní konfigurační soubor pro Postgresql 14 lze nalézt v této cestě /etc/postgresql/14/main/pg_hba.conf

Změňme identifikaci partnera na důvěryhodnost:

sed -i '/^local/s/peer/trust/' /etc/postgresql/14/main/pg_hba.conf

Změňte identifikaci na md5, abyste umožnili přihlášení pomocí hesla.

sed -i '/^host/s/ident/md5/' /etc/postgresql/14/main/pg_hba.conf

Přidejte blok, abyste umožnili přístup odkudkoli:

Přidejte tento obsah do souboru /etc/postgresql/14/main/pg_hba.conf

host    all             all             0.0.0.0/0                md5

Ujistěte se, že PostgreSQL naslouchá na *

Přidejte tento řádek do konfigurace zde /etc/postgresql/14/main/postgresql.conf

listen_addresses='*'

Povolte a restartujte server postgresql, aby se znovu načetly konfigurace

sudo systemctl restart postgresql
sudo systemctl enable postgresql

6. Správa uživatelů

Vytvoření superuživatele

Nyní, když je vše nastaveno, pojďme vytvořit superuživatele.
Připojte se k DB jako postres role:

# sudo -u postgres psql
psql (14.0 (Debian 14.0-1.pgdg110+1))
Type "help" for help.

postgres=#

Vytvořte superuživatele se jménem root :

CREATE ROLE root WITH LOGIN SUPERUSER CREATEDB CREATEROLE PASSWORD 'passwordhere';

Výstup:

# CREATE ROLE root WITH LOGIN SUPERUSER CREATEDB CREATEROLE PASSWORD 'passwordhere';
CREATE ROLE
postgres=# \du
                                   List of roles
 Role name |                         Attributes                         | Member of
-----------+------------------------------------------------------------+-----------
 postgres  | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
 root      | Superuser, Create role, Create DB                          | {}

postgres=#

Správa uživatelů aplikací

Toto použijte k vytvoření databáze, vytvoření uživatele a udělení všech přístupů tomuto uživateli k této databázi:

create database app_db_name;
create user app_user with encrypted password 'dbpassword';
grant all privileges on database app_db_name to app_user;

Prohlédněte si tohoto komplexního průvodce správou uživatelů a oprávnění v postgres zde.

Připojení k instanci ze vzdáleného hostitele

Tento příkaz použijte k připojení k postgresové instanci z místního počítače:

psql 'postgres://<username>:<password>@<host>:<port>/<db>?sslmode=disable'

# like
psql 'postgres://root:[email protected]:5432/postgres?sslmode=disable'

Závěr

Do této chvíle se nám podařilo nainstalovat Postgresql 14 na server Debian 11, provést několik základních konfigurací a poté provést základní správu uživatelů.


Debian
  1. Jak nainstalovat a nakonfigurovat Postgres 14 Ubuntu 20.04

  2. Jak nainstalovat a nakonfigurovat docker na Debian 11

  3. Jak nainstalovat a nakonfigurovat Postgres 14 na Debian 11

  1. Jak nainstalovat a nakonfigurovat Mariadb 10 v Debianu 11

  2. Jak nainstalovat a nakonfigurovat MongoDB 5 na Debian 11

  3. Jak nainstalovat a nakonfigurovat Redis 6 na Debian 11

  1. Jak nainstalovat a nakonfigurovat Postgres 13 Ubuntu 20.04

  2. Jak nainstalovat a nakonfigurovat Postgres 13 na Centos 8

  3. Jak nainstalovat a nakonfigurovat Postgres 14 na Fedoře 34