受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

21.5. 预定义角色 #

PostgreSQL提供了一组预定义角色,它们提供对某些常见且需要权限的能力和信息的访问。管理员(包括具有CREATEROLE权限的角色)可以把这些角色GRANT给其环境中的用户和/或其他角色,从而让这些用户获得所指定的能力和信息。例如:

GRANT pg_signal_backend TO admin_user;

Warning

授予这些角色时应当谨慎,确保它们只在需要时使用,并理解这些角色会授予对敏感信息的访问。

下文介绍这些预定义角色。请注意,随着将来增加更多能力,各个角色的具体权限可能会发生变化。管理员应关注发行说明中的变更。

pg_checkpoint #

pg_checkpoint允许执行CHECKPOINT命令。

pg_create_subscription #

pg_create_subscription允许在数据库上具有CREATE权限的用户执行CREATE SUBSCRIPTION

pg_database_owner #

pg_database_owner始终恰好有一个隐式成员:当前数据库的拥有者。它不能被授予任何角色中的成员资格,也不能有任何角色被授予pg_database_owner中的成员资格。不过,和其他角色一样,它可以拥有对象并获得访问权限授权。因此,一旦pg_database_owner在某个模板数据库中拥有权限,由该模板实例化的每个数据库的拥有者都将拥有这些权限。最初,这个角色拥有public模式,因此每个数据库拥有者都管理该模式在本数据库中的使用。

pg_maintain #

pg_maintain允许在所有关系上执行VACUUMANALYZECLUSTERREFRESH MATERIALIZED VIEWREINDEX 以及LOCK TABLE,其效果就像对这些对象拥有MAINTAIN权限一样。

pg_monitor
pg_read_all_settings
pg_read_all_stats
pg_stat_scan_tables #

这些角色旨在让管理员能够方便地为监控数据库服务器配置一个角色。它们授予一组常见权限,使该角色能够读取各种有用的配置设置、统计信息以及其他通常仅限超级用户查看的系统信息。

pg_monitor允许读取或执行各种监控视图和函数。该角色是pg_read_all_settingspg_read_all_statspg_stat_scan_tables的成员。

pg_read_all_settings允许读取所有配置变量,即使是那些通常仅对超级用户可见的变量。

pg_read_all_stats允许读取所有 pg_stat_* 视图,并使用各种与统计信息相关的扩展,即使是那些通常仅对超级用户可见的扩展。

pg_stat_scan_tables允许执行可能在表上持有ACCESS SHARE锁并持续较长时间的监控函数(例如pgrowlocks(text),见pgrowlocks扩展)。

pg_read_all_data
pg_write_all_data #

pg_read_all_data允许读取所有数据(表、视图、序列),其效果就像对这些对象拥有SELECT权限并对所有模式拥有USAGE权限一样。该角色不会绕过行级安全(RLS)策略。如果正在使用 RLS,管理员可能希望对被授予此角色的角色设置BYPASSRLS

pg_write_all_data允许写入所有数据(表、视图、序列),其效果就像对这些对象拥有INSERTUPDATEDELETE权限并对所有模式拥有USAGE权限一样。该角色不会绕过行级安全(RLS)策略。如果正在使用 RLS,管理员可能希望对被授予此角色的角色设置BYPASSRLS

pg_read_server_files
pg_write_server_files
pg_execute_server_program #

这些角色旨在允许管理员创建受信任但非超级用户的角色,使其能够以数据库运行所用操作系统用户的身份访问文件并在数据库服务器上运行程序。它们在直接访问文件时会绕过所有数据库级权限检查,并且可被用来获得超级用户级别的访问能力。因此,向用户授予这些角色时必须极其谨慎。

pg_read_server_files允许使用COPY和其他文件访问函数,从服务器上数据库可访问的任何位置读取文件。

pg_write_server_files允许使用COPY和其他文件访问函数,向服务器上数据库可访问的任何位置写入文件。

pg_execute_server_program允许使用COPY和其他允许执行服务器端程序的函数,以数据库运行所用用户的身份在数据库服务器上执行程序。

pg_signal_autovacuum_worker #

pg_signal_autovacuum_worker允许向自动清理工作进程发送信号,以取消当前表的清理操作或终止其会话。见Section 9.28.2

pg_signal_backend #

pg_signal_backend允许向另一个后端发送信号,以取消查询或终止其会话。注意,这个角色不允许向由超级用户拥有的后端发送信号。见Section 9.28.2

pg_use_reserved_connections #

pg_use_reserved_connections允许使用通过reserved_connections保留的连接槽。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。