clickhouse执行分布式DDL报错:Table `xxx` isn't replicated, but shard #2 is replicated according to its cluster definition

原创 2020-11-17 18:06 阅读(1602)次

clickhouse执行分布式DDL报错:Table `xxx` isn't replicated, but shard #2 is replicated according to its cluster definition

执行的语句是:

alter table engs_comp_clg_result_local on cluster shipin_cluster drop partition 20191101

我是想把我集群shipin_cluster中两个节点的本地表中一个分区删除掉,但是一执行报如上错误,说是我的本地表不是复制表,但是分片2却根据定义在复制。

我的集群配置如下:

<yandex>
    <!-- 集群配置 -->
    <clickhouse_remote_servers>
        <!-- 集群名称 2分片一副本,名称可自定义 -->
        <mycluster>
            <!-- 数据分片1  -->
            <shard>
		<internal_replication>true</internal_replication>
                <replica>
                    <host>192.168.15.137</host>
                    <port>9000</port>
		    <user>default</user>
                    <password>123456</password>
                </replica>
            </shard>
            <!-- 数据分片2  -->
            <shard>
		<internal_replication>true</internal_replication>
                <replica>
                    <host>192.168.15.139</host>
                    <port>9000</port>
		    <user>default</user>
                    <password>123456</password>					
                </replica>
            </shard>
        </mycluster>
    </clickhouse_remote_servers>
	<!--压缩算法 -->
    <clickhouse_compression>
        <case>
            <min_part_size>10000000000</min_part_size>
            <min_part_size_ratio>0.01</min_part_size_ratio>
            <method>lz4</method>
        </case>
    </clickhouse_compression>
</yandex>

我并没有配置复制节点,只有2个分片节点,所以上面报的错,应该是我配置错了,后来发现:

<internal_replication>true</internal_replication>

这个配置是副本复制配置,于是我删除,再执行分布式DDL语句成功了!两个分片的表分区都成功删除了。


如果开发过程中有什么问题,或者想了解一些clickhouse的原理的同学,推荐朱凯老师这本书

链接地址点:ClickHouse原理解析与应用实践