使用阿里云服务器搭建PostgreSQL主从架构图文流程

这篇具有很好参考价值的文章主要介绍了使用阿里云服务器搭建PostgreSQL主从架构图文流程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

阿里云百科分享使用阿里云服务器搭建PostgreSQL主从架构图文流程,PostgreSQL被业界誉为最先进的开源数据库,支持NoSQL数据类型(JSON/XML/hstore)。本文档介绍在CentOS 7操作系统的ECS实例上搭建PostgreSQL主从架构的操作步骤。

目录

前提条件

步骤一:选购ECS实例

步骤二:配置PostgreSQL主节点

步骤三:配置PostgreSQL从节点

步骤四:检测验证


前提条件

  • 已注册阿里云账号。如还未注册,请先完成账号注册。
  • 已在安全组入方向中添加规则放行5432端口。具体步骤,请参见添加安全组规则。
  • ECS云服务器:aliyunbaike.com/go/ecs
  • 实例规格:ecs.g6.large
  • 操作系统:CentOS 7.2
  • PostgreSQL:11

本教程基于yum方式手动安装并搭建PostgreSQL主从复制架构。

步骤一:选购ECS实例

搭建PostgreSQL主从复制架构,需要选购2台专有网络类型的ECS实例,一台ECS实例作为主节点,另一台ECS实例作为从节点。 具体操作,请参见使用向导创建实例。

说明 建议您不为ECS实例分配公网IP,按需购买弹性公网IP绑定至ECS实例,后续您可以根据实际情况考虑升级配置或调优架构。详情请参见申请弹性公网IP。

 

步骤二:配置PostgreSQL主节点

  1. 远程连接PostgreSQL主节点。

    具体操作,请参见连接方式概述。

  2. 依次运行以下命令,安装PostgreSQL。
    yum update -y
    wget --no-check-certificate https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
    rpm -ivh pgdg-redhat-repo-latest.noarch.rpm
    yum install postgresql11-server postgresql11-contrib -y
    /usr/pgsql-11/bin/postgresql-11-setup initdb

    说明 本教程以PostgreSQL 11版本为例。实际安装时,请您使用最新版本。

  3. 依次运行以下命令,启动服务并设置服务开机自启动。
    systemctl start postgresql-11.service    #启动服务
    systemctl enable postgresql-11.service   #设置服务开机自启动
  4. 在主节点上创建数据库账号replica(用于主从复制),并设置密码及登录权限和备份权限。可以在阿里云CLUB中心:aliyun.club 领取云服务器专用的满减券。
    1. 运行以下命令,登录postgres用户。
      su - postgres
    2. 当显示-bash-4.2$时表示成功登录,然后输入以下命令进入PostgreSQL交互终端。
      psql
    3. 当显示postgres=#时表示成功进入交互终端,然后为用户postgres设置密码,增强安全性。
      ALTER USER postgres WITH PASSWORD 'YourPassWord';
    4. 输入以下SQL语句创建数据库账号replica,并设置密码及登录权限和备份权限。本示例中将密码设置为replica
      CREATE ROLE replica login replication encrypted password 'replica';
    5. 查询账号是否创建成功。
      SELECT usename from pg_user;
      返回结果如下,表示已创建成功。
      usename  
      ----------
      postgres
      replica
      (2 rows)
    6. 查询权限是否创建成功。
      SELECT rolname from pg_roles;
      返回结果如下,表示已创建成功。
      rolname  
      ----------
      postgres
      replica
      (2 rows)
    7. 输入以下命令,并按Enter退出SQL终端。
      \q
    8. 输入以下命令,并按Enter退出PostgreSQL。
      exit
  5. 运行以下命令,打开pg_hba.conf文件,设置replica用户白名单。
    vim /var/lib/pgsql/11/data/pg_hba.conf
    IPv4 local connections段添加下面两行内容。
    host    all             all             <从节点的VPC IPv4网段>          md5     #允许VPC网段中md5密码认证连接
    host    replication     replica         <从节点的VPC IPv4网段>          md5     #允许用户从replication数据库进行数据同步

    添加完成后,按Esc键,输入:wq并按下enter键,保存并退出。

  6. 运行以下命令,打开postgresql.conf文件。
    vim /var/lib/pgsql/11/data/postgresql.conf
    分别找到以下参数,并将参数修改为以下内容:
    listen_addresses = '*'   #监听的IP地址
    wal_level = hot_standby  #启用热备模式
    synchronous_commit = on  #开启同步复制
    max_wal_senders = 32     #同步最大的进程数量
    wal_sender_timeout = 60s #流复制主机发送数据的超时时间
    max_connections = 100    #最大连接数,从库的max_connections必须要大于主库的

    修改完成后,按Esc键,输入:wq并按下enter键,保存并退出。

  7. 运行以下命令,重启服务。
    systemctl restart postgresql-11.service

步骤三:配置PostgreSQL从节点

  1. 远程连接PostgreSQL从节点。

    具体操作,请参见连接方式概述。

  2. 依次运行以下命令,安装PostgreSQL。
    yum update -y
    wget --no-check-certificate https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm
    rpm -ivh pgdg-redhat-repo-latest.noarch.rpm
    yum install postgresql11-server postgresql11-contrib -y
  3. 运行以下命令,使用pg_basebackup基础备份工具指定备份目录。
    pg_basebackup -D /var/lib/pgsql/11/data -h <主节点IP> -p 5432 -U replica -X stream -P
    本示例中Passwordreplica
    Password: 
    30075/30075 kB (100%), 1/1 tablespace
  4. 依次运行以下命令,新建并修改recovery.conf配置文件。
    cp /usr/pgsql-11/share/recovery.conf.sample /var/lib/pgsql/11/data/recovery.conf
    vim /var/lib/pgsql/11/data/recovery.conf
    分别找到以下参数,并将参数修改为以下内容:
    standby_mode = on     #声明此节点为从库
    primary_conninfo = 'host=<主节点IP> port=5432 user=replica password=replica' #对应主库的连接信息
    recovery_target_timeline = 'latest' #流复制同步到最新的数据

    修改完成后,按Esc键,输入:wq并按下enter键,保存并退出。

  5. 运行以下命令,打开postgresql.conf文件。
    vim /var/lib/pgsql/11/data/postgresql.conf
    分别找到以下参数,并将参数修改为以下内容:
    max_connections = 1000             # 最大连接数,从节点需设置比主节点大
    hot_standby = on                   # 开启热备
    max_standby_streaming_delay = 30s  # 数据流备份的最大延迟时间
    wal_receiver_status_interval = 1s  # 从节点向主节点报告自身状态的最长间隔时间
    hot_standby_feedback = on          # 如果有错误的数据复制向主进行反馈

    修改完成后,按Esc键,输入:wq并按下enter键,保存并退出。

  6. 运行以下命令,修改数据目录的属组和属主。
    chown -R postgres.postgres /var/lib/pgsql/11/data
  7. 依次运行以下命令,启动服务并设置服务开机自启动。
    systemctl start postgresql-11.service    #启动服务
    systemctl enable postgresql-11.service   #设置服务开机自启动

 

步骤四:检测验证

检测验证需要主从节点之间存在数据交互,例如,从节点备份目录时,进行检测能够得到预期的结果。

pg_basebackup -D /var/lib/pgsql/96/data -h <主节点IP> -p 5432 -U replica -X stream -P
  1. 在主节点中运行以下命令,查看sender进程。
    ps aux |grep sender
    返回结果如下,表示可成功查看到sender进程。
    postgres  2916  0.0  0.3 340388  3220 ?        Ss   15:38   0:00 postgres: wal sender     process replica 192.168.**.**(49640) streaming 0/F01C1A8
  2. 在从节点中运行以下命令,查看receiver进程。
    ps aux |grep receiver
    返回结果如下,表示可成功查看到receiver进程。
    postgres 23284  0.0  0.3 387100  3444 ?        Ss   16:04   0:00 postgres: wal receiver process   streaming 0/F01C1A8
  3. 在主节点中进入PostgreSQL交互终端,输入以下SQL语句,在主库中查看从库状态。
    select * from pg_stat_replication;
    返回结果如下,表示可成功查看到从库状态。
    pid | usesysid | usename | application_name | client_addr | client_hostname | client_port | backend_start | backend_xmin | state | sent_location | write_locati
    on | flush_location | replay_location | sync_priority | sync_state 
    ------+----------+---------+------------------+---------------+-----------------+------------- +-------------------------------+--------------+-----------+---------------+-------------
    ---+----------------+-----------------+---------------+------------
    2916 | 16393 | replica | walreceiver | 192.168.**.** | | 49640 | 2017-05-02 15:38:06.188988+08 | 1836 | streaming | 0/F01C0C8 | 0/F01C0C8 
    | 0/F01C0C8 | 0/F01C0C8 | 0 | async
    (1 rows)

原文来自阿里云官方文档。 文章来源地址https://www.toymoban.com/news/detail-644264.html

到了这里,关于使用阿里云服务器搭建PostgreSQL主从架构图文流程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 利用docker搭建mysql主从服务器

    1.首先拉取docker镜像,我们这里使用5.7版本的mysql: 2.然后使用此镜像启动容器,这里需要分别启动主从两个容器 3.配置Master(主) 通过docker名称进入:docker exec -it master /bin/bash`/

    2024年02月11日
    浏览(39)
  • 使用阿里云服务器搭建Discuz论坛网站教程基于CentOS系统

    阿里云百科分享使用阿里云服务器建站教程,本文是搭建Discuz论坛,Discuz!是一款通用的社区论坛软件系统,它采用PHP和MySQL组合的基础架构,为您提供高效的论坛解决方案。本文介绍如何在CentOS 7操作系统的ECS实例上搭建Discuz! X3.4论坛。 目录 前提条件 操作步骤 后续操作 已创

    2024年02月13日
    浏览(38)
  • Linux 中搭建 主从dns域名解析服务器

    作者主页: 点击! Linux专栏:点击! ————前言———— 主从(Master-Slave)DNS架构是一种用于提高DNS系统可靠性和性能的配置方式。 高可用性 :通过配置主从DNS服务器,可以实现DNS服务的高可用性。当主DNS服务器发生故障或不可用时,从DNS服务器可以接管服务,确保域

    2024年03月17日
    浏览(50)
  • 服务器离线部署docker,镜像迁移,mysql主从搭建等服务

    公司项目要上线项目,买了两台云服务器,需进行环境部署(1台接入公网,一台只能局域网访问),主要部署以下内容 1、服务器之间配置ssh免密 2、离线docker部署 3、docker镜像迁移 4、redis服务 5、minio文件服务 6、kkFileView文件预览服务 7、mysql主从搭建 目录 1、配置两台服务器

    2024年02月04日
    浏览(34)
  • 【AI】使用阿里云免费服务器搭建Langchain-Chatchat本地知识库

    书接上文,由于家境贫寒的原因,导致我本地的GPU资源无法满足搭建Langchain-Chatchat本地知识库的需求,具体可以看一下这篇文章,于是我只能另辟蹊径,考虑一下能不能白嫖一下云服务器资源,于是去找网上找,您还别说,还真有,具体的领取方法可以查看我的这篇文章:【

    2024年02月03日
    浏览(68)
  • 阿里云服务器如何搭建MQTT服务器

    入门教程:链接 将系统配置成Ubuntu18的(因为我只会用这个系统) 在实例处停止当前系统的运行,然后依次选择2,下拉菜单找到3进行更换系统,更换完成以后重启就好了。 如下图,依次点击1-4的按钮,第五步需要重新设置系统的密码 Xshell下载链接 安装完成后打开Xshell按照

    2024年02月03日
    浏览(49)
  • 阿里云国际-在阿里云服务器上快速搭建幻兽帕鲁多人服务器

    幻兽帕鲁是最近流行的新型生存游戏。该游戏一夜之间变得极为流行,同时在线玩家数量达到了200万。然而,幻兽帕鲁的服务器难以应对大量玩家的压力。为解决这一问题,幻兽帕鲁允许玩家建立专用服务器,其提供以下优势: (1)更高的稳定性,减少崩溃或停机的风险;

    2024年02月21日
    浏览(47)
  • 免费搭建幻兽帕鲁服务器,白嫖阿里云游戏服务器

    阿里云幻兽帕鲁服务器免费搭建方案,先在阿里云高校计划「云工开物」活动领取学生专享300元无门槛代金券,幻兽帕鲁专用服务器4核16G配置26元1个月、149元半年,直接使用这个无门槛300元代金券抵扣即可免费搭建幻兽帕鲁服务器。阿里云服务器网aliyunfuwuqi.com分享详细免费

    2024年02月22日
    浏览(46)
  • 阿里云服务器搭建django+区块链

    djago搭建参考:https://www.bilibili.com/read/cv10030536/ 成功搭建后加入区块链部分,其中遇到的问题: 1.区块链相关代码: tip:注意路径和要引入的包 2.证书拷贝问题 说是证书配置问题,按照fisco bcos的教程把fisco下的证书文件重新复制的sdk的bin目录下,把bin目录里面的内容删除掉

    2024年01月19日
    浏览(38)
  • 申请阿里云服务器并搭建公网可支持数据上传的HTTP服务器

            拥有一台自己的云服务器可以做很多事情。阿里云服务器毫无疑问是国内最好的。         阿里云服务器可以用于各种互联网应用的搭建和运行,提供稳定、高性能的服务。         阿里云服务器的用途,包括但不限于以下几个方面: 网站托管:可以将网站

    2024年02月16日
    浏览(65)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包