维护指南
本章提供的是本应用自身特殊等维护与配置。而配置域名、HTTPS设置、数据迁移、应用集成、Web Server 配置、Docker 配置、修改数据库连接、服务器上安装更多应用、操作系统升级、快照备份等操作通用操作请参考:管理员指南 和 安装后配置 相关章节。
场景
PostgreSQL 备份与恢复
PostgreSQL上的应用备份有多种备份方案,常见包括:
- 使用 pg_dump, pg_dumpall, pgAdmin, phpPgAdmin等工具进行数据库导出(SQL转存)
- 使用 pg_basebackup等工具实现增量备份和基于时 间的恢复
- 数据库文件目录直接复制
其中数据库文件目录直接复制等同于服务器快照备份,无需重复再做。
PostgreSQL 升级
PostgreSQL 提供了大版本升级工具 pg_upgrade。升级总是比较复杂,这里只列出 pg_upgrade 常用参数
pg_upgrade --help
pg_upgrade upgrades a PostgreSQL cluster to a different major version.
Usage:
pg_upgrade [OPTION]...
Options:
-b, --old-bindir=BINDIR old cluster executable directory
-B, --new-bindir=BINDIR new cluster executable directory
-c, --check check clusters only, don't change any data
-d, --old-datadir=DATADIR old cluster data directory
-D, --new-datadir=DATADIR new cluster data directory
-j, --jobs=NUM number of simultaneous processes or threads to use
-k, --link link instead of copying files to new cluster
-o, --old-options=OPTIONS old cluster options to pass to the server
-O, --new-options=OPTIONS new cluster options to pass to the server
-p, --old-port=PORT old cluster port number (default 50432)
-P, --new-port=PORT new cluster port number (default 50432)
-r, --retain retain SQL and log files after success
-U, --username=NAME cluster superuser (default "root")
-v, --verbose enable verbose internal logging
-V, --version display version information, then exit
-?, --help show this help, then exit
Before running pg_upgrade you must:
create a new database cluster (using the new version of initdb)
shutdown the postmaster servicing the old cluster
shutdown the postmaster servicing the new cluster
When you run pg_upgrade, you must provide the following information:
the data directory for the old cluster (-d DATADIR)
the data directory for the new cluster (-D DATADIR)
the "bin" directory for the old version (-b BINDIR)
the "bin" directory for the new version (-B BINDIR)
For example:
pg_upgrade -d oldCluster/data -D newCluster/data -b oldCluster/bin -B newCluster/bin
or
$ export PGDATAOLD=oldCluster/data
$ export PGDATANEW=newCluster/data
$ export PGBINOLD=oldCluster/bin
$ export PGBINNEW=newCluster/bin
$ pg_upgrade
Report bugs to <pgsql-bugs@postgresql.org>.
故障排除
除以下列出的 PostgreSQL 故障问题之外, 通用故障处理 专题章节提供了更多的故障方案。
运行 psql 命令显示 "cannot be run as root Failure, exiting"?
为了安全考量,默认安装已经创建了一个数据库账号 postgres
,如果使用 root
账号登录,请切换用户后再使用 psql
sudo -i -u postgres
常见问题
什么是 PostgreSQL 的 Client 和 Server?
PostgreSQL Server 是指 PostgreSQL 程序本体,而 PostgreSQL Client 指采用TCP协议用于连接程序本地的客户端工具。
它们是两个完全不同的程序,也就是说它们并需要同时安装到同一台服务上。
PostgreSQL 有默认数据库吗?
有,名称为 postgres
PostgreSQL 支持哪些数据类型?
PostgreSQL 支持官方的数据类型,包括:数据、JASON、JSONB 以及几何类型,还可以使用 SQL 命令创建自定义类型
PostgreSQL C/S 架构组成部分?
PostgreSQL 本身是一个 C/S 架构的程序,即包括客户端程序和服务器程序。
- 客户端程序:psql, clusterdb, pgAdmin等
- 服务器程序:initdb, pg_ctl, postgres, postmaster, pg_upgrade等
PostgreSQL 有几种连接方式?
PostgreSQL 允许四种连接方式,主要包括:
- local: 基于 Unix 域套接字的连接方法,域套接字是进程间的一种非网络通信机制,效率高,安全可靠
- host: 基于 TCP/IP 的连接,允许非 SSL 连接,默认值只允许 localhost 本地连接。
- hostssl: 基于 TCP/IP 的 SSL 加密连接
- hostnossl: 基于 TCP/IP 的非 SSL 连接
PostgreSQL 有几种认证方法?
PostgreSQL 常见的认证方法包括:
- reject: 拒绝某一网段的少数特定主机
- md5: 双种MD5加密
- password: 明文密码
- scram-sha-256: 基于SASL的加密认证,是 PostgreSQL 最安全的认证方式,但不支持 10 以下的版本
- trust: 完全信任
- peer:基于 unix socket 免密连接
pgAdmin 支持多语言吗?
支持数十种语言(包含中文)