【数据库学习】pg安装与运维

news/2024/7/9 20:44:57 标签: 数据库, postgresql

1,安装与配置

#安装
yum install https:....rpm

1)安装目录

bin目录:二进制可执行文件目录,此目录下有postgres、psql等可执行程序;pg_ctl工具在此目录,可以通过pg_ctl --help查看具体使用。
conf目录:
empty
include:头文件目录
lib:动态库目录,如libpq.so
share:存放文档和配置模板文件,一些扩展包的sql文件在子目录extension下。

2)数据目录

/var/lib/pgsql/<verson>/data。

在这里插入图片描述

i>pg_hba.conf(认证配置文件)

用于配置数据库的远程连接,通过加入以下命令行,运行任何用户远程连接本数据库,连接时需要提供密码。

host    replication     all             127.0.0.1/32            md5
host    replication     all             10.99.99.99            md5  # ip为10.99.99.99机器可访问
host    all             all          0.0.0.0/0       md5     # navicat可访问。md5表示要求客户端提供一个 MD5 加密的口令进行认证。如果改为trust表示无条件地允许联接。
postgresqlconf_32">ii>postgresql.conf(主配置文件)

所有配置信息在系统视图pg_settings中可查看,通过context可知修改相关配置后是否需要重启。

  1. internal 只读参数,初始化实例时写死的。
  2. postmaster 改变后需要重启。
  3. sighup/backend 不需要重启,需要向postmaster主进程发送SIGHUP信号,让其重启装配配置新的参数。运行pg_ctl reload命令重新装配。
  4. superuser 超级用户使用set命令改变。
  5. user 普通用户使用set命令改变。
## 连接配置项
listen_addresses = '*'          # 默认为localhost,这会导致远程主机无法登录数据库。写具体网络ip表示让特定机器登录,*表示所有地址都可监听。
port = 5432                             # pg默认端口为5432。多个pg实例可以设置不同端口。
max_connections         #允许数据库连接的最大并发连接数,默认100,修改后需要重启。通过sql:show max_connections;也可以查看
superuser_reserved_connections  #超级用户连接数。默认为3,为防止普通用户消费连接数过多导致超级用户无法连接pg。

## 日志配置项
logging_collector = on    #开启日志收集。pgSQL10已经默认开启
log_directory = 'log'     #日志目录。日志切换与覆盖有多种方案,可配。一是每天生成一个新的日志文件;二是日志写满到一定大小开启新文件;三是只保留最近7天日志,循环覆盖(pgSQL10默认模式)。

## 内存配置项
shared_buffers = 4096MB                 # min 128kB  共享内存大小,主要用于共享数据块。默认值为32MB,尽量设置大一些。具体说明见后文讲解。
work_mem = 4MB                         # min 64kB 单个SQL执行、排序、Hash Join时使用的内存,执行完毕后释放。设置大一些会提高排序操作效率。具体说明见后文讲解。
max_stack_depth    #服务器执行堆栈的最大安全深度,默认为2M。如果发现不能运行复杂的函数时,可以调高此配置,但一个正在运行的递归函数可能会导致pg后台服务进程崩溃,慎重设置。
iii>其它文件
文件/目录作用备注
PG_VERSIONpg版本号
postmaster.opts记录服务器上次启动的命令行参数
base默认表空间的目录下面子目录以对应数据库的OID命名,对应OID子目录下存放着这个数据库的表、索引等数据文件。OID通过select oid,datname from pg_database;查询。
global一些共享系统表的目录
log程序日志目录pg10版本之前未pg_log目录
pg_commit_ts视图提交的时间戳数据pg9.5之后
pg_walWAL日志的目录,在pg10之前此目录是pg_clog

oid(objectID,行对象标识符)
该系统字段只有在创建表时使用了with oids或配置参数default_with_oids的值为真时出现。字段类型也是oid,是4字节无符号整数,不能提供大数据范围内的唯一性保证,因此pg官方不推荐在用户表中使用oid字段。

2,psql命令行操作

# 数据库连接: psql命令在postgresql/bin目录下。
# 添加参数-E可以在执行psql快捷命令时同时输出对应sql。也可以通过命令\set ECHO_HIDDEN on|off控制
psql "host=127.0.0.1 port=5432 user=postgres password=123456 dbname=postgres"
psql -U postgres -d DB_NAME -h localhost -c 'select * from user_info'
# 数据导出-pg_dump命令
pg_dump "host=XX.XX.XX.XX port=5432 user=XXXX password=XXXX dbname=XXXXX" -t table_name -f table_name.sql
# 数据导出-psql命令
psql "host=XX.XX.XX.XX port=5432  user=XXX password=XXX dbname=XXX" -f table_name.sql

常见psql快捷命令(通过psql连接数据库后,通过“\”开头的快捷命令进行数据库相关操作,tab键可补全命令):

说明命令备注
退出命令行模式\q
查看数据库\l小写L
切换数据库\c dbName
查询当前登录的数据库和用户\cYou are now connected to database “postgres” as user “postgres”
查看sql语法(help)\h create user
查看更多命令?
查看所有表\d
查看结构\d namename可以包含通配符*或?,可以是表名、索引、视图、序列、函数。如果使用\d+会显示的更详细
列出所有schema\dn
查看所有表空间\db
查看所有角色和用户\du或\dgpg中用户和角色是不区分的
查看表权限分配情况\dp或\z
查看执行时间\timing on sql语句
指定客户端字符编码\encoding gbkutf8
执行外部文件的sql命令\i fileNamepsql -x -f fileName
编辑器\e类似vi,退出vi后会执行其中输入的内容
查看或编辑函数\ef 函数名不加函数名显示函数模板。退出vi后可\reset来清除命令缓冲区数据,防止误操作。
查看或编辑视图\ev 视图名不加函数名显示视图模板。退出vi后可\reset来清除命令缓冲区数据,防止误操作。

3,系统命令

1)查看版本信息

说明命令
查看客户端版本psql --version
查看服务器版本详细信息select version();
查看服务器版本信息show server_version;
查看服务器数字版本信息包括小版号SHOW server_version_num;

2)时间相关命令

说明命令备注
查看数据库启动时间select pg_postmaster_start_time()
查看最后load配置文件的时间select pg_conf_load_time()pg_ctl reload后改变这个时间
显示当前数据库时区show timezone时区不一样的情况下,数据库时间和操作系统时间不一致。;PRC: People’s Republic of China
查看当前时间select now()
设置时区set time zone ‘GMT’PRC为北京时区
查看所有时区的名字SELECT * FROM pg_timezone_names

3)其它常用命令

说明命令备注
当前连接数据库select current_catalog, current_database();两者结果一样
查看pg是否正在做基础备份select pg_is_in_backup(),pg_backup_start_time();
查看数据库大小select pg_database_size('ngsoc'), pg_size_pretty(pg_database_size('ngsoc'));pg_size_pretty会转换成MB\GB等格式展示

4,服务启停及原理

1)服务启动

  1. 直接运行postgres进程
/lwh/postgresql/bin/postgres -D /lwh/data/postgresql &   #-D指定数据目录,&表示后台执行。postgres也可以换成postmaster,一回事。如果权限不够在命令前面添加:su postgres -c 
  1. 使用pg_ctl命令启动
/lwh/postgresql/bin/pg_ctl start -D /lwh/data/postgresql  #-D指定数据目录

2)服务停止

  1. 直接向运行的postgres主进程发送signal信号
signal信号关机模式描述
SIGTERMSmart Shutdown 智能关机服务器将不允许新连接,等所有连接断开才关闭数据库
SIGINTFast Shutdown 快速关机不再允许新连接,并向所有子进程发送 SIGINT 信号,让它们立刻退出,然后等待子进程退出后关闭数据库
SIGQUITImmediate Shutdown 立即关闭立即关闭并退出,下次启动时数据库重放WAL日志进行恢复。仅用于紧急情况的关闭。
  1. 使用pg_ctl命令停止数据库
#没有权限需要在最前面添加su postgres -c
pg_ctl stop -D dataDir -m smart  #对应Smart Shutdown 模式;fast对应 Fast Shutdown;immediate 对应 Immediate Shutdown.具体说明可通过--help查看。默认模式是哪个?谁知道啊???

3)服务检测是否启动

ps aux | grep /lwh/data/postgresql | grep -v grep | wc -l    #返回值不为0表示服务存在
ps aux | grep /lwh/data/postgresql | grep -v grep | awk '{print $2}' #返回具体的pid表示服务存在
或者:
netstat -ntlp | grep 5432  #5432为pg默认端口

5,备份与还原

分为逻辑备份和物理备份。

1)pg_dump/pg_dumpall命令

pg_dumpall是将一个pg集群全部转存到另一个脚本文件(sql脚本、归档文件)中,而pg_dump命令可以选择一个数据库或部份表进行备份。pg_dump结合pg_restore使用,能灵活备份和恢复。

2)冷备份

最简单的物理备份就是冷备份,即:停止pg,然后拷贝pg的data目录。

3)热备份

即不停止数据库进行备份,常见的方法有:PITR方法、使用文件系统或块设备级别的快照功能完成备份。Linux下最简单的备份方式是使用LVM的快照功能。


http://www.niftyadmin.cn/n/5347777.html

相关文章

Vue 插槽 (Slots) 源码解析与用法

聚沙成塔每天进步一点点 本文内容 ⭐ 专栏简介1. 默认插槽的实现原理用法示例&#xff1a; 2. 具名插槽的实现原理用法示例&#xff1a; 3. 作用域插槽的实现原理用法示例&#xff1a; ⭐ 写在最后 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到 Vue 技能树参考资料专栏&…

ZYNQ程序固化

文章目录 一、简介二、固化操作2.1 生成固化文件2.2 固化到SD卡2.3 固化到Flash 参考 将程序存储在非易失性存储器中&#xff0c;在上电或者复位时让程序自动加载运行。 这个过程需要启动引导程序( Boot Loader)参与&#xff0c;Boot Loader会加载FPGA配置文件&#xff0c;以及…

论述Python中列表、元组、字典和集合的概念

Python列表是用于存储任意数目、任意类型的数据集合&#xff0c;包含多个元素的有序连续的内存空间&#xff0c;是内置可变序列&#xff0c;或者说可以任意修改。在Python中&#xff0c;列表以方括号&#xff08;[ ]&#xff09;形式编写。 Python元组与Python列表类似&#x…

Overleaf(LaTeX文档在线编写平台)使用学习记录

一、LaTeX简概[1] LaTeX&#xff0c;是一种基于TEX的排版系统&#xff0c;是一种可以处理排版和渲染的标记语言。由美国计算机科学家莱斯利兰伯特在20世纪80年代初期开发&#xff0c;利用这种格式系统的处理&#xff0c;即使用户没有排版和程序设计的知识也可以充分发挥由TEX所…

机器学习-随机森林【手撕】

随机森林 集成学习算法 概述 集成学习不是一个单独的机器学习算法&#xff0c;而是通过在数据上构建多个模型&#xff0c;集成所有模型的建模结果&#xff0c;基本上现在的所有机器学习都能看到集成学习的身影 目标 综合考虑多个弱评估器的结果&#xff0c;综合得到最终的…

【C语言】(3)字符

字符串 1. 字符串简介 在C语言中&#xff0c;字符串是由字符数组构成的序列&#xff0c;以空字符&#xff08;\0&#xff09;结尾。这个空字符不可见&#xff0c;用于标记字符串的结束。C语言中没有专门的字符串类型&#xff0c;通常使用字符数组表示字符串。 2. 声明和初始…

NC开发客户端(前端)连接启动失败can‘t connect to server, please wait

效果图 解决方法 IP地址和端口要对应 1-IP地址中间启动&#xff0c;肯定是这个127.0.0.1 2-端口号&#xff0c;要对应中间件启动在控制台输出的端口 或者是在home目录-》bin-》sysConfig.bat这里面的服务器&#xff0c; 里面可以看到对应启动ip地址和端口

模拟问题刷题

模拟类题目是机试题中出现频率很高的一种类型&#xff0c;这类题目的特点是并不涉及特别高 深的知识&#xff0c;只需利用程序实现题目的要求。由于这类题目通常不需要经过太多的思考&#xff0c;所以能够很纯粹地考查考生的编程能力。 1. 图形排版 图形排版是最为常见的模拟…