Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >什么是基于角色的安全?

什么是基于角色的安全?

作者头像
用户1217611
发布于 2022-05-06 08:35:56
发布于 2022-05-06 08:35:56
1.3K00
代码可运行
举报
文章被收录于专栏:文渊之博文渊之博
运行总次数:0
代码可运行

介绍

安全角色可以简化SQL Server中的权限。在本文中,解释了固定的服务器数据库角色

管理SQL Server的安全是非常重要的。作为DBA或安全管理员,您需要为登录用户和数据库用户提供访问SQL Server中的资源的权限。SQL Server同时拥有服务器和数据库资源,其中可能需要授予访问权限。可以将对这些资源的访问权限授予单个登录用户或数据库用户,也可以授予角色(登录用户或数据库用户可以是角色的成员)。通过角色授予访问权称为基于角色的安全。

两种类型的角色:固定的或用户定义的。在本文中,我将讨论SQL server提供的不同的固定服务器和数据库角色,以及如何使用这些角色来支持基于角色的安全性,从而简化对不同SQL server资源的访问。在以后的文章中,我将讨论用户定义的服务器和数据库角色。

什么是基于角色的安全?

基于角色的安全是通过角色的成员来提供登录和/或数据库用户访问SQL Server资源的概念。角色是SQL Server中包含成员的对象,很像Windows组包含成员。当登录用户或数据库用户是角色的成员时,他们继承角色的权限。当使用基于角色的安全时,对SQL Server资源的实际访问权限被授予一个角色,而不是特定的登录或用户。当多个登录或用户需要对SQL Server资源进行相同的访问时,基于角色的安全性减少了授予和管理安全性所需的管理工作量。一旦设置了角色,并向其授予了适当的权限,只需将登录或用户添加到角色,就可以为其提供与角色相同的访问权限。如果不使用角色,管理员将需要向每个登录用户或数据库用户授予相同的权限,从而导致额外的管理工作。还可能会出现错误,导致一些登录和用户获得错误的权限集。SQL Server中有两种固定角色:服务器和数据库。固定的服务器角色提供对服务器资源的特定安全访问。相比之下,固定的数据库角色提供对数据库资源的访问。

固定的服务器角色

Fixed Server roles have server-wide scope. They come with a set of canned permissions tied to them. The permissions for server roles can’t be changed or extended.

There are nine different fixed server roles provided with SQL Server, which are shown in Table 1, along with a description. The information in the table is directly from the Microsoft SQL Server documentation.

固定的服务器角色具有服务器范围的作用域。它们附带了一组固定的权限。服务器角色的权限不能更改或扩展。

SQL server提供了9种不同的固定服务器角色,如表1所示,并提供了描述。表中的信息直接来自Microsoft SQL Server 文档

Table 1: 固定服务器橘色

Server Role

Description

sysadmin

sysadmin的成员可以执行服务器中的任何指令和操作。

serveradmin

可以更改服务器范围的配置选项并关闭服务器。

securityadmin

理登录及其属性。它们可以GRANT、DENY和REVOKE服务器级别的权限。如果他们有访问数据库的权限,他们还可以GRANT、DENY和REVOKE数据库级权限。此外,他们可以重置SQL Server登录的密码。   重要提示:授予对数据库引擎的访问权限和配置用户权限的能力允许安全管理员分配大多数服务器权限。securityadmin角色应被视为与sysadmin角色等同。

processadmin

可以终止SQL Server实例中运行的进程。

setupadmin

以使用Transact-SQL语句添加和删除链接服务器。(使用Management Studio时需要sysadmin成员身份。)

bulkadmin

可以执行BULK INSERT语句。

diskadmin

用于管理磁盘文件。

dbcreator

可以创建、修改、删除和恢复任何数据库。

public

每个SQL Server登录都属于公共服务器角色。当服务器主体未被授予或拒绝对安全对象的特定权限时,用户将继承该对象上授予public的权限。仅当您希望对象对所有用户可用时,才为该对象分配公共权限。您不能公开更改会员资格。   注意:public的实现与其他角色不同,可以从public fixed server角色中授予、拒绝或撤销权限。

每个固定的服务器角色提供一组唯一的固定权限,这些权限可以提供对服务器资源的不同类型的访问。固定服务器角色(公共服务器角色除外)关联的权限集不能修改。公共角色与所有其他固定服务器角色略有不同,因为您可以向该角色授予权限。当将权限授予该公共角色时,所有访问SQL Server的用户将继承该公共角色的权限。公共角色是为每次登录提供一些默认权限的好方法。当登录、Windows帐户或Windows组成为这些服务器角色之一的成员时,它们将继承与该角色关联的权限。如果某人需要与服务器角色拥有相同的权限,那么让他们成为角色的成员要比授予他们对与角色关联的每个权限的访问权限容易得多。此外,当您希望向多个登录授予相同的服务器权限时,将每个登录放在相同的服务器角色中可以很容易地实现这一点,确保它们获得完全相同的权限。用户定义的角色也可以添加为服务器角色的成员。关于用户定义角色的讨论将留到另一篇文章中讨论。有许多不同的存储过程、视图和函数可用于处理固定的服务器角色。

如果不确定与服务器角色关联的权限,可以使用系统存储过程sp_srvrolepermission来显示分配给单个固定服务器角色或所有固定服务器角色的权限。清单1中的代码显示了如何使用这个存储过程的两个不同示例。

Listing 1: 使用sp_srvrolepermission 展示单个或者全部角色权限

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
-- Displaying all server role permissions
EXEC sp_srvrolepermission;
GO
-- Displaying permissions for only the dbcreator role
EXEC sp_srvrolepermission @srvrolename = 'dbcreator';

可以使用SQL server Management Studio (SSMS)或TSQL向固定服务器角色添加登录。要使用SSMS,请遵循以下步骤:

连接到一个实例

  1. 展开Security项
  2. 展开“服务器角色”项
  3. 右键单击固定服务器角色,然后单击属性选项
  4. 单击服务器角色属性页面上的Add按钮
  5. 选择要添加到固定服务器角色中的登录或自定义服务器角色
  6. 单击一系列Ok按钮,完成向角色添加新成员的操作

如下:

Figure 1: 添加一个新的成员到固定服务器角色

Alternatively, you can use the TSQL code to add a login to a fixed server role. The code in Listing 2 adds the Red-Gate login to the sysadmin fixed server role.

或者采用下面listing 2 的脚本添加。

Listing 2: 添加新的角色成员.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ALTER SERVER ROLE sysadmin ADD MEMBER [Red-Gate];

Listing 3: 删除成员

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ALTER SERVER ROLE sysadmin DROP MEMBER [Red-Gate];

固定服务器角色是一种很好的方式,可以让dba、安全管理员和操作人员访问他们执行工作职责所需的服务器资源。通过使用服务器角色,可以简化对服务器资源的权限授予。除了固定的服务器角色外,还有固定的数据库角色。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SQL Server安全(3/11):主体和安全对象(Principals and Securables)
在保密你的服务器和数据,防备当前复杂的攻击,SQL Server有你需要的一切。但在你能有效使用这些安全功能前,你需要理解你面对的威胁和一些基本的安全概念。这篇文章提供了基础,因此你可以对SQL Server里的安全功能充分利用,不用在面对特定威胁,不能保护你数据的功能上浪费时间。 通常来说,你通过在对象上分配许可到主体来实现SQL Server里的用户和对象安全。但什么是SQL Server主体?它上面获得哪些许可?在这篇文章里,你会学到各种主体,可以通过许可授权进行SQL Server实例里进行操作和访
逸鹏
2018/04/10
1.3K0
SQL Server安全(3/11):主体和安全对象(Principals and Securables)
SQLServer 服务器角色管理
常用的为:db_datareader(查权限)db_datawriter(增删改权限)db_owner(完全权限)
李郑
2019/12/04
3.2K0
数据库角色
为了帮助管理数据库级别的安全性,SQL Server具有数据库角色。就像服务器角色一样,也有两种不同类型的数据库角色:固定的和用户定义的。固定的数据库角色就像固定的服务器角色一样,这意味着它们拥有一组特定的权限,这些权限不能被更改。
用户1217611
2022/05/06
8100
数据库角色
SqlServer服务器和数据库角色
首先我们来阐述服务器(实例级别)的权限,实例级别和数据库级别权限的最大不同在于:实例级别的权限是直接授权给登录名,而数据库级别的全显示授予数据库用户的,然后数据库用户再与登录名匹配。(再SqlServer中,登录名和用户是两个概念,登录名用于登录到数据库实例,而用户位于数据库之内,用于和登录名匹配) 举例: --指定登录名为dbtester,并且创建test数据库中的用户tester1 execute sp_grantdbaccess ‘dbtester’,'tester1' 在服务器(实例)范围内,对
用户1217611
2018/01/30
2.5K0
SqlServer服务器和数据库角色
SQL Server 权限管理
权限管理是数据库管理中的一个关键方面,它涉及到确定哪些用户或数据库主体(如登录、用户、角色等)有权执行特定的操作。权限管理的目的是确保数据库的安全性,防止未经授权的访问,保护敏感数据和维护数据库的完整性
神秘泣男子
2024/06/03
3010
SQL Server 权限管理
管理SQL Server 2008 数据库角色
角色是SQL Server 2008用来集中管理数据库或者服务器的权限。数据库管理员将操作数据库的权限赋予角色。然后,数据库管理员再将角色赋给数据库用户或者登录账户,从而使数据库用户或者登录账户拥有了相应的权限。 
幽鸿
2020/04/02
2.3K0
管理SQL Server 2008 数据库角色
mssql注入
一些sql扩展 xp_regaddmultistring xp_regdeletekey 删除键名 xp_regdeletevalue 删除键值 xp_regenumkeys 枚举 xp_regenumvalues xp_regread 对于 xp_regremovemultistring xp_regwrite 写 xp_availablemedia 查看驱动器 xp_dirtree 看目录 xp_enumdsn ODBC数据源 xp_loginconfig 一些服务器安全配置的信
赵腰静
2018/03/09
3.7K0
SQL 中如何给指定数据库创建只读用户?
在SQL Server 中,为了保护数据库的安全,需要给不同的使用者开通不同的访问用户,那么如何简单的控制用户的权限呢?下面我们就创建一个只读用户,给大家学习使用。
逆锋起笔
2021/11/02
4.1K0
MsSQL编程入门-待补充
https://www.cnblogs.com/rainman/p/6203065.html
全栈工程师修炼指南
2022/09/29
5860
MsSQL编程入门-待补充
SharePoint 2013 Farm 安装指南——Least Privilege
写过很多关于SharePoint 2013 安装,这是第四篇。可能你会觉得为什么如此简单的安装至于花那么多精力去折腾吗。我的答案是肯定的。知识的积累不是一蹴而就的,而是循序渐进的去学习,每一个阶段都有独立的思考,于是乎第四篇SharePoint 2013的安装记录就诞生了,这边文章我想和大家分享怎样让SharePoint Farm的安全性得到提升。 利用AutoSPSourceBuilder和Autospinstaller自动安装SharePoint Server 2013图解教程——Part 1
用户1161731
2018/01/11
1.9K0
SharePoint 2013 Farm 安装指南——Least Privilege
SQLServer 中的身份验证及登录问题
SQL Server 支持两种身份验证模式,即Windows 身份验证模式和混合模式。
授客
2019/09/12
4.5K0
SQLServer 中的身份验证及登录问题
【DB笔试面试369】在MSSQL中,若希望用户USER1具有数据库服务器上的全部权限,则应将USER1加入到下列哪个角色()
在SQL Server 2000中,若希望用户USER1具有数据库服务器上的全部权限,则应将USER1加入到下列哪个角色()
AiDBA宝典
2022/02/22
7330
GreenPlum的角色权限及客户端认证管理
Greenplum数据库使用roles管理数据库访问权限。角色的概念包含用户和组的概念。 一个角色可以是一个数据库用户、一个数据库组或者两者间距。角色可以拥有数据库对象(例如表),并可以将这些对象上的权限赋予其他角色,依此来控制对对象的访问。角色可以是其他角色的成员,因此成员角色可以继承其父角色的对象权限。
AiDBA宝典
2023/11/06
6310
GreenPlum的角色权限及客户端认证管理
sql server系统表详细说明
在特殊情况下,包含与数据库中的文件相对应的行。该表存储在 master 数据库中。
jack.yang
2025/04/05
1040
从零开始学PostgreSQL (四): 数据库角色
在 PostgreSQL 中,角色(Roles)是用来管理数据库访问权限的一种机制。一个角色可以被认为是一个用户或一组用户。角色可以拥有数据库对象(如表、视图、函数等)并控制其他角色对这些对象的访问权限。角色的主要属性包括:
DBA实战
2024/09/06
2610
从零开始学PostgreSQL (四): 数据库角色
干货 | MSSQL注入和漏洞利用姿势总结
Microsoft SQL Server 是微软开发的关系型数据库管理系统。作为数据库服务器,它是一种软件产品,主要功能是根据其他软件应用程序的请求存储和检索数据,这些应用程序可以在同一台计算机上运行,也可以在网络(包括 Internet)上的另一台计算机上运行。SQL Server 默认开放的端口是 TCP 1433。
HACK学习
2023/01/03
7.1K0
干货 | MSSQL注入和漏洞利用姿势总结
忘记SQL Server 管理员密码不可怕,学会这招就够了
作者 | 邹建,资深数据库专家,精通各项 SQL Server 技术,具有丰富的管理、维护、优化能力以及业务应用经验。他一直热心于技术知识的分享、传播,持续活跃在 CSDN 和 MSDN 社区,曾多年蝉联 CSDN 论坛积分榜首。
数据和云
2018/10/08
2.3K0
忘记SQL Server 管理员密码不可怕,学会这招就够了
利用PowerShell复制SQLServer账户的所有权限
问题   对于DBA或者其他运维人员来说授权一个账户的相同权限给另一个账户是一个很普通的任务。但是随着服务器、数据库、应用、使用人员地增加就变得很枯燥乏味又耗时费力的工作。那么有什么容易的办法来实现这个任务吗? 当然,作为非DBA在测试甚至开发环境也会遇到这种问题,要求授予所有服务器数据库的某个权限给一个人的时候。我们是不是有什么其他办法提高效率? 解决方案   如果这个时候我们网上去搜索解决方案,大多数时候搜到的都是使用T-SQL解决方案,但是这又会产生下面几个小问题: 我们需要到目标服务器上执行这些脚本
用户1217611
2018/01/30
1.9K0
用户、角色和权限
InterSystems IRIS®具有系统级安全性,以及一组与sql相关的额外安全性特性。 在数据库级保护之外,InterSystems SQL安全性提供了额外级别的安全功能。 SQL和系统级安全性之间的一些关键区别是:
用户7741497
2022/06/07
2.2K0
数据库PostrageSQL-数据库角色
PostgreSQL使用角色的概念管理数据库访问权限。一个角色可以被看成是一个数据库用户或者是一个数据库用户组,这取决于角色被怎样设置。角色可以拥有数据库对象(例如,表和函数)并且能够把那些对象上的权限赋予给其他角色来控制谁能访问哪些对象。此外,还可以把一个角色中的成员资格授予给另一个角色,这样允许成员角色使用被赋予给另一个角色的权限。
cwl_java
2020/11/26
1.7K0
推荐阅读
相关推荐
SQL Server安全(3/11):主体和安全对象(Principals and Securables)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验