ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

【Postgresql分布式---单节点多实例部署citus】

2021-12-26 10:01:27  阅读:210  来源: 互联网

标签:Postgresql postgres pg10 citus --- pg conf home data


1.安装依赖
yum -y install libcurl-devel openssl-devel zlib-devel readline-devel libevent-devel autoconf

2.创建cn 和 worker 节点
su - pg10
mkdir -p /home/pg10/{data_cn,data_worker01,data_worker02}

3.初始化三个实例
initdb -D /home/pg10/data_cn
initdb -D /home/pg10/data_worker01
initdb -D /home/pg10/data_worker02

4.修改postgresql.auto.conf文件里实例端口和listen_addresses
echo “PORT=1921”>> /home/pg10/data_cn/postgresql.auto.conf
echo “PORT=7000”>> /home/pg10/data_worker01/postgresql.auto.conf
echo “PORT=8000”>> /home/pg10/data_worker02/postgresql.auto.conf

echo “listen_addresses=’’">> /home/pg10/data_cn/postgresql.auto.conf
echo "listen_addresses=’’”>> /home/pg10/data_worker01/postgresql.auto.conf
echo “listen_addresses=’*’”>> /home/pg10/data_worker02/postgresql.auto.conf

5.启动三个实例
pg_ctl start -D /home/pg10/data_cn -l /tmp/cnlog
pg_ctl start -D /home/pg10/data_worker01 -l /tmp/dn1log
pg_ctl start -D/home/pg10/data_worker02 -l /tmp/dn2log

6.连接到每个实例下创建 postgres 超级用户
psql -d postgres -p 1921 -c "CREATE USER postgres WITH SUPERUSER PASSWORD ‘1qaz@WSX’; "
psql -d postgres -p 7000 -c "CREATE USER postgres WITH SUPERUSER PASSWORD ‘1qaz@WSX’; "
psql -d postgres -p 8000 -c “CREATE USER postgres WITH SUPERUSER PASSWORD ‘1qaz@WSX’;”

7.编译安装 citus
我的压缩包为v8.3.2.tar.gz,放在/home/pg10/resource目录下
cd /home/pg10/resource
tar -zxvf v8.3.2.tar.gz
cd citus-8.3.2/

./autogen.sh
./configure
make -j24
make install -j24

8.给每个实例下的 pg_hba.conf 添加如下
vi /home/pg10/data_cn/pg_hba.conf
host all all 0.0.0.0/0 trust

vi /home/pg10/data_worker01/pg_hba.conf
host all all 0.0.0.0/0 trust

vi /home/pg10/data_worker02/pg_hba.conf
host all all 0.0.0.0/0 trust

9.reload使配置生效
pg_ctl reload -D /home/pg10/data_cn
pg_ctl reload -D /home/pg10/data_worker01
pg_ctl reload -D /home/pg10/data_worker02

10.在 postgresql.conf 中添加 预载库,并重新启动
echo “shared_preload_libraries = ‘citus’” >>
/home/pg10/data_cn/postgresql.conf

echo “shared_preload_libraries = ‘citus’” >> /home/pg10/data_worker01/postgresql.conf

echo “shared_preload_libraries = ‘citus’” >> /home/pg10/data_worker02/postgresql.conf

重新启动
pg_ctl restart -D /home/pg10/data_cn
pg_ctl restart -D /home/pg10/data_worker01
pg_ctl restart -D /home/pg10/data_worker02

11.在每个节点创建 citus扩展
psql -U postgres -d postgres -p 1921 -c “CREATE EXTENSION IF NOT EXISTS citus;”
psql -U postgres -d postgres -p 7000 -c “CREATE EXTENSION IF NOT EXISTS citus;”
psql -U postgres -d postgres -p 8000 -c “CREATE EXTENSION IF NOT EXISTS citus;”

12.在cn 节点添加 worker (172.20.10.7为我部署citus的这台主机的ip)
psql -U postgres -d postgres -p 1921
SELECT master_add_node(‘172.20.10.7’,7000);
SELECT master_add_node(‘172.20.10.7’,8000);

//如果添加错误可以用如下命令移除节点
select master_remove_node(‘localhost’, ‘port’);

13.验证添加结果
SELECT * FROM master_get_active_worker_nodes();

标签:Postgresql,postgres,pg10,citus,---,pg,conf,home,data
来源: https://blog.csdn.net/weixin_47308871/article/details/122152036

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有