首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何为db用户撤消对system.*表的访问?

如何为db用户撤消对system.*表的访问?
EN

Stack Overflow用户
提问于 2022-02-18 09:42:31
回答 1查看 128关注 0票数 0

我正在创建一个具有以下权限的用户:

代码语言:javascript
运行
复制
CREATE USER IF NOT EXISTS U371bqJkJ6sGJ IDENTIFIED WITH sha256_password BY '...O4CqSR1' SETTINGS PROFILE 'default' DEFAULT ROLE user GRANTEES NONE
REVOKE ALL ON *.* FROM U371bqJkJ6sGJ
GRANT SHOW DATABASES ON U371bqJkJ6sGJ.* TO U371bqJkJ6sGJ
GRANT SELECT ON U371bqJkJ6sGJ.* TO U371bqJkJ6sGJ

但出于某种原因,他能读懂系统。

代码语言:javascript
运行
复制
SELECT * FROM system.errors

如何撤消对系统表的访问?谢谢!

EN

回答 1

Stack Overflow用户

发布于 2022-02-18 13:14:36

这里是https://github.com/ClickHouse/ClickHouse/issues/24887的唯一方法

代码语言:javascript
运行
复制
create user foo identified by '123';
revoke all on *.* from foo;

create role RO;

CREATE ROW POLICY ro_query_log_filter  ON system.query_log USING 1 AS RESTRICTIVE TO RO;
CREATE ROW POLICY ro_part_log_filter  ON system.part_log USING 1 AS RESTRICTIVE TO RO;
CREATE ROW POLICY ro_trace_log_filter ON  system.trace_log USING 1 AS RESTRICTIVE TO RO;
CREATE ROW POLICY ro_processes_filter ON  system.processes USING 1 AS RESTRICTIVE TO RO;

grant RO to foo;
ALTER USER foo DEFAULT ROLE RO SETTINGS NONE;


clickhouse-client -u  foo --password=123

select count() from system.trace_log;
0 rows in set.

select count() from system.query_log;
0 rows in set.

select count() from system.tables;
0 rows in set.

select query from system.processes;
0 rows in set
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71171288

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档