Difference between revisions of "PostgreSQL"

From wikieduonline
Jump to navigation Jump to search
 
(21 intermediate revisions by 5 users not shown)
Line 21: Line 21:
 
     -v /custom/mount:/var/lib/postgresql/data \
 
     -v /custom/mount:/var/lib/postgresql/data \
 
     postgres
 
     postgres
 +
 +
image: [[arm64v8/postgres]]
 +
 +
 +
* Binaries: [[pg_isready]], [[psql]], [[pg_restore]]
  
 
== PostgreSQL ==
 
== PostgreSQL ==
[[bitnami/postgresql]]
+
* <code>[[bitnami/postgresql]]</code>
[[bitnami/postgresql-ha]]
+
* <code>[[bitnami/postgresql-ha]]</code>
  
 
== Configuration and data files ==
 
== Configuration and data files ==
* <code>/etc/postgresql/10/main/[[postgresql.conf]]</code>
+
* <code>/etc/postgresql/*/main/[[postgresql.conf]]</code>
* <code>/etc/postgresql/10/main/[[pg_hba.conf]]</code> (PostgreSQL Client Authentication Configuration File)
+
* <code>/etc/postgresql/*/main/[[pg_hba.conf]]</code> (PostgreSQL Client Authentication Configuration File)
  
 
  # "local" is for Unix domain socket connections only
 
  # "local" is for Unix domain socket connections only
 
  local  all            all                                    md5
 
  local  all            all                                    md5
  
Data:
+
* Data: <code>[[/var/lib/postgresql/]]</code>
* <code>[[/var/lib/postgresql/]]</code>
 
  
 
== [[PostgreSQL logs]] ==
 
== [[PostgreSQL logs]] ==
*<code>[[/var/log/]]postgresql</code>
+
*<code>[[/var/log/postgresql/]]</code>
  
 
== Basic Commands==
 
== Basic Commands==
Line 55: Line 59:
 
* Show version: <code>[[SELECT version();]]</code>
 
* Show version: <code>[[SELECT version();]]</code>
  
* Create backup: use <code>pg_dump</code> <ref>https://www.postgresql.org/docs/current/static/app-pgdump.html</ref> and <code>~/.pgpass</code> file for automating login.
+
* Create backup: use <code>pg_dump</code> <ref>https://www.postgresql.org/docs/current/static/app-pgdump.html</ref> and <code>[[~/.pgpass]]</code> file for automating login.
 
* Create user:  
 
* Create user:  
 
** <code>[[create user]] <username></code>
 
** <code>[[create user]] <username></code>
Line 77: Line 81:
 
* [[Adminer]]
 
* [[Adminer]]
 
* [[Amazon Redshift]]
 
* [[Amazon Redshift]]
* [[PostgreSQL statistics collector]]: <code>[[pg_stat]]*</code>
+
* [[PostgreSQL monitoring]]
* <code>[[prometheus-postgres-exporter]]</code>
+
** [[PostgreSQL statistics collector]]: <code>[[pg_stat]]*</code>
 +
** <code>[[prometheus-postgres-exporter]]</code>
 
* [[Multi-Version Concurrency Control (MVCC)]]
 
* [[Multi-Version Concurrency Control (MVCC)]]
* [[Master]] user, [[Index (PostgreSQL)]]
+
* [[Index (PostgreSQL)]]
 
* [[Greenplum]]
 
* [[Greenplum]]
 
* [[PostgreSQL replication]]
 
* [[PostgreSQL replication]]
 +
* [[PGO PostgreSQL Operator]]
 
* [[Amazon Aurora PostgreSQL Serverless]]
 
* [[Amazon Aurora PostgreSQL Serverless]]
 
* [[PgBouncer]] connection pooler
 
* [[PgBouncer]] connection pooler
 
* [[Amazon RDS for PostgreSQL]]
 
* [[Amazon RDS for PostgreSQL]]
* [[PGO PostgreSQL Operator]]
+
* [[Master]] user for RDS: <code>[[postgres]]</code>
 +
* Ansible: <code>[[community.postgresql.postgresql_query]]</code>
 +
* [[psycopg2]]
 +
* [[PostgreSQL logging]]
 +
* <code>[[yum install postgresql]]</code>
 +
* <code>[[arm64v8/postgres]]</code>
 +
* [[Azure Cosmos DB for PostgreSQL]]
 +
* [[Azure Database for PostgreSQL]]
  
 
== Activities ==
 
== Activities ==
 
* [[PostgreSQL parameter tunning]]
 
* [[PostgreSQL parameter tunning]]
 
* Read PostgreSQL - How to grant access to users? https://tableplus.com/blog/2018/04/postgresql-how-to-grant-access-to-users.html
 
* Read PostgreSQL - How to grant access to users? https://tableplus.com/blog/2018/04/postgresql-how-to-grant-access-to-users.html
 +
* [[Operations]]
 +
* Find which user you are using for connecting: <code>[[\conninfo]]</code>
  
 
== See also ==
 
== See also ==
 
* [[Patroni]] [[HA]] solution for PostgreSQL that requires <code>[[etcd]]</code>, <code>[[Zookeeper]]</code>, or <code>[[Consul]]</code>
 
* [[Patroni]] [[HA]] solution for PostgreSQL that requires <code>[[etcd]]</code>, <code>[[Zookeeper]]</code>, or <code>[[Consul]]</code>
 +
* {{PostgreSQL extensions}}
 
* {{PostgreSQL}}
 
* {{PostgreSQL}}
* {{DBs}}
 
  
 
[[Category:PostgreSQL]]
 
[[Category:PostgreSQL]]

Latest revision as of 10:46, 23 September 2024

wikipedia:PostgreSQL, often simply Postgres, is an object-relational database management system (ORDBMS). PostgreSQL is ACID-compliant and Transactional. PostgreSQL has updatable Views and Materialized view, Triggers, Foreign key; supports functions and stored procedures, and other expandability. PostgreSQL listens by default in TCP port 5432.

Installing PostgreSQL[edit]

MacOS[edit]

Linux, BSD variants[edit]

The easiest way to install PostgreSQL in these operating systems is to use their respective built-in package managers - for instance, the pkg command in DragonFlyBSD or apt in Debian and its derivatives. Be advised that there will be different variants of PostgreSQL available for install at a given point, specially regarding version numbers and client/server side. You should decide beforehand which version suits your needs for a particular application. Furthermore, you need to make sure that you have sufficient privileges in the system to install software (properly configured sudo/doas access, for example) or your install will fail.

Docker[edit]

docker run -p 5432:5432 --name MY_POSTGRES_DB -e POSTGRES_PASSWORD=mysecretpassword -d postgres[1]
* Docker-compose.xml PostgreSQL
docker run -p 5432:5432 -d \
   --name some-postgres \
   -e POSTGRES_PASSWORD=mysecretpassword \
   -e PGDATA=/var/lib/postgresql/data/pgdata \
   -v /custom/mount:/var/lib/postgresql/data \
   postgres
image: arm64v8/postgres


PostgreSQL[edit]

Configuration and data files[edit]

# "local" is for Unix domain socket connections only
local   all             all                                     md5

PostgreSQL logs[edit]

Basic Commands[edit]

Binaries: psql, pg_dump.

  • Connect to a PostgreSQL database: psql -h localhost -U postgres -d somedb[2]
  • Connect to a PostgreSQL database with a timeout of 5 seconds: env PGCONNECT_TIMEOUT=5 psql -h localhost -U postgres -d somedb[3]
  • Show databases:
    • \list
    • SELECT datname FROM pg_database WHERE datistemplate = false;
  • Show tables: \dt or SELECT * FROM pg_catalog.pg_tables;[4]
  • Show users: \du
  • Drop DB: dropdb DB_NAME
  • Create backup: use pg_dump [6] and ~/.pgpass file for automating login.
  • Create user:
    • create user <username>
    • ALTER USER user_name WITH PASSWORD 'new_password';
  • create database
  • Modify user privileges:
    • Privileges to create DB: ALTER USER user1 CREATEDB;



Processs[edit]

  • wal writer process

Related terms[edit]

Activities[edit]

See also[edit]

Text is available under the Creative Commons Attribution-ShareAlike License; additional terms may apply. By using this site, you agree to the Terms of Use and Privacy Policy.

Source: wikiversity

Advertising: