ClickHouse 用户权限管理小探

背景

与传统的MySQL数据库类似,ClickHouse也有较完备的用户权限管理功能。其支持通过扩展users.xml配置和SQL-Driven两种方式来配置。安全无小事,大家在做数据集成相关的工作的时候,需要从数据库用户层面,做好安全防护。从入口处,明确数据访问的权限和范围。可别依赖于上层应用所做的限制。

通过扩展users.xml进行配置

我们可以新建相关的用户配置文件,不需要修改默认的users.xml文件,把新增的用户配置文件,放到/etc/clickhouse-server/users.d文件夹下,clickhouse会动态加载配置信息。如果users.d文件夹不存在,可自行新建。需要保证clickhouse启动用户有访问权限。

支持的场景包括:

1、操作权限控制

可以定义不同角色,比如:只读角色(readonly)和管理角色(management)。配置示例如下:

xml 复制代码
<!-- Profiles of settings. -->
    <profiles>
        <!-- Profile that allows only read queries. -->
        <readonly>
            <readonly>1</readonly>
            <allow_ddl>0</allow_ddl>
        </readonly>
        <management>
            <readonly>0</readonly>
            <allow_ddl>1</allow_ddl>
        </management>
    </profiles>

2、库访问控制

通过allow_databases限制用户能访问哪些数据库。结合操作权限,实现对哪些数据库有哪些访问权限。配置示例:

xml 复制代码
<profile>management</profile>
<allow_databases>
  <database>db01</database>
</allow_databases>
<allow_databases>
  <database>db02</database>
</allow_databases>

3、表访问控制

扩展users.xml进行配置的方式,目前无法实现具体的访问哪些表的权限控制。只能针对具体表,控制访问具体表中哪些行的权限。其实这个功能比较鸡肋。如果想具体控制到表级别,只能通过别的方式来实现。

xml 复制代码
<databases>
     <db01>
          <xxx_table>
               <filter>id is not null</filter>
          </xxx_table>
     </db01>
</databases>

4、其他的一些控制

包括:并发数、最大使用内存、超时时间等。官方给的示例如下:

xml 复制代码
<!-- Settings profiles -->
<profiles>
    <!-- Default settings -->
    <default>
        <!-- The maximum number of threads when running a single query. -->
        <max_threads>8</max_threads>
    </default>

    <!-- Settings for queries from the user interface -->
    <web>
        <max_rows_to_read>1000000000</max_rows_to_read>
        <max_bytes_to_read>100000000000</max_bytes_to_read>

        <max_rows_to_group_by>1000000</max_rows_to_group_by>
        <group_by_overflow_mode>any</group_by_overflow_mode>

        <max_rows_to_sort>1000000</max_rows_to_sort>
        <max_bytes_to_sort>1000000000</max_bytes_to_sort>

        <max_result_rows>100000</max_result_rows>
        <max_result_bytes>100000000</max_result_bytes>
        <result_overflow_mode>break</result_overflow_mode>

        <max_execution_time>600</max_execution_time>
        <min_execution_speed>1000000</min_execution_speed>
        <timeout_before_checking_execution_speed>15</timeout_before_checking_execution_speed>

        <max_columns_to_read>25</max_columns_to_read>
        <max_temporary_columns>100</max_temporary_columns>
        <max_temporary_non_const_columns>50</max_temporary_non_const_columns>

        <max_subquery_depth>2</max_subquery_depth>
        <max_pipeline_depth>25</max_pipeline_depth>
        <max_ast_depth>50</max_ast_depth>
        <max_ast_elements>100</max_ast_elements>

        <max_sessions_for_user>4</max_sessions_for_user>

        <readonly>1</readonly>
    </web>
</profiles>

SQL-Driven配置

通过SQL-Driven很容易管理用户的访问权限,上面说到的表级别的控制,很容易实现。与MySQL的操作方式非常类似,此处就不加赘述。参考SQL如下:

sql 复制代码
#创建管理设备表的角色
CREATE ROLE xxx_read_write;
GRANT SELECT, INSERT ON db01.x1_table TO xxx_read_write;
GRANT SELECT ON db01.x2_table TO device_read_write;

CREATE USER user_001 IDENTIFIED WITH sha256_password BY '12xxyy' HOST IP '::/0' DEFAULT ROLE xxx_read_write;

通过以上脚本可以实现对于表级别的权限控制。以上只是抛砖引玉,更多的功能请参考官方的文档。更多的,我们还是推荐使用SQL-Driven来配置权限。

相关推荐
lynnlovemin1 天前
SpringBoot+SSE构建AI实时流式对话系统:原理剖析与代码实战
人工智能·spring boot·后端·ai·sse
这就是佬们吗1 天前
力扣---leetcode48
java·笔记·后端·算法·leetcode·idea
jason.zeng@15022071 天前
spring boot mqtt开发-原生 Paho 手动封装(最高灵活性,完全自定义)
java·spring boot·后端
sunnyday04261 天前
Filter、Interceptor、Spring AOP 的执行顺序详解
java·spring boot·后端·spring
想用offer打牌1 天前
一站式了解Spring AI Alibaba的Memory机制
java·人工智能·后端·spring·chatgpt·系统架构
打工的小王1 天前
Langchain4j(二)RAG知识库
java·后端·ai·语言模型
李慕婉学姐1 天前
【开题答辩过程】以《基于springcloud的空气质量监控管理系统》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
后端·spring·spring cloud
a努力。1 天前
饿了么Java面试被问:一致性哈希的虚拟节点和数据迁移
java·chrome·后端·websocket·面试·职场和发展
0和1的舞者1 天前
非力扣hot100-二叉树专题-刷题笔记(一)
笔记·后端·算法·leetcode·职场和发展·知识
源代码•宸1 天前
Golang原理剖析(GMP调度原理)
开发语言·经验分享·后端·面试·golang·gmp·runnext