支持的版本: 当前 (17) / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1

21.2. 角色属性 #

数据库角色可以拥有许多属性,这些属性定义了其权限并与客户端身份验证系统交互。

登录权限

只有具有 LOGIN 属性的角色才能用作数据库连接的初始角色名称。 具有 LOGIN 属性的角色可以被认为是与数据库用户相同。要创建具有登录权限的角色,请使用以下任一方法:

CREATE ROLE name LOGIN;
CREATE USER name;

(CREATE USERCREATE ROLE 等效,区别在于 CREATE USER 默认包含 LOGIN,而 CREATE ROLE 不包含。)

超级用户状态

数据库超级用户会绕过所有权限检查,除了登录权限。这是一个危险的权限,不应草率使用;最好以非超级用户的角色完成大部分工作。要创建新的数据库超级用户,请使用 CREATE ROLE name SUPERUSER。 您必须以已经是超级用户的角色执行此操作。

数据库创建

必须明确授予角色创建数据库的权限(超级用户除外,因为他们会绕过所有权限检查)。要创建这样的角色,请使用 CREATE ROLE name CREATEDB

角色创建

必须明确授予角色创建更多角色的权限(超级用户除外,因为他们会绕过所有权限检查)。要创建这样的角色,请使用 CREATE ROLE name CREATEROLE。具有 CREATEROLE 权限的角色可以更改和删除已使用 ADMIN 选项授予 CREATEROLE 用户的角色。当非超级用户的 CREATEROLE 用户创建新角色时,会自动发生这种授予,因此默认情况下,CREATEROLE 用户可以更改和删除他们创建的角色。更改角色包括可以使用 ALTER ROLE 进行的大多数更改,例如,更改密码。它还包括可以使用 COMMENTSECURITY LABEL 命令对角色进行的修改。

但是,CREATEROLE 不会赋予创建 SUPERUSER 角色的能力,也不会赋予对已存在的 SUPERUSER 角色的任何权力。此外,CREATEROLE 不会赋予创建 REPLICATION 用户的能力,也不会赋予授予或撤销 REPLICATION 权限的能力,也不会赋予修改此类用户的角色属性的能力。但是,它允许对 REPLICATION 角色使用 ALTER ROLE ... SETALTER ROLE ... RENAME,以及使用 COMMENT ON ROLESECURITY LABEL ON ROLEDROP ROLE。最后,CREATEROLE 不会赋予授予或撤销 BYPASSRLS 权限的能力。

启动复制

必须明确授予角色启动流复制的权限(超级用户除外,因为他们会绕过所有权限检查)。用于流复制的角色还必须具有 LOGIN 权限。要创建这样的角色,请使用 CREATE ROLE name REPLICATION LOGIN

密码

只有当客户端身份验证方法要求用户在连接到数据库时提供密码时,密码才重要。passwordmd5 身份验证方法会使用密码。数据库密码与操作系统密码是分开的。在创建角色时使用 CREATE ROLE name PASSWORD 'string' 指定密码。

权限继承

默认情况下,角色会继承其所属角色的权限。但是,要创建默认情况下不继承权限的角色,请使用 CREATE ROLE name NOINHERIT。或者,可以使用 WITH INHERIT TRUEWITH INHERIT FALSE 覆盖单个授予的继承。

绕过行级安全性

必须明确授予角色绕过每个行级安全 (RLS) 策略的权限(超级用户除外,因为他们会绕过所有权限检查)。要创建这样的角色,请以超级用户身份使用 CREATE ROLE name BYPASSRLS

连接限制

连接限制可以指定角色可以建立的并发连接数。 -1(默认值)表示没有限制。在创建角色时使用 CREATE ROLE name CONNECTION LIMIT 'integer' 指定连接限制。

可以使用 ALTER ROLE 在创建后修改角色的属性。 有关详细信息,请参阅 CREATE ROLEALTER ROLE 命令的参考页面。

角色还可以具有许多在 第 19 章 中描述的运行时配置设置的角色特定默认值。例如,如果出于某种原因您想在每次连接时禁用索引扫描(提示:不是一个好主意),您可以使用

ALTER ROLE myname SET enable_indexscan TO off;

这将保存设置(但不会立即设置)。在此角色后续的连接中,它会表现得好像在会话开始之前执行了 SET enable_indexscan TO off 一样。您仍然可以在会话期间更改此设置;它只会是默认设置。要删除特定于角色的默认设置,请使用 ALTER ROLE rolename RESET varname。请注意,附加到没有 LOGIN 权限的角色的角色特定默认值是相当无用的,因为它们永远不会被调用。

当非超级用户使用 CREATEROLE 权限创建角色时,创建的角色会自动授予回创建用户,就像引导超级用户执行了命令 GRANT created_user TO creating_user WITH ADMIN TRUE, SET FALSE, INHERIT FALSE 一样。由于 CREATEROLE 用户只有在该角色上具有 ADMIN OPTION 时才能对现有角色行使特殊权限,因此此授予足以允许 CREATEROLE 用户管理他们创建的角色。但是,由于它是使用 INHERIT FALSE, SET FALSE 创建的,因此 CREATEROLE 用户不会继承创建角色的权限,也无法使用 SET ROLE 访问该角色的权限。但是,由于任何对角色具有 ADMIN OPTION 的用户都可以将该角色的成员资格授予任何其他用户,因此 CREATEROLE 用户可以通过简单地使用 INHERIT 和/或 SET 选项将该角色授予回他们自己来获得对创建角色的访问权限。因此,默认情况下不继承权限并且默认情况下不授予 SET ROLE 是为了防止意外,而不是安全功能。另请注意,由于此自动授予是由引导超级用户授予的,因此 CREATEROLE 用户无法删除或更改它;但是,任何超级用户都可以撤销它、修改它和/或向其他 CREATEROLE 用户发出额外的此类授予。任何 CREATEROLE 用户在任何给定时间对角色具有 ADMIN OPTION 都可以管理它。

提交更正

如果您在文档中发现任何不正确的内容,与您对特定功能的体验不符或需要进一步澄清的内容,请使用此表单来报告文档问题。