PostgreSQL学习第四篇--数据库cluster启停

本文介绍了如何使用pg_ctl工具启动和关闭PostgreSQL数据库集群,包括三种不同的关闭模式及其与Oracle对应模式的区别,并解决了因端口冲突导致的启动失败问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

启动数据库cluster:
pg_ctl start -D $PGDATA

关闭数据库cluster:
pg_ctl stop -D $PGDATA [-m mode]

mode有三种模式:

	1. smart :等待所有的连接终止后,关闭数据库cluster。如果客户端连接不终止,则无法关闭数据库cluster。看起来是Oracle的normal。
	2. fast:快速关闭数据库cluster,断开客户端的连接,让已有的事务回滚,然后正常关闭数据库cluster,看起来是Oracle的immediate。
	3. immediate:立即关闭数据库cluster,相当于数据库cluster进程立即停止,直接退出,下次启动数据库cluster需要恢复。看起来是Oracle的abort。


[postgres@single ~]$ pg_ctl start -D $PGDATA
server starting
[postgres@single ~]$ LOG:  could not bind IPv6 socket: Address already in use
HINT:  Is another postmaster already running on port 5432? If not, wait a few seconds and retry.
LOG:  could not bind IPv4 socket: Address already in use
HINT:  Is another postmaster already running on port 5432? If not, wait a few seconds and retry.
WARNING:  could not create listen socket for "localhost"
FATAL:  could not create any TCP/IP sockets
LOG:  database system is shut down


发现是因为前面已经启动了-D /usr/pg/postgresql-9.6.1/data/
先停掉:
[postgres@single ~]$ pg_ctl stop -D /usr/pg/postgresql-9.6.1/data/
waiting for server to shut down.... done
server stopped

然后起:
[postgres@single ~]$ pg_ctl start -D $PGDATA
server starting
[postgres@single ~]$ LOG:  database system was shut down at 2016-11-17 08:55:51 CST
LOG:  MultiXact member wraparound protections are now enabled
LOG:  database system is ready to accept connections
LOG:  autovacuum launcher started

可以了。
 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丹心明月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值