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.
V této příručce nainstalujeme Postgresql 14 v OpenSUSE Leap 15.3
Související obsah
- 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 14 na Centos 8
- 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 Debian 11
- Jak nainstalovat a nakonfigurovat Postgres 14 Ubuntu 20.04
- Jak nainstalovat a nakonfigurovat Postgres 14 na Fedoře 34
Předpoklady
Chcete-li pokračovat, ujistěte se, že máte následující:
- Aktualizovaný server Opensuse Leap 15
- Přístup uživatele root k serveru nebo uživateli s přístupem root
- Přístup k internetu ze serveru
- Základní znalost terminálu Linux
Obsah
- Ujistěte se, že je server aktuální
- Instalace a spuštění serveru Postgres
- Role PostgreSQL a metody ověřování databází
- Připojování k databázi postgres
- Konfigurace instance postgres 14 pro vzdálený přístup
- Správa uživatelů v Postgres 14
1. Ujistěte se, že je server aktuální
Než budete pokračovat, ujistěte se, že náš server má aktuální balíčky. Nejprve aktualizujte databázi balíčků repo
~> sudo zypper ref
Repository 'Update repository of openSUSE Backports' is up to date.
Repository 'Debug Repository' is up to date.
Repository 'Update Repository (Debug)' is up to date.
Repository 'Non-OSS Repository' is up to date.
Repository 'Main Repository' is up to date.
Repository 'Update repository with updates from SUSE Linux Enterprise 15' is up to date.
Repository 'Source Repository' is up to date.
Repository 'Main Update Repository' is up to date.
Repository 'Update Repository (Non-Oss)' is up to date.
All repositories have been refreshed.
Pak použijte tento příkaz k aktualizaci balíčků:
~> sudo zypper up
Retrieving repository 'Update repository with updates from SUSE Linux Enterprise 15' metadata ...................................[done]
Building repository 'Update repository with updates from SUSE Linux Enterprise 15' cache ........................................[done]
Loading repository data...
Reading installed packages...
Nothing to do.
2. Instalace a spuštění Postgres Server
Ve výchozím nastavení Opensuse Leap neobsahuje úložiště Postgresql. K nastavení repozitářů pro postgres 14 použijeme repo poskytnuté týmem postgres. To nám umožní nainstalovat Postgres.
Nainstalujme úložiště Postgres pomocí tohoto příkazu:
sudo zypper addrepo https://download.postgresql.org/pub/repos/zypp/repo/pgdg-sles-15-pg14.repo
Poté před instalací obnovte úložiště pomocí tohoto příkazu:
sudo zypper ref
Nakonec nainstalujte server PostgreSQL 14. Instalujeme také balíček Contrib, který poskytuje několik dalších funkcí pro databázový systém PostgreSQL:
sudo zypper in postgresql14-server postgresql14-contrib
Po dokončení instalace inicializujte databázi PostgreSQL následujícím příkazem:
~> sudo /usr/pgsql-14/bin/postgresql-14-setup initdb
Initializing database ... OK
Spusťte postgres pomocí tohoto příkazu:
sudo systemctl start postgresql-14
Poté povolte službu, aby se spustila, když se server restartuje.
~> sudo systemctl enable postgresql-14
Created symlink /etc/systemd/system/multi-user.target.wants/postgresql-14.service → /usr/lib/systemd/system/postgresql-14.service.
Potvrďte, že Postgres běží:
~> sudo systemctl status postgresql-14
● postgresql-14.service - PostgreSQL 14 database server
Loaded: loaded (/usr/lib/systemd/system/postgresql-14.service; enabled; vendor preset: disabled)
Active: active (running) since Tue 2021-10-26 18:52:54 UTC; 38s ago
Docs: https://www.postgresql.org/docs/14/static/
Main PID: 26244 (postmaster)
Tasks: 8 (limit: 4587)
CGroup: /system.slice/postgresql-14.service
├─26244 /usr/pgsql-14/bin/postmaster -D /var/lib/pgsql/14/data/
├─26245 postgres: logger
├─26247 postgres: checkpointer
├─26248 postgres: background writer
├─26249 postgres: walwriter
├─26250 postgres: autovacuum launcher
├─26251 postgres: stats collector
└─26252 postgres: logical replication launcher
Oct 26 18:52:54 ip-10-2-40-60 systemd[1]: Starting PostgreSQL 14 database server...
Oct 26 18:52:54 ip-10-2-40-60 postmaster[26244]: 2021-10-26 18:52:54.691 UTC [26244] LOG: redirecting log output to logging collector>
Oct 26 18:52:54 ip-10-2-40-60 postmaster[26244]: 2021-10-26 18:52:54.691 UTC [26244] HINT: Future log output will appear in directory>
Oct 26 18:52:54 ip-10-2-40-60 systemd[1]: Started PostgreSQL 14 database server.
Active: active (running)
ukazuje, že služba je v provozu.
Dále ověřte, že instalace proběhla úspěšně, připojením k databázovému serveru PostgreSQL a vytištěním jeho verze:
sudo -u postgres psql -c "SELECT version();"
Výstup:
~> sudo -u postgres psql -c "SELECT version();"
version
------------------------------------------------------------------------------------
PostgreSQL 14.0 on x86_64-pc-linux-gnu, compiled by gcc (SUSE Linux) 7.5.0, 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é vpg_hba.conf
jsou splněny.Password
– Role se může připojit zadáním hesla. Hesla lze uložit jakoscram-sha-256
,md5
apassword
(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
- 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)
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)
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ě /var/lib/pgsql/14/data/pg_hba.conf
Změňme identifikaci partnera na důvěryhodnost:
sed -i '/^local/s/peer/trust/' /var/lib/pgsql/14/data/pg_hba.conf
Změňte identifikaci na md5, abyste umožnili přihlášení pomocí hesla.
sed -i '/^host/s/ident/md5/' /var/lib/pgsql/14/data/pg_hba.conf
Přidejte blok, abyste umožnili přístup odkudkoli:
Přidejte tento obsah do souboru /var/lib/pgsql/14/data/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 /var/lib/pgsql/14/data/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)
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:
postgres=# 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 Opensuse Leap 15.3, provést několik základních konfigurací a poté provést základní správu uživatelů.