• Clickhouse 学习笔记(6)—— ClickHouse 分片集群


    前置知识:

    Clickhouse学习笔记(5)—— ClickHouse 副本-CSDN博客

    与副本对比:

    副本虽然能够提高数据的可用性,降低丢失风险,但是每台服务器实际上必须容纳全量数据,对数据的横向扩容没有解决

    要解决数据水平切分的问题,需要引入分片的概念。通过分片把一份完整的数据进行切分,不同的分片分布到不同的节点上,再通过 Distributed 表引擎把数据拼接起来一同使用

    Distributed 表引擎本身不存储数据,有点类似于 MyCat 之于 MySql,成为一种中间件,通过分布式逻辑表来写入、分发、路由来操作多台节点不同分片的分布式数据

    集群写入流程(3分片 2副本 共6节点)

    一般来说internal_replication这一参数都是为true的,可以减轻distribute节点的压力

    集群读取流程(3分片 2副本 共6节点)

    所谓errors_count就是在通信过程中产生错误的次数

    集群配置流程(2分片 只有1个分片有副本 3节点)

    集群架构示意

    1.新建配置文件metrika-shard.xml

    在hadoop102上,进入/etc/clickhouse-server/config.d

    新建文件metrika-shard.xml

    也可以不创建外部文件,直接在 config.xml 的中指定

    先文件中写入内容(hadoop102):

    1. "1.0"?>
    2. <yandex>
    3. <remote_servers>
    4. <gmall_cluster>
    5. <shard>
    6. <internal_replication>trueinternal_replication>
    7. <replica>
    8. <host>hadoop102host>
    9. <port>9000port>
    10. replica>
    11. <replica>
    12. <host>hadoop103host>
    13. <port>9000port>
    14. replica>
    15. shard>
    16. <shard>
    17. <internal_replication>trueinternal_replication>
    18. <replica>
    19. <host>hadoop104host>
    20. <port>9000port>
    21. replica>
    22. shard>
    23. gmall_cluster>
    24. remote_servers>
    25. <zookeeper-servers>
    26. <node index="1">
    27. <host>hadoop102host>
    28. <port>2181port>
    29. node>
    30. <node index="2">
    31. <host>hadoop103host>
    32. <port>2181port>
    33. node>
    34. <node index="3">
    35. <host>hadoop104host>
    36. <port>2181port>
    37. node>
    38. zookeeper-servers>
    39. <macros>
    40. <shard>01shard>
    41. <replica>rep_1_1replica>
    42. macros>
    43. yandex>

    hadoop103:(仅macros参数不同)

    1. <macros>
    2. <shard>01shard>
    3. <replica>rep_1_2replica>
    4. macros>

    hadoop104:(仅macros参数不同)

    1. <macros>
    2. <shard>02shard>
    3. <replica>rep_2_1replica>
    4. macros>

    2.修改config.xml

    然后同步到hadoop103、104

    3.重启服务

    sudo clickhouse restart

    查看是否启动成功:ps -ef | grep clickhouse

    集群功能测试

    在hadoop102创建表,会自动同步到hadoop103和104上

    1. create table st_order_mt on cluster gmall_cluster (\
    2. id UInt32,\
    3. sku_id String,\
    4. total_amount Decimal(16,2),\
    5. create_time Datetime\
    6. ) engine =ReplicatedMergeTree('/clickhouse/tables/{shard}/st_order_mt','{replica}')\
    7. partition by toYYYYMMDD(create_time)\
    8. primary key (id)\
    9. order by (id,sku_id);

    其中on cluster后面要设置配置文件中自定义的集群名称

    ReplicatedMergeTree中的分片和副本名称从配置文件的宏定义(marcos)中获取

    可以看到在103和104上都有对应的表:

    然后在 hadoop102 上创建 Distribute 分布式表

    1. create table st_order_mt_all on cluster gmall_cluster\
    2. (id UInt32, \
    3. sku_id String,\
    4. total_amount Decimal(16,2),\
    5. create_time Datetime\
    6. )engine = Distributed(gmall_cluster,default, st_order_mt,hiveHash(sku_id));

    参数含义:

    Distributed(集群名称,库名,本地表名,分片键)

    分片键必须是整型数字,所以用 hiveHash 函数转换,也可以 rand()

    同样也可以同步到103和104上:

    然后在hadoop102上插入数据:

    1. insert into st_order_mt values\
    2. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    3. (202,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    4. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    5. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    6. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    7. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    8. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    9. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    10. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    11. (201,'sku_009',1000.00,'2020-06-01 12:00:00') ,\
    12. (202,'sku_002',2000.00,'2020-06-01 12:00:00'),\
    13. (203,'sku_004',2500.00,'2020-06-01 12:00:00'),\
    14. (204,'sku_002',2000.00,'2020-06-01 12:00:00'),\
    15. (205,'sku_003',600.00,'2020-06-02 12:00:00');

    查询分布式表和本地表即可得到结果;

  • 相关阅读:
    数据库规范化理论
    全网唯一!Matlab王者荣耀配色包MHonor
    idea远程debug调试
    WEB应用
    win10环境安装kettle&linux环境安装kettle
    Ruby on Rails 实践:更换 aloe 首页
    删除链表的倒数第N个节点
    JAVA后端工程师笔试题-避坑公司
    关于设置Windows文件夹区分大小写
    Vue3.0 实现支持搜索和筛选的用户列表(带动画过渡效果)
  • 原文地址:https://blog.csdn.net/qq_51235856/article/details/134346276