主节点宕机数据,备库数据恢复
背 景
在从节点停止服务,然后往主库不断写入数据,然后把主机宕机掉,启动从库,把主库宕机期间的增量wal日志复制到从库的archive目录下, 执行恢复脚本,则会把主机宕机后的增量数据追加到数据库。
环境
- 配置16 master 的 pg_hba,conf 文件
host all all 10.10.56.0/0 md5 host replication all 10.10.56.0/0 trust "pg_hba.conf" 96L, 4652C
配置16 master的 postgresql.conf
listen_addresses = '*' max_connections = 1000 wal_level = logical archive_mode = on archive_command = '/bin/true' log_destination = 'csvlog' logging_collector = on log_filename = 'postgresql-%Y-%m-%d.log' log_rotation_size = 20MB log_statement = 'mod' log_replication_commands = on deadlock_timeout = 100ms
配置18 slave,初始化数据库从master pg_basebackup
/opt/pgsql-10/bin/pg_basebackup -h 10.10.56.16 -U repl -W -Fp -Pv -Xs -R -D /pgdata/10/poc/data/
配置18的 recovery.conf ,从归档目录恢复数据
#standby_mode = 'on' #primary_conninfo = 'user=repl password=123456 host=10.10.56.16 port=5432 sslmode=disable sslcompression=1 target_session_attrs=any' restore_command = 'cp /pgdata/10/archive/%f %p'
以上就实现了主从异步流复制
启动16查询 为 f 表示为 主库
pocdb=# select pg_is_in_recovery(); pg_is_in_recovery ------------------- f (1 row) Time: 0.786 ms pocdb=#
在16 创建用户 repl 、创建表、略
主库16正常时,p表数据为
pocdb=# select max(id) from p; max --------- 3774121 (1 row)
从库18 p表数据
pocdb=# select max(id) from p; max --------- 3774121 (1 row)
主库宕机前(16)
pocdb=# select max(id) from p; max --------- 4005263 (1 row)
主库(16)宕机后,从库进行恢复后,数据已经追加:
postgres@clw-db3:/pgdata/10/poc/data> /opt/pgsql-10/bin/psql pocdb psql (10.3) Type "help" for help. pocdb=# select max(id) from p; max --------- 4005263 (1 row)
补充:postgresql在windows重装后如何重新恢复的方法
背景
windows系统重装后我们的postgresql服务器就不会正常启动,因为在系统中注册的服务重装后已经没有了,但是你的postgresql不是安装在系统盘区上的,那么postgresql服务器的文件和数据就还是存在的,比如原来的安装目录是D:\PostgreSQL,那么我们怎么让服务器服务自动运行起来,这样我们的程序才能连接数据库了,而且数据还不会丢失。
处理方法
第一种方法:
最简单的办法重装,把原来的文件全部删除,如果原来有数据备份,把备份数据恢复就可以了,那如果重装系统前没有备份数据呢?这种办法就找不回原来的数据了,对于开发者来说是很头疼的,那么我给大家介绍第二种方法,前提是数据库的安装目录和数据库数据目录文件夹都是完好无损的,否则我也没办法了;
第二种方法:
重新注册服务,其实比重新安装还简单了;执行命令就可以了,
第一步:进入到数据库的安装目录,cd D:\PostgreSQL\bin;
第二部:执行服务注册:
pg_ctl register -N pg921 -D D:\PostgreSQL\data -S auto -w -t 10 -l D:/PostgreSQL/pg921.log -o "-p 5432",
-N pg921 代表注册服务的名称 ,-D代表数据库文件目录 ,-S代表服务启动方式auto自动,demand手动,-o "-p 5432"指启动服务端口;(可以通过pg_ctl --help命令查看使用方法)
第三步:启动服务,net start pg921;
通过上面的的方法就成功的注册了服务器,以后每次开机都可以使用数据库了;
但是postgresql自带的一个管理工具pgAdmin3还是不能正常使用,需要我们配置,配置方法见下图:
注意:服务项不需要填写,主机填写localhost,如果填写真实的ip,必须在数据库配置文件中配置ip权限,否则不能连接;
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]