1、linux切换到pg命令:
$ su - postgres
$ psql
postgres=#
2、查看/退出pg
ps -ef |grep postgres
postgres=# \q
3、一般优化项
参数名 | 作用 | 64GB建议值 | 256GB建议值 |
shared_buffers | 设置PostgreSQL中用于缓存的专用内存量。建议的设置值为机器总内存大小的25%。 | 16GB | 64GB |
wal_buffers | WAL(预写日志)记录缓冲区,由wal_buffers定义的缓冲区的默认大小为16MB,但如果有大量并发连接的话,则设置为一个较高的值可以提供更好的性能。 | 32MB | 64MB |
max_wal_size | WAL(预写日志),增大max_wal_size可以延长checkpoint时间间隔 | 10GB | 10GB |
effective_cache_size | 用于磁盘高速缓存的内存量的估计值。更高的数值会使得索引扫描更可能被使用,更低的数值会使得顺序扫描更可能被使用。 | 32GB | 128GB |
work_mem | 用于复合排序,全局设置此参数可能会导致内存使用率过高,强烈建议在会话级别修改此参数。 | 4MB | 16MB |
maintenance_work_mem | 用于维护任务的内存设置。 | 64MB | 256MB |
checkpoint_completion_target | 在两个checkpoint之间多长时间内完成刷盘动作,数值越小对磁盘IO能力要求越高 | 0.8 | 0.8 |
4、查看现有参数值
postgres=# show effective_cache_size;
动态修改现有参数:
alter system set effective_cache_size='16GB';(单位大写字母,单引号)
动态修改参数后生效:
postgres=# select pg_reload_conf();
以上优化项中shared_buffers需要重启pg,其他的修改完后直接执行一次 select pg_reload_conf(); 即可
5、快速停止,启动,重启pg
#su - postgres -c "/usr/pgsql-9.6/bin/pg_ctl stop -m fast -D /opt/pgsql/9.6/data"
#su - postgres -C "/usr/pgsql-9.6/bin/pg_ctl start -m fast -D /opt/pgsql/9.6/data"
#su - postgres -C "/usr/pgsql-9.6/bin/pg_ctl restart -m fast -D /opt/pgsql/9.6/data"
-D /opt/pgsql/9.6/data表示pg中数据存储所在的路径
6、查看长事务
SELECT * FROM pg_stat_activity
WHERE STATE <> 'idle'
AND pg_backend_pid () != pid
AND ( backend_xid IS NOT NULL OR backend_xmin IS NOT NULL )
AND EXTRACT (epoch FROM ( now() - xact_start )) > 60
ORDER BY xact_start;
杀掉长事务会话:select pg_terminate_backend(pid);