postgresql pgsql最新版安装指南及数据存储路径更改及主从配置

安装指南

  1. 首先在apt的list添加你当前系统版本对应的apt列表

    目前官网有16.04,14.04,12.04 分别对应下面的xenial,xenial,precise

    sudo vim /etc/apt/sources.list.d/pgdg.list

    根据对应系统复制下面的repo到pgdg.list中,

    deb http://apt.postgresql.org/pub/repos/apt/ xenial-pgdg main

    deb http://apt.postgresql.org/pub/repos/apt/ trusty-pgdg main

    deb http://apt.postgresql.org/pub/repos/apt/ precise-pgdg main

  2. 更新对应远程pg的repo的key

    wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | sudo apt-key add -

  3. 更新本地的list

    sudo apt-get update

  4. 安装PGSQL

    sudo apt-get install postgresql

PGSQL更改数据的存储路径

  1. 找到配置文件查看原来的数据存储路径在哪

    sudo find / -name postgresql.conf

    一般是在/etc/postgresql/9.6/main/postgresql.conf

  2. 停掉PGSQL

    sudo service postgresql stop

  3. 拷贝原来的数据路径到新的路径下

    sudo cp -rf /var/lib/postgresql/9.6/main/ /data/postgresql/

  4. 设置用户和权限

    sudo chown -R postgres:postgres /data/postgresql/

    sudo chmod 700 /data/postgresql/

  5. 将配置文件的数据存储路径改成新的

    sudo vim /etc/postgresql/9.6/main/postgresql.conf

  6. 再启动就行了

    sudo service postgresql start

PGSQL主从配置

  1. 修改postgresql.conf

    sudo vim /etc/postgresql/9.6/main/postgresql.conf

    listen_addresses = '*'

    wal_level = replica

    max_wal_senders = 2

    wal_keep_segments = 64

    hot_standby = on

  2. 创建一个超级用户来专门负责让standby连接去拖WAL日志

    create user replica superuser password '1234';

    将添加的用户添加到hba的配置中

    sudo vim /etc/postgresql/9.6/main/pg_hba.conf

    host replication replica 1.1.1.1 md5

  3. pg_basebackup 创建备库

    使用postgres用户创建备库

    pg_basebackup -D /data/postgresql/ -Fp -Xs -v -P -h 1.1.1.1 -p 5432 -U replica

    备库创建成功之后修改hba配置文件:

    sudo vim /etc/postgresql/9.6/main/pg_hba.conf

    添加以下的内容:

    host all all 0.0.0.0/0 trust

    host replication repuser master md5

  4. 配置recovery.conf
  • master端

    sudo cp /usr/share/postgresql/9.6/recovery.conf.sample /data/postgresql/recovery.done

    sudo vim /data/postgresql/recovery.done

    修改以下的配置项

    recovery_target_timeline = 'latest'

    standby_mode = on

    primary_conninfo = 'host=slave.ip port=5432 user=repuser password=repuser'

    trigger_file = '/home/postgres/data/trigger_file'

  • slave端

    sudo cp /usr/share/postgresql/9.6/recovery.conf.sample /data/postgresql/recovery.conf

    sudo vim /data/postgresql/recovery.conf

    修改以下的配置项

    recovery_target_timeline = 'latest'

    standby_mode = on

    primary_conninfo = 'host=master.ip port=5432 user=repuser password=repuser'

    trigger_file = '/home/postgres/data/trigger_file'

主从配置基本步骤到这就结束了。

如果进入从库遇到psql: FATAL: the database system is starting up的问题只需要修改一下从库的配置文件postgresql.conf,设置standby=on就可以了。

postgresql pgsql最新版安装指南及数据存储路径更改及主从配置的更多相关文章

  1. windows mysql数据存储路径更改

    背景:之前服务器磁盘很小,随着数据量的不断增加,磁盘不够,所以新申请了更大的磁盘,然后需要将旧路径下的数据迁移到新磁盘上. 1.任务管理器-打开服务,找到mysql的启动项,停止服务,属性查看可执行文 ...

  2. mysql数据库存储路径更改 数据文件位置

    使用了VPS一段时间之后发现磁盘空间快满了.本人的VPS在购买的时候买了500gb的磁盘,提供商赠送了20GB的高性能系统磁盘.这样系统就有两个磁盘空间了.在初次安装mysql 的时候将数据库目录安装 ...

  3. mysql修改默认数据存储路径

    1.先关闭mysql服务 可cmd--services.msc进入关闭服务 或cmd命令输入net stop mysql57关闭服务 2.进入C:\ProgramData\MySQL\MySQL Se ...

  4. mysql修改数据存储路径报错处理

    Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock'解决?: >>> vim ...

  5. mysql 数据库存储路径更改

    使用了VPS一段时间之后发现磁盘空间快满了.本人的VPS在购买的时候买了500gb的磁盘,提供商赠送了20GB的高性能系统磁盘.这样系统就有两个磁盘空间了.在初次安装mysql 的时候将数据库目录安装 ...

  6. postgresql使用文档之一 初始化数据存储区

    17.2. 创建一个数据库集群(Database Cluster) 在你能做任何事情之前,你必须在磁盘上初始化一块存储空间.我们称这为一个数据库集群(database cluster). 一个Data ...

  7. 更改mysql数据存储路径

    1.检查mysql数据库存放目录 mysql -u root -prootadmin show variables like '%dir%'; quit; (查看datadir 那一行所指的路径) 2 ...

  8. 【转载】变更MySql数据存储路径的方法

    1.在mysql安装目录下找到my.ini文件,更改#Path to the database root datadir="希望存放数据的地址" 2.将默认存放路径(一般为&quo ...

  9. Unity数据存储路径总结

    一.在项目根目录中创建Resources文件夹来保存文件.可以使用Resources.Load("文件名字,注:不包括文件后缀名");把文件夹中的对象加载出来.注:此方可实现对文件 ...

随机推荐

  1. nodejs异步处理

    采用Async.Q.Promise等第三方库处理异步回调 Async 安装 npm install async --save-dev

  2. http请求与响应(content-type)

    http请求信息由浏览器把地址栏URL信息和页面(html.jsp.asp)组装成http请求消息体(如下). <request-line>(请求消息行)<headers>(请 ...

  3. 如果mac电脑的usb转接器连接wlan时不显示,也就是不识别usb此时的网络连接没有,解决办法就是如下

    1.接上电源   关机 先按下shift +ctrl + opt + 开机键    ,等待10秒,这10秒是没有反应的,屏幕不会亮,系统不会跑起来,  10秒之后松开所有键,再按下opt + cmd ...

  4. C#技术漫谈之垃圾回收机制(GC)

    GC的前世与今生 虽然本文是以.NET作为目标来讲述GC,但是GC的概念并非才诞生不久.早在1958年,由鼎鼎大名的图林奖得主John McCarthy所实现的Lisp语言就已经提供了GC的功能,这是 ...

  5. thinkphp5.0助手函数占用服务器资源

    db('user')  默认情况下,每次请求都会重新连接数据库,这样会占用服务器资源 方法1.如果不想每次都重连可以这样 db("List",[],false) 方法2.还可以直接 ...

  6. 1.2输出100以内的素数&输出前100个素数。

    输出100以内的素数只是一个嵌套,在1.1的基础上添加一层循环,只需要注意从2开始,并且变量需要换一个. #include<stdio.h> int main() { ; ; i < ...

  7. python基础知识(三)

    摘要:主要涉及新数据类型set集合.三元运算.深浅拷贝.函数基础.全局变量与局部变量 一.set --> 无序,不允许重复的集合 不允许重复的列表,   1,创建    s = set() 接收 ...

  8. 04 MapReduce原理介绍

    大数据实战(上) # MapReduce原理介绍 大纲: * Mapreduce介绍 * MapReduce2运行原理 * shuffle及排序    定义 * Mapreduce 最早是由googl ...

  9. table隔行变色

    table tr:nth-child(2n) {         background: #EEF8F0;     }     table tr:nth-child(2n+1) {         b ...

  10. ES6学习笔记一

    块级作用域:在ES5中只有全局作用域与函数作用域,ES6中新增的块级作用域避免变量的覆盖与泄露.考虑到代码运行环境,在块级作用域中应避免声明函数,最好用函数表达式的方式声明. let与const:le ...