暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

原创 ysl 2021-06-06
2432

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();

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论