ON CLUSTER 子句支持在集群中创建用户,参见 分布式 DDL。
身份标识
IDENTIFIED WITH no_passwordIDENTIFIED WITH plaintext_password BY 'qwerty'IDENTIFIED WITH sha256_password BY 'qwerty'orIDENTIFIED BY 'password'IDENTIFIED WITH sha256_hash BY 'hash'orIDENTIFIED WITH sha256_hash BY 'hash' SALT 'salt'IDENTIFIED WITH double_sha1_password BY 'qwerty'IDENTIFIED WITH double_sha1_hash BY 'hash'IDENTIFIED WITH bcrypt_password BY 'qwerty'IDENTIFIED WITH bcrypt_hash BY 'hash'IDENTIFIED WITH ldap SERVER 'server_name'IDENTIFIED WITH kerberosorIDENTIFIED WITH kerberos REALM 'realm'IDENTIFIED WITH ssl_certificate CN 'mysite.com:user'IDENTIFIED WITH ssh_key BY KEY 'public_key' TYPE 'ssh-rsa', KEY 'another_public_key' TYPE 'ssh-ed25519'IDENTIFIED WITH http SERVER 'http_server'orIDENTIFIED WITH http SERVER 'http_server' SCHEME 'basic'IDENTIFIED BY 'qwerty'
在 ClickHouse Cloud 中,默认情况下,密码必须满足以下复杂度要求:
- 长度至少为 12 个字符
- 至少包含 1 个数字
- 至少包含 1 个大写字母
- 至少包含 1 个小写字母
- 至少包含 1 个特殊字符
示例
-
以下用户名为
name1,且无需密码——显然,这样几乎没有什么安全性可言: -
要指定明文密码:
-
最常见的做法是使用经过 SHA-256 哈希处理的密码。当你指定
IDENTIFIED WITH sha256_password时,ClickHouse 会自动为你计算密码哈希。例如:现在,name3用户可以使用my_password登录,但密码实际以上面的哈希值形式存储。系统会在/var/lib/clickhouse/access中创建以下 SQL 文件,并在服务器启动时执行:
-
double_sha1_password通常并不常用,但在配合需要它的客户端时会很有帮助 (例如 MySQL 接口) :ClickHouse 会生成并执行以下查询: -
bcrypt_password是存储密码时最安全的选项。它使用 bcrypt 算法,即使密码哈希泄露,也能有效抵御暴力破解攻击。使用此方法时,密码长度限制为 72 个字符。 bcrypt work factor 参数用于定义计算哈希和验证密码所需的计算量与时间,可在服务器配置中修改:work factor 必须介于 4 到 31 之间,默认值为 12。
-
也可以省略密码类型:
在这种情况下,ClickHouse 将使用服务器配置中指定的默认密码类型:可用的密码类型有:
plaintext_password、sha256_password、double_sha1_password。 -
可以指定多种身份验证方法:
- 较旧版本的 ClickHouse 可能不支持多种身份验证方法的语法。因此,如果 ClickHouse 服务器 中存在此类用户,而又被降级到不支持该语法的版本,这些用户将无法使用,并且部分与用户相关的操作也会失效。为了平稳降级,必须在降级前将所有用户都设置为仅包含一种身份验证方法。或者,如果 server 未按正确流程就已降级,则应删除这些有问题的用户。
- 出于安全原因,
no_password不能与其他身份验证方法同时存在。因此,只有当它是查询中唯一的身份验证方法时,您才可以指定no_password。
用户主机
HOST 部分中按以下方式指定主机:
HOST IP 'ip_address_or_subnetwork'— 用户只能从指定的 IP 地址或某个子网连接到 ClickHouse 服务器。示例:HOST IP '192.168.0.0/16'、HOST IP '2001:DB8::/32'。在生产环境中,建议仅指定HOST IP元素 (IP 地址及其掩码) ,因为使用host和host_regexp可能会带来额外延迟。HOST ANY— 用户可以从任何位置连接。这是默认选项。HOST LOCAL— 用户只能在本地连接。HOST NAME 'fqdn'— 用户主机可以指定为 FQDN。例如:HOST NAME 'mysite.com'。HOST REGEXP 'regexp'— 指定用户主机时,可以使用 pcre 正则表达式。例如:HOST REGEXP '.*\.mysite\.com'。HOST LIKE 'template'— 允许使用 LIKE 运算符来过滤用户主机。例如,HOST LIKE '%'等同于HOST ANY,HOST LIKE '%.mysite.com'会过滤mysite.com域下的所有主机。
@ 语法。示例:
CREATE USER mira@'127.0.0.1'— 等同于HOST IP语法。CREATE USER mira@'localhost'— 等同于HOST LOCAL语法。CREATE USER mira@'192.168.%.%'— 等同于HOST LIKE语法。
VALID UNTIL 子句
YYYY-MM-DD [hh:mm:ss] [timezone] 格式,其中 [timezone] 必须是数值偏移量 (如 +09:00) ,或 UTC、GMT、Z、MSK、MSD 之一;像 Asia/Tokyo 这样的 IANA 具名时区无法识别 (见下方说明) 。默认情况下,该参数的值为 'infinity'。
除非查询中未指定任何身份验证方法,否则 VALID UNTIL 子句只能与某种身份验证方法一起指定。在这种情况下,VALID UNTIL 子句将应用于所有现有的身份验证方法。
示例:
CREATE USER name1 VALID UNTIL '2025-01-01'CREATE USER name1 VALID UNTIL '2025-01-01 12:00:00 UTC'CREATE USER name1 VALID UNTIL '2025-01-01 12:00:00 +09:00'CREATE USER name1 VALID UNTIL 'infinity'CREATE USER name1 IDENTIFIED WITH plaintext_password BY 'no_expiration', bcrypt_password BY 'expiration_set' VALID UNTIL '2025-01-01'
日期时间字符串由
parseDateTimeBestEffort 解析,它只识别时区标记 UTC、GMT、Z、MSK、MSD 以及 +09:00 或 -05:00 这类数值偏移量。不支持 Asia/Tokyo 或 Europe/London 这类 IANA 具名时区;此外,对于实行夏令时的区域,固定偏移量并不等同于 IANA 时区,因此你必须针对要编码的具体日期计算正确的偏移量。GRANTEES 子句
GRANTEES 子句的选项包括:
user— 指定该用户可以向其授予权限的用户。role— 指定该用户可以向其授予权限的角色。ANY— 该用户可以向任何人授予权限。这是默认设置。NONE— 该用户不能向任何人授予权限。
EXCEPT 表达式来排除任意用户或角色。例如,CREATE USER user1 GRANTEES ANY EXCEPT user2。这表示如果 user1 拥有某些通过 GRANT OPTION 授予的权限,它就能够将这些权限授予除 user2 之外的任何人。
示例
mira,并使用密码 qwerty 进行保护:
mira 应在运行 ClickHouse 服务器的主机上启动客户端应用程序。
创建用户账户 john 并分配角色:
john,分配角色,并将其中部分角色设为默认:
john,并允许他将自己的权限授予 jack 用户账户:
john: