【实验】阿里云大数据助理工程师认证(ACA)- ACA认证配套实验-05-安全与权限基本操作(下)

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 【实验】阿里云大数据助理工程师认证(ACA)- ACA认证配套实验-05-安全与权限基本操作(下)

2.2 实验:角色管理与授权


提示:本章节所需操作均需使用阿里云主账号或者具有项目admin权限的用户进行实验,实验环境需在各阿里云主账号对应的项目中进行。


1、用户A新建一个角色 reader:

create role reader;

2、用户A赋予角色reader几张表的读权限:


grant describe, select on table dual to role reader;
grant describe, select on table t_test to role reader;


3、用户A查看角色的权限:


desc role reader;


4、用户A查看B用户拥有的权限:


show grants for ALIYUN$huiongshan@126.com;


5、用户A将角色reader赋予用户B:


grant reader to ALIYUN$huiongshan@126.com;


6、用户A查看B用户拥有的权限:


show grants for ALIYUN$huiongshan@126.com;


7、用户A赋予角色reader另外几张表的读权限:

grant describe, select on table t_tunnel to role reader;
grant describe, select on table t_tunnel_p to role reader;

8、用户A查看角色的权限和使用情况:


desc role reader;


9、用户A查看B用户拥有的权限:


show grants for ALIYUN$huiongshan@126.com;


10、用户A删除角色reader(会报错,删除失败):


drop role reader;


11、用户A移除用户B(会报错,移除失败):


remove user ALIYUN$huiongshan@126.com;


12、用户A查看角色的权限和使用情况:


desc role reader;


13、用户A从用户B收回角色:


revoke reader from ALIYUN$huiongshan@126.com;


14、用户A删除角色reader:


drop role reader;


15、用户A移除用户B:


remove user ALIYUN$huiongshan@126.com;


2.3 实验:鉴权模型查看与管理


提示:本章节所需操作均需使用阿里云主账号或者具有项目admin权限的用户进行实验,实验环境需在各阿里云主账号对应的项目中进行。


1、用户A查看当前项目的鉴权模型:

show SecurityConfiguration;

2、用户A赋予用户B建表的权限:


add user ALIYUN$huiongshan@126.com;
grant createtable on project Lab_class to user ALIYUN$huiongshan@126.com;


3、用户B建表:


create table Lab_class.t_test_sg (id int);
desc Lab_class.t_test_sg;
select count(*) from Lab_class.t_test_sg;


image.png

image.png

image.png


4、用户A修改鉴权模型,将ObjectCreatorHasAccessPermission改为false:

set ObjectCreatorHasAccessPermission=false;
show SecurityConfiguration;


5、用户B访问Lab_class.t_test_sg(报错,权限不足):


desc Lab_class.t_test_sg;
select count(*) from Lab_class.t_test_sg;


image.png

image.png


6、用户B删除Lab_class.t_test_sg(报错,权限不足):


drop table Lab_class.t_test_sg;


image.png


7、用户A修改鉴权模型,将ObjectCreatorHasAccessPermission改为true:

set ObjectCreatorHasAccessPermission=true;
show SecurityConfiguration;

8、用户B访问Lab_class.t_test_sg:


desc Lab_class.t_test_sg;
select count(*) from Lab_class.t_test_sg;


image.png

image.png


9、用户B删除Lab_class.t_test_sg:


drop table Lab_class.t_test_sg;


image.png


10、用户A收回用户B建表的权限:

revoke createtable on project Lab_class from user ALIYUN$huiongshan@126.com;
remove user ALIYUN$huiongshan@126.com;


2.4 实验:基于标签的安全控制


提示:本章节所需操作均需使用阿里云主账号或者具有项目admin权限的用户进行实验,实验环境需在各阿里云主账号对应的项目中进行。


1、用户A查看当前项目的鉴权模型:

show SecurityConfiguration;


2、如果LabelSecurity的值为false,则需要将它设置成true:


set LabelSecurity=true;


3、增加用户B到当前项目Lab_class,并设置安全许可标签:


(默认安全标签为0,我们将用户B(ALIYUN$huiongshan@126.com) 安全许可标签设置为3)
add user ALIYUN$huiongshan@126.com;
set label 3 to user ALIYUN$huiongshan@126.com;
grant select,describe on table t_tunnel to user ALIYUN$huiongshan@126.com;


4、用户B此时可以访问Lab_class.t_tunnel:


select * from Lab_class.t_tunnel;


image.png


5、用户A将t_tunnel的id敏感等级提高成4:


set label 4 to table t_tunnel(id);


image.png


6、用户B此时因安全等级低,无法访问敏感等级高的数据Lab_class.t_tunnel:


select * from Lab_class.t_tunnel;


image.png


7、用户A将t_tunnel中的id字段的敏感度调整到3:


set label 3 to table t_tunnel(id);


8、用户B此时可以访问Lab_class.t_tunnel中敏感级别不大于3的列id:


select id from Lab_class.t_tunnel;


image.png

9、用户A可以设置对低权限用户B进行临时授权可以访问高敏感级别的表t_tunnel_p:


set label 3 to user ALIYUN$huiongshan@126.com;
grant select,describe on table t_tunnel_p to user ALIYUN$huiongshan@126.com;
set label 5 to table t_tunnel_p(name);
set label 4 to table t_tunnel_p (id);
grant label 4 on table t_tunnel_p to user ALIYUN$huiongshan@126.com with exp 1;


10、用户B此时可以访问Lab_class.t_tunnel_p中敏感级别不大于4的所有列:


select id from Lab_class.t_tunnel_p;
select name from Lab_class.t_tunnel_p;


image.png

image.png


11、用户A查看当前有权限访问t_tunnel_p的表的用户列表:


show label grants on table t_tunnel_p;


12、用户A查看用户B有权限访问的所有的表的列表:


show grants for ALIYUN$huiongshan@126.com;


13、用户A收回用户B权限,并从项目中移除用户B,并复原项目的鉴权模型:

revoke describe,select on table t_tunnel from user ALIYUN$huiongshan@126.com;
revoke describe,select on table t_tunnel_p from user ALIYUN$huiongshan@126.com;
remove user ALIYUN$huiongshan@126.com;
set LabelSecurity=false;
show SecurityConfiguration;


2.5 实验:跨项目空间的资源分享


提示:本章节所需操作均需使用阿里云主账号或者具有项目admin权限的用户进行实验,实验环境需在各阿里云主账号对应的项目中进行。


1、用户A创建package,并将表t_tunnel以及表t_tunnel_p的访问权限添加到该package:

create package pk_tunnel_read;
add table t_tunnel to package pk_tunnel_read with privileges select;
add table t_tunnel_p to package pk_tunnel_read with privileges describe;

2、用户A将pk_tunnel_read赋给用户B所在的项目Star_research:


allow project Star_research to install package pk_tunnel_read;


3、用户B查看所在项目空间可用的package:


show packages;


image.png

4、用户B安装pk_tunnel_read:


install package Lab_class.pk_tunnel_read;
show packages;
desc package Lab_class.pk_tunnel_read;


image.png

image.png

image.png


5、用户B访问package中包含的资源:

select * from Lab_class.t_tunnel;
desc Lab_class.t_tunnel_p;


image.png

image.png


6、用户B卸载package:


uninstall package Lab_class.pk_tunnel_read;


image.png

7、用户A删除package:


drop package pk_tunnel_read;


2.6 实验:项目空间保护


提示:本章节所需操作均需使用阿里云主账号或者具有项目admin权限的用户进行实验,实验环境需在各阿里云主账号对应的项目中进行。


1、用户A查看当前项目的鉴权模型,确认目前的ProjectProtection处于false状态:


show SecurityConfiguration;


2、增加用户B到当前项目Lab_class,并赋予表t_tunnel的读写权限:


add user ALIYUN$huiongshan@126.com;
grant all on table t_tunnel to user ALIYUN$huiongshan@126.com;
grant select on table dual to user ALIYUN$huiongshan@126.com;


3、用户B操作表t_tunnel:可以读取记录,或者插入数据


select * from Lab_class.t_tunnel;
insert into table Lab_class.t_tunnel select  '1' from Lab_class.dual;


image.png

image.png


4、用户B甚至可以把表中的数据搬到本地的项目中来:


create table iris as select * from Lab_class.t_tunnel;


image.png


5、用户A为了防止数据流出,打开项目保护选项:ProjectProtection:


set ProjectProtection=true;


6、用户B对t_tunnel的操作都被禁止,需要联系Lab_class的owner:

select * from Lab_class.t_tunnel;
insert into table Lab_class.t_tunnel select  '-2' from Lab_class.t_tunnel;
create table iris_again as select * from Lab_class.t_tunnel;

image.png

image.png

image.png


7、用户A为用户B设置例外:

set ProjectProtection=true with exception c:\pf_try;
其中,pf_try为一个授权策略文件(ANSI/ANSII格式),内容如下:
{
“Version”: “1”,
“Statement”:[{
"Effect":"Allow",
"Principal":"ALIYUN$huiongshan@126.com",
"Action":["odps:Select"],
"Resource":["acs:odps:*:projects/Lab_class/tables/t_tunnel"],
"Condition":{
    "StringEquals": {
        "odps:TaskType":"SQL"
    } }

}]

}

8、用户B可以对表Lab_class.t_tunnel进行正常操作:

select * from Lab_class.t_tunnel;
create table iris_again as select * from Lab_class.t_tunnel;

image.png

image.png

9、用户A设置无例外项目保护:


set ProjectProtection=true;


第 3 章:实验总结


3.1 实验总结


通过本次实验,了解MaxCompute的用户授权、角色管理、鉴权模型、基于标签的安全控制、项目空间资源分享、项目空间保护等配置是如何实现,熟练掌握各种权限配置的方法,在后续的工作学习中,通过已学的配置方法,可较为方便的实现资源共享。

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
目录
相关文章
|
2月前
|
存储 安全 大数据
大数据隐私保护:用户数据的安全之道
【10月更文挑战第31天】在大数据时代,数据的价值日益凸显,但用户隐私保护问题也愈发严峻。本文探讨了大数据隐私保护的重要性、面临的挑战及有效解决方案,旨在为企业和社会提供用户数据安全的指导。通过加强透明度、采用加密技术、实施数据最小化原则、加强访问控制、采用隐私保护技术和提升用户意识,共同推动大数据隐私保护的发展。
|
2月前
|
存储 安全 大数据
|
5月前
|
存储 监控 安全
大数据架构设计原则:构建高效、可扩展与安全的数据生态系统
【8月更文挑战第23天】大数据架构设计是一个复杂而系统的工程,需要综合考虑业务需求、技术选型、安全合规等多个方面。遵循上述设计原则,可以帮助企业构建出既高效又安全的大数据生态系统,为业务创新和决策支持提供强有力的支撑。随着技术的不断发展和业务需求的不断变化,持续优化和调整大数据架构也将成为一项持续的工作。
|
5月前
|
安全 关系型数据库 MySQL
揭秘MySQL海量数据迁移终极秘籍:从逻辑备份到物理复制,解锁大数据迁移的高效与安全之道
【8月更文挑战第2天】MySQL数据量很大的数据库迁移最优方案
889 17
|
6月前
|
分布式计算 安全 大数据
HAS插件式Kerberos认证框架:构建安全可靠的大数据生态系统
在教育和科研领域,研究人员需要共享大量数据以促进合作。HAS框架可以提供一个安全的数据共享平台,确保数据的安全性和合规性。
|
6月前
|
SQL 安全 大数据
如何安全的大数据量表在线进行DDL操作
如何安全的大数据量表在线进行DDL操作
88 0
如何安全的大数据量表在线进行DDL操作
|
6月前
|
存储 分布式计算 DataWorks
MaxCompute产品使用合集之表被删除重建后如何查到之前的权限信息
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
6月前
|
弹性计算 分布式计算 大数据
MaxCompute产品使用合集之如何将用户A从项目空间A申请的表权限需要改为用户B
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
6月前
|
分布式计算 运维 DataWorks
MaxCompute操作报错合集之用户已在DataWorks项目中,并有项目的开发和运维权限,下载数据时遇到报错,该如何解决
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
|
7月前
|
机器学习/深度学习 自然语言处理 监控
金融行业的大数据风控模型:构建安全高效的信用评估体系
金融机构借助大数据风控提升信贷效率,通过数据收集、清洗、特征工程、模型构建与评估来识别风险。关键技术涉及机器学习、深度学习、NLP和实时处理。以下是一个Python风控模型构建的简例,展示了从数据预处理到模型训练、评估的过程,并提及实时监控预警的重要性。该文旨在阐述大数据风控的核心要素和关键技术,并提供基础的代码实现概念。【6月更文挑战第23天】
1098 8

热门文章

最新文章