Postgresql 数据库控制解析(一)

Stella981
• 阅读 955

前面我们通过“探索postgresql数据库(一)”和“探索postgresql数据库(二)”基本了解了postgresql数据库。接下来本文开始介绍下数据库控制(server control)。。

一、手动开启数据库(Starting the database server manually)
默认postgresql会随着系统自动启动,不过有时候设置改动可能需要手动停止或者启动数据库。
首先需要区别server和service两个概念。server指的是database server和他的一些进程,service指的是操作系统中被server包装起来的服务。server本质上可以在不同平台上以相同的方式工作,但是service就会因为各个操作系统不同而不同。
在所有操作系统平台,都有命令来启动postgresql server,如:

UBUNTU/DEBIAN pg_ctlcluster 9.0 main reload
RED HAT/FEDORA pg_ctl -D /var/lib/pgsql/data start
SOLARIS pg_ctl -D /var/lib/pgsql/data start
MAC OS pg_ctl -D /var/lib/pgsql/data start
FREEBSD pg_ctl -D /var/lib/pgsql/data start

在有些平台,也可以用这些命令启动。

RED HAT/FEDORA service postgresql start
WINDOWS net start postgres

二、安全快速停止数据库(Stopping the server safely and quickly)
可以用以下命令快速停止数据库:

pg_ctl -D datadir -m fast stop
如果想快速停止,就一定要加-m fast这个参数,因为默认postgresql是需要等所有用户结束才会关闭的。使用fast快速停止命令,所有用户在进行的操作都会终止。在关闭数据库时,postgresql和其他如Oracle, DB2, 或者SQLServer关系型数据库的区别是postgresql的事务回滚非常快,而其他数据库关闭可能需要很长时间。

三、紧急停止数据库(Stopping the server in an emergency)

pg_ctl -D datadir stop -m immediate
使用immediate模式和fast模式一样,都会强制中止所有用户的事务,关闭连接。不过immediate模式相当于数据库经历了崩溃,比如断电。下次重启时缓存的文件需要重建,数据库自己也需要对崩溃进行恢复。
需要dba注意的是,Oracle中的immediate模式相当于强制关闭数据库,postgresql和oracle这个是不一样的。

四、重新加载数据库配置文件(Reloading the server configuration files)
postgresql配置文件中的一些参数需要重新加载才会生效。以下是各个操作系统平台重新加载的命令:

UBUNTU/DEBIAN pg_ctlcluster 9.0 main reload
RED HAT/FEDORA service postgresql reload 或pg_ctl -D /var/lib/pgsql/data reload
SOLARIS pg_ctl -D /var/lib/pgsql/data reload
MAC OS pg_ctl -D /var/lib/pgsql/data reload
FREEBSD pg_ctl -D /var/lib/pgsql/data reload

我们也可以在连接postgresql的时候重新加载配置文件,不过前提是你登陆的是超级用户:

postgres=# select pg_reload_conf();
pg_reload_conf
----------------
t
在pg_settings这个系统表中有一个context字段,如果字段值是”sighup”,那么就必须要reload。以下列出在数据库配置中可能需要改变的参数:

forummon=# select name,setting,unit,(source='default') as is_default from pg_settings
where context ='sighup' and (name like '%delay' or name like '%timeout') and setting !='0' ;
name | setting | unit | is_default
------------------------------+---------+------+------------
authentication_timeout | 60 | s | t
autovacuum_vacuum_cost_delay | 20 | ms | t
bgwriter_delay | 200 | ms | t
checkpoint_timeout | 300 | s | t
max_standby_archive_delay | 30000 | ms | t
max_standby_streaming_delay | 30000 | ms | t
wal_receiver_timeout | 60000 | ms | t
wal_sender_timeout | 60000 | ms | t
wal_writer_delay | 200 | ms | t
(9 rows)
五、快速重启数据库(Restarting the server quickly)
有些数据库配置的修改必须要求重启数据库,如何快速重启就显得特别重要。当然重启最好是在数据库压力很小的时候。
基础快速重启命令:

pg_ctl -D datadir restart -m fast
重启表面上看是先停止,在启动,很简单的一个步骤。在大多数情况下,这个确实很简单。

六、防止新链接(Preventing new connections)
在某些紧急情况下,dba们可能需要完全锁定数据库,或者静止特定的人连接。
一下是防止新链接的几个方法:
1、暂停或者恢复会话池;后面介绍
2、关闭数据库,不推荐这样做;
3、设置特定数据库的连接数为0;
ALTER DATABASE foo_db CONNECTION LIMIT 0;
这个可以限制除了超级用户外的其他用户。
4、设置特定用户的连接数为0
ALTER USER foo CONNECTION LIMIT 0;
这个可以限制除了超级用户外的其他用户。
5、修改host-based authentication (HBA)文件,重新加载数据库
先备份下pg_hba.conf文件,修改pg_hba.conf文件。
###如下两行将会禁止所有用户连接数据库,包括超级用户:

# TYPE DATABASE USER CIDR-ADDRESS METHOD
local all all reject
host all all 0.0.0.0/0 reject
###如果需要让postgres这个超级用户连接,可以修改成如下设置:
# TYPE DATABASE USER CIDR-ADDRESS METHOD
local all postgres ident
local all all reject
host all all 0.0.0.0/0 reject
d.重新加载数据库

七、限制每个连接用户只能打开一个session(Restricting users to just one session each)
如果需要控制服务器资源,你可能会希望一个用户只能同时打开一个session连接。当然这个也可以用来限制用户,这个上面已经有介绍。以下是基本命令:

postgres=# ALTER ROLE fred CONNECTION LIMIT 1;
需要取消限制可以把值设为-1。
查询用户链接限制

SELECT rolconnlimit FROM pg_roles WHERE rolname = 'postgres';
查看用户当前连接数

SELECT count(*) FROM pg_stat_activity WHERE usename = 'postgres';

原文链接: http://www.sijitao.net/1454.html

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
九路 九路
2年前
PostgreSQL 数组类型使用详解
PostgreSQL数组类型使用详解可能大家对PostgreSQL这个关系型数据库不太熟悉,因为大部分人最熟悉的,公司用的最多的是MySQL我们先对PostgreSQL数据库(下面简称PG)简单的介绍一下,以后有机会,再
待兔 待兔
4年前
postgresql和mysql哪个好
postgresql和mysql都是免费且功能强大的开源数据库,很多用户面对这两个库都会有一个问题,那就是哪一个才是最好的开源数据库,MySQL还是PostgreSQL呢?该选择哪一个开源数据库呢?postgresql和mysql哪个好一.PostgreSQL相对于MySQL的优势1、在SQL的标准实现上要比MySQL完善,而且功能实现比较严谨;
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Java修道之路,问鼎巅峰,我辈代码修仙法力齐天
<center<fontcolor00FF7Fsize5face"黑体"代码尽头谁为峰,一见秃头道成空。</font<center<fontcolor00FF00size5face"黑体"编程修真路破折,一步一劫渡飞升。</font众所周知,编程修真有八大境界:1.Javase练气筑基2.数据库结丹3.web前端元婴4.Jav
待兔 待兔
4年前
PostgreSQL介绍以及如何开发框架中使用PostgreSQL数据库
最近准备下PostgreSQL数据库开发的相关知识,本文把总结的PPT内容通过博客记录分享,本随笔的主要内容是介绍PostgreSQL数据库的基础信息,以及如何在我们的开发框架中使用PostgreSQL数据库,希望大家多多提意见。1、PostgreSQL数据库介绍PostgreSQL是以加州大学伯克利分校计算机系开发的POSTGRES,现在已经更
Stella981 Stella981
3年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Stella981 Stella981
3年前
PostgreSQL 数据库备份与恢复 pd_dump pg_restore
备份PG数据库生成的文件可以有两种,一种是SQL文件,一种是二进制文件,二进制文件只能使用pg\_restore进行恢复。PostgreSQL数据库操作简要说明PostgreSQL数据库版本psqlversionpsql(PostgreSQL)9.1.3下面是在linux下的操作,在windows下面将sup
3A网络 3A网络
2年前
PostgreSQL 数组类型使用详解
PostgreSQL数组类型使用详解PostgreSQL数组类型使用详解可能大家对PostgreSQL这个关系型数据库不太熟悉,因为大部分人最熟悉的,公司用的最多的是MySQL我们先对PostgreSQL数据库(下