Citus介绍
citus是PostgreSQL数据库中的一种轻量级的分库分表解决方案。它是PostgreSQL数据库中的一个插件,每个citus集群由多个PostgreSQL数据库实例组成,数据库实例分为两类:
master节点,通常有一台。master节点只存储分库分表的元数据,不存储实际的数据。
worker节点,通常有多台。worker节点存储实际的分片数据(shard)。
环境
华为云ECS 8核,32G内存 3台
CentOS 7.2 x64
PostgreSQL 12.1
Citus 9.1.2
sysbench 1.0.19
集群配置1
192.168.1.132 coordinator node
192.168.1.105 worker(data) node
192.168.1.58 worker(data) node
集群配置2
192.168.1.105 coordinator node
192.168.1.132 worker(data) node
192.168.1.58 worker(data) node
集群配置3
192.168.1.58 coordinator node
192.168.1.132 worker(data) node
192.168.1.105 worker(data) node
1.安装PG和citus
# useradd jerome # passwd jerome # cd /ssd_data # mkdir pg_test # chown jerome.jerome pg_test # chmod 0700 pg_test # su - jerome --上传12.1源码至服务器并安装PG $ tar zxvf postgresql-12.1.tar.gz $ cd ~/postgresql-12.1 $ ./configure --prefix=/home/jerome/pg12 --with-pgport=1912 --without-zlib $ make && make install --下载最新release版 v9.1.2 $ wget https://codeload.github.com/citusdata/citus/tar.gz/v9.1.2 $ tar zxvf v9.1.2 $ cd citus-9.1.2/ $ ./configure PG_CONFIG=/home/jerome/pg12/bin/pg_config $ make && make install --初始化数据目录 $ /home/jerome/pg12/bin/initdb -D /ssd_data/pg_test/data1912 -Ujerome --参数配置 $ vi /ssd_data/pg_test/data1912/postgresql.conf shared_preload_libraries='citus' listen_addresses = '0.0.0.0' port = 1912 max_connections = 200 log_destination = 'csvlog' logging_collector = on log_directory = 'log' log_filename = 'postgresql-%a.log' log_truncate_on_rotation = on log_rotation_age = 1d log_rotation_size = 0 log_min_duration_statement = 5s log_checkpoints = on log_connections = on log_disconnections = on log_error_verbosity = verbose log_line_prefix = '%m [%p] ' log_lock_waits = on log_statement = 'ddl' log_timezone = 'PRC' log_autovacuum_min_duration = 0 $ vi /ssd_data/pg_test/data1912/pg_hba.conf --添加如下内容 host all all 192.168.1.0/24 trust --启动PG服务 $ /home/jerome/pg12/bin/pg_ctl -D /ssd_data/pg_test/data1912 -l /ssd_data/pg_test/data1912/pg.log start & --安装citus扩展 $ /home/jerome/pg12/bin/psql -p1912 -Ujerome postgres psql (12.1) Type "help" for help. postgres=# create extension citus; CREATE EXTENSION
复制
2.安装sysbench
$ wget https://github.com/akopytov/sysbench/archive/1.0.19.tar.gz $ tar zxvf 1.0.19.tar.gz $ cd sysbench-1.0.19/ $ ./autogen.sh $ ./configure --prefix=/home/jerome/sysbench --without-mysql \ --with-pgsql \ --with-pgsql-includes=/home/jerome/pg12/include \ --with-pgsql-libs=/home/jerome/pg12/lib $ make -j $ make install
复制
3.单机测试
只读场景测试
--单表一千万条记录 $ /home/jerome/sysbench/bin/sysbench oltp_read_only \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=8 \ --table_size=10000000 \ prepare $ /home/jerome/sysbench/bin/sysbench oltp_read_only \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=128 \ --time=120 \ --report-interval=2 \ run
复制
读写场景测试
$ /home/jerome/sysbench/bin/sysbench oltp_read_write \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=128 \ --time=120 \ --report-interval=2 \ run
复制
只写场景测试
$ /home/jerome/sysbench/bin/sysbench oltp_write_only \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=128 \ --time=120 \ --report-interval=2 \ run
复制
插入场景测试
$ /home/jerome/sysbench/bin/sysbench oltp_insert \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=128 \ --time=120 \ --report-interval=2 \ run
复制
删除场景测试
$ /home/jerome/sysbench/bin/sysbench oltp_delete \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=128 \ --time=120 \ --report-interval=2 \ run
复制
4.citus主服务器添加数据节点
$ /home/jerome/pg12/bin/psql -Ujerome postgres postgres=# SELECT * from master_add_node('192.168.1.105', 1912); postgres=# SELECT * from master_add_node('192.168.1.58', 1912); --查看是否添加成功 postgres=# SELECT * FROM master_get_active_worker_nodes(); node_name | node_port ---------------+----------- 192.168.1.58 | 1912 192.168.1.105 | 1912 (2 rows)
复制
5.citus主服务器初始化数据并分片
--单表一千万条记录 $ /home/jerome/sysbench/bin/sysbench oltp_read_only \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=8 \ --table_size=10000000 \ prepare --将sbtest1表转换为sharding表(2个shard,每台物理机每个PG实例一个shard) postgres=# set citus.shard_count =2; postgres=# select create_distributed_table('sbtest1','id');
复制
6.使用citus配置1进行测试
测试案例参考第三步单机测试
7. 使用citus配置2进行测试
测试案例参考第三步单机测试
8.使用citus配置3进行测试
测试案例参考第三步单机测试
9.读写混合测试24小时
使用citus配置3进行测试 nohup /home/jerome/sysbench/bin/sysbench oltp_read_write \ --db-driver=pgsql \ --pgsql-host=127.0.0.1 \ --pgsql-port=1912 \ --pgsql-user=jerome \ --pgsql-db=postgres \ --threads=64 \ --time=86400 \ --report-interval=2 \ run > citus3_read_write_c64_24h.log 2>&1 &
复制
10.测试结果
最后修改时间:2020-02-06 19:34:43
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
文章被以下合辑收录
评论
相关阅读
明明想执行的SQL是DELETE、UPDATE,但为什么看到的是SELECT(FDW的实现原理解析)
小满未满、
393次阅读
2025-03-19 23:11:26
PostgreSQL初/中/高级认证考试(3.15)通过考生公示
开源软件联盟PostgreSQL分会
387次阅读
2025-03-20 09:50:36
9.9 分高危漏洞,尽快升级到 pgAdmin 4 v9.2 进行修复
严少安
298次阅读
2025-04-11 10:43:23
openHalo问世,全球首款基于PostgreSQL兼容MySQL协议的国产开源数据库
严少安
239次阅读
2025-04-07 12:14:29
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
230次阅读
2025-04-15 14:48:05
IvorySQL 4.4 发布 - 基于 PostgreSQL 17.4,增强平台支持
通讯员
230次阅读
2025-03-20 15:31:04
PG vs MySQL 执行计划解读的异同点
进击的CJR
161次阅读
2025-03-21 10:50:08
PostgreSQL分区管理扩展——pg_partman
chirpyli
130次阅读
2025-03-19 15:48:31
手把手教你在 openKylin 上部署 IvorySQL 4.4
严少安
124次阅读
2025-03-27 20:41:28
postgresql+patroni+etcd高可用安装
necessary
121次阅读
2025-03-28 10:11:23