postgresql 常规操作以及检查备份
一、建表时,复制源表的信息
test=#
test=# \d test.t1
Table "test.t1"
Column | Type | Collation | Nullable | Default
--------+---------+-----------+----------+---------
col1 | integer | | |
col2 | integer | | |
col3 | integer | | |
Indexes:
"test_t1_unq" UNIQUE CONSTRAINT, btree (col1)
test=# create table test.t2 (like test.t1 including all);
CREATE TABLE
test=# \d test.t2;
Table "test.t2"
Column | Type | Collation | Nullable | Default
--------+---------+-----------+----------+---------
col1 | integer | | |
col2 | integer | | |
col3 | integer | | |
Indexes:
"t2_col1_key" UNIQUE CONSTRAINT, btree (col1)
其中,including选项包括以下:
including defaults
including constraints
including indexes
including storages
including commits
including all
其中including all 是吧所有属性复制过去。
二、pgsql修改字段跟oracle以及MySQL不一样;
test=# \d blog
Table "pgsql.blog"
Column | Type | Collation | Nullable | Default
---------+---------+-----------+----------+---------
id | integer | | |
title | text | | |
content | text | | |
alter table blog alter column id set not null;
test=# alter table blog rename column id to blog_id;
ALTER TABLE
test=# \d blog
Table "pgsql.blog"
Column | Type | Collation | Nullable | Default
---------+---------+-----------+----------+---------
blog_id | integer | | not null |
title | text | | |
content | text | | |
三、表继承及分区表
test=# insert into persons values ('haha',30,'f');
INSERT 0 1
create table students ( class_no int) inherits (persons);
test=# insert into students values ('bb',20,'f',2);
INSERT 0 1
test=# select * from persons;
name | age | sex
------+-----+-----
haha | 30 | f
bb | 20 | f
(2 rows)
test=#
test=#
test=#
test=# select * from only persons;
name | age | sex
------+-----+-----
haha | 30 | f
(1 row)
test=#
test=#
test=# select * from students;
name | age | sex | class_no
------+-----+-----+----------
bb | 20 | f | 2
(1 row)
四、查看PGSQL的锁。
select * from pg_locks;
查看当前会话的PID;
select pg_backend_pid();
查看当前会话:
select * from pg_stat_activity;
select pid,usename,client_addr,client_hostname,client_port from pg_stat_activity;
五、参数修改
5.1 重新读取配置文件
pg_ctl reload
5.2 查看当前实例状态
pg_ctl status
5.3 杀进程
查看当前的进程:也可以通过查看锁
select pg_backend_pid();
pg_backend_pid
----------------
1564
杀进程:
pg_ctl kill INT 1564
5.3 需要执行清理过程:
postgres --single -D /pgsql11data/ postgres --数据库启动到单用户下
backend> vacuum full ;
5.4配置参数
所有的配置项都是大小写不敏感的。
六、备份
PG提供物理备份和逻辑备份
物理备份:WAL热备份
逻辑备份:pg_dump,pg_dumpall,恢复时pg_restore
1、备份test 数据库
pg_dump test >testdb.sql 跟MySQL一样,生成的是sql文件
比如我把test数据库恢复成testbak数据库
create database testbak encoding UTF8;
[pgsql@node2 ~]$ psql testbak < /home/pgsql/test.sql
SET
SET
SET
SET
SET
set_config
------------
(1 row)
跟mysql 很类似。
也可以指定格式的备份成*.dmp文件
[pgsql@node2 ~]$ pg_dump -Fc -Upgsql test > testpgsql.dmp
恢复
create database test encoding UTF8;
[pgsql@node2 ~]$ pg_restore -d test testpgsql.dmp
2.想备份psql模式下所有表,但是不包括test2
test=# \d+
List of relations
Schema | Name | Type | Owner | Size | Description
--------+--------------+----------+-------+------------+-------------
pgsql | blog | table | pgsql | 8192 bytes |
pgsql | persons | table | pgsql | 8192 bytes |
pgsql | students | table | pgsql | 8192 bytes |
pgsql | test_view | view | pgsql | 0 bytes |
pgsql | testtab01 | table | pgsql | 211 MB |
public | capitals | table | pgsql | 8192 bytes |
public | cities | table | pgsql | 8192 bytes |
public | duty | table | pgsql | 16 kB |
public | example | table | pgsql | 0 bytes |
public | non_capitals | table | pgsql | 8192 bytes |
public | products | table | pgsql | 8192 bytes |
public | t | table | pgsql | 0 bytes |
public | t1 | table | pgsql | 16 kB |
public | t2 | table | pgsql | 16 kB |
public | t_id_seq | sequence | pgsql | 8192 bytes |
public | test1 | table | pgsql | 20 MB |
public | test2 | table | pgsql | 8192 bytes |
public | weather | table | pgsql | 8192 bytes |
(18 rows)
[pgsql@node2 ~]$ pg_dump -t 'pgsql.t*' -T psql.t2 test > pgsqltest.sql
备份所有数据库test 对象,不包括duty
[pgsql@node2 ~]$ pg_dump -T 'pgsql.duty' test > noduty.sql
在192.168.211.152 上备份,恢复到 192.168.211.154:
test=# create database hl;
CREATE DATABASE
[pgsql@node2 ~]$ pg_dump -h 192.168.211.152 -Upgsql test -Fc > remote_test.dmp
[pgsql@node2 ~]$ ls -lh
total 445M
-rw------- 1 pgsql pgsql 854 Apr 13 23:52 logfile
-rw-rw-r-- 1 pgsql pgsql 80M Jun 12 23:16 noduty.sql
-rw-rw-r-- 1 pgsql pgsql 75M Jun 12 23:14 pgsqltest.sql
-rw-rw-r-- 1 pgsql pgsql 106M Jun 12 23:26 remote_test.dmp
-rw-rw-r-- 1 pgsql pgsql 106M Jun 12 23:06 testpgsql.dmp
-rw-rw-r-- 1 pgsql pgsql 80M Jun 12 22:54 test.sql
testbak=# create database test;
CREATE DATABASE
[pgsql@node2 ~]$ pg_restore -h 192.168.211.152 -Upgsql -C -d test remote_test.dmp
-c, --clean clean (drop) database objects before recreating
-C, --create create the target database
最后,要讲备份的 remote_test.dmp的数据重新加载到一个不是新建的不同名称的数据库 remote中,可以使用下面命令:
createdb -T template0 remote;
pg_restore -d remote remote_test.dmp
从template0而不是template1 创建数据库,确保干净,没有使用-C,而是直接恢复到remote数据库上。
七、PGSQL 常规操作
select version(); --查看版本
select pg_postmaster_start_time(); --查看数据库启动时间
select pg_conf_load_time(); --查看配置文件的时间
show timezone; --查看数据库时区
select user;
select current_user;
select session_user;
select current_catalog,current_database();
select inet_client_addr(),inet_client_port(); --查看session客户端登录IP,端口
inet_client_addr | inet_client_port
------------------+------------------
192.168.211.152 | 36891
select inet_server_addr(),inet_server_port(); --查看数据库服务器登录IP,端口
inet_server_addr | inet_server_port
------------------+------------------
192.168.211.152 | 5432
select pg_backend_pid(); 查看当前session的后台服务器进程的PID
show shared_buffers; --查看共享buffer
select current_setting('shared_buffers'); --查看当前shared_buffers
select pg_xlogfile_name(pg_current_xlog_location()); --查看当前正在写的WAL文件
select pg_is_in_backup(),pg_backup_start_time(); --查看实例是否正在做基础备份
select pg_is_in_recovery(); --查看实例时hot standby 状态还是正常数据库状态
select pg_database_size('test'),pg_size_pretty(pg_database_size('test')); --查看test数据库大小(显示会慢)
select pg_size_pretty(pg_relation_size('test1')); --查看连接数据库test1表的大小(不包括索引)
select pg_size_pretty(pg_total_relation_size('test1')); --查看连接数据库test1表的大小(包括索引)
select pg_size_pretty(pg_indexes_size('test1')); --查看表test1上索引的大小
select pg_size_pretty(pg_tablespace_size('test')); 查看test表空间的使用大小
select pg_relation_filepath('test1'); --查看test1表空间对应的数据文件
八、系统维护常用命令
修改配置文件postgresql.conf后,生效的两种方式:
1.pg_ctl reload
2.select pg_reload_conf();
能生效的不需要重启服务器。
切换日志文件
select pg_rotate_logfile();
切换WAL日志文件
select pg_switch_xlog(); --貌似有问题 或者checkpoint;
3.取消正在执行的长时间的SQL方法
pg_cancel_backend(pid):取消正在执行的SQL
pg_terminate_backend(pid):终止一个后台服务进程,同时释放此后台服务进程的资源。
select pid ,datname,usename,query_start,query from pg_stat_activity; --查看运行的SQL
select pg_cancel_backend(pid); 如果取消不了,用这一句取消:select pg_terminate_backend(28184);
postgresql 常规操作以及检查备份的更多相关文章
- Oracle user,role,profile常规操作--用户,权限,角色,配置文件
Oracle user,role,profile常规操作--用户,权限,角色,配置文件 1 权限查询 1查看所有用户 SQL> select username,account_status,lo ...
- postgres 常规操作杂记
分布式:1.扩容不方便(数据重分布)2.分布键变更很麻烦3.分布键选择(架构设计)谨慎4.跨库join性能差5.分布式事务性能差6.sql限制多,功能确实多7.应用改造成本巨大8.全局一致性时间点恢复 ...
- db2操作 连接、备份、恢复db2
先deactivate后再start standby再primary报错不能启动hadr standby的时候,先restore,但是别rollback,直接start hadr as standby ...
- FTP服务器常规操作
导读 FTP协议是Internet文件传输的基础,它是由一系列规格说明文档组成,目标是提高文件的共享性,提供非直接使用远程计算机,使存储介质对用户透明和可靠高效地传送数据.下面就由我给大家简单介绍一下 ...
- Apache服务器常规操作
导读 Apache是世界上排名第一的Web服务器,50%以上的Web服务器都在使用Apache,它几乎可以在所有计算机平台上运行.下面就由我给大家说说Apache服务器的一些常规操作. Apache服 ...
- mysql服务器的常规操作
mysql服务器的常规操作 导读 MySQL是一个小型关系数据库管理系统,目前被广泛的应用在Internet上的中小型网站中,体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,使得许多中小型网站 ...
- Mongodb常规操作【一】
Mongodb是一种比较常见的NOSQL数据库,数据库排名第四,今天介绍一下Net Core 下,常规操作. 首先下C# 版的驱动程序 "MongoDB.Driver",相关依赖包 ...
- Learn Docker(一)—软件安装与常规操作
一.安装Docker Windows平台 在Windows10 X64专业版上可以直接下载Docker原生应用进行安装,在控制面板的程序与功能里启用Hyper-v,之后就可以运行docker程序啦. ...
- GIT 的常规操作
GIT 的常规操作 常规操作也是我自己平时常用的几个命令, 学自于 pro git 这本书中 git 配置文件 git的配置文件位置 针对所有用户:/etc/gitconfig 针对当前用户: -/. ...
随机推荐
- 【Linux】Vi中的各种命令
Ctrl+u:向文件首翻半屏: Ctrl+d:向文件尾翻半屏: Ctrl+f:向文件尾翻一屏: Ctrl+b:向文件首翻一屏: Esc:从编辑模式切换到命令模式: ZZ:命令模式下保存当前文件所做的修 ...
- Verification之PSL之intro
1 PSL - Property specification language 1.1 Property - Characteristics of the designs/verification e ...
- 读书笔记「Python编程:从入门到实践」_6.字典
6.1 一个简单的字典 alien_0 = {'color': 'green', 'points': 5} print(alien_0['color']) print(alien_0['points' ...
- JSP_内置对象_请求转发和请求重定向的区别
请求重定向:客户端行为,response.sendRedirect(),从本质上将等同与两次请求,前一次请求request对象不会保存,地址栏的URL地址会改变. 请求转发:服务器行为,request ...
- 浅谈Web缓存-缓存的实现过程详解
在前端开发中,性能一直都是被大家所重视的一点,然而判断一个网站的性能最直观的就是看网页打开的速度.其中提高网页反应速度的一个方式就是使用缓存.一个优秀的缓存策略可以缩短网页请求资源的距离,减少延迟,并 ...
- java 循环document 通用替换某个字符串或特殊字符
document 生成xml时 报错 XML-20100: (Fatal Error) Expected ';'. 查了半天发现是 特殊字符 & 不能直接转出,需要进行转换,因为是通用方法很 ...
- TextInputLayout使用时各个地方的字体颜色
我们现在在做Android端的输入框时,要具备如下功能: 默认提示获取焦点时提示上移至输入框顶部获取焦点时输入框有提示错误时增加错误提示直接上图: 默认情况: 获取焦点时: 开始输入文字时: 有错误时 ...
- eoLinker GoKu Gateway 开源版 V2.1发布,加入UI管理系统等
GoKu API Gateway 是eoLinker旗下的开源版接口网关,支持OpenAPI与微服务管理,支持私有云部署,实现API转发.请求参数转换.数据校验等功能,提供图形化界面管理,能够快速管理 ...
- 使用Linux自带的命令logrotate对Nginx日志进行切割
说明: Nginx安装目录:/usr/local/nginx/Nginx日志目录:/var/log/nginx/error/*.log /var/log/nginx/access/w1/*.log / ...
- POJ 2954
PICK定理:格子上的多边形面积=边界上格子点数/2+内部点数-1. 利用叉积求出面积.再枚举边上的点数.然后按公式求出内部点数就可以了. 关于PICK:http://blog.csdn.net/i_ ...