openstack的role到底怎么用

news/2024/7/18 12:14:55 标签: openstack

openstack_0">openstack权限

role:角色,在Openstack的keystone数据库中定义,表示一个角色。

rule: 规则,在Policy.yaml中定义,表示一个或多个role的集合。比如在nova中,rule用两种用法

  • 定义role为rule,如nova中最常用的管理员定义"context_is_admin": "role:admin",context_is_admin就变成了一个新的rule
  • 套娃式定义, 比如对member类型的定义"project_member_api": "role:member and project_id:%(project_id)s""rule:admin_or_owner": "rule:project_member_api"这两条,就是典型的套娃式。

policy: 政策,也在Policy.yaml中定义, 如"os_compute_api:os-admin-actions:reset_state": "rule:context_is_admin", 这里面的os_compute_api:os-admin_actions:reset_state就是nova的一个api访问权限控制,即这个policy是可以被管理员进行操作的。即role=admin的角色 。

自定义rule/role

现在我们有一个需求,即一些非管理员也需要获取到一些管理员的权限,来查看一些系统的基本数据 。

创建role

创建一个新的role(access_admin),并且与我们的非管理员租户(business)中的用户(business_user1)进行关联。


# 创建role 
root@controller01:~# openstack role create access_admin
+-------------+----------------------------------+
| Field       | Value                            |
+-------------+----------------------------------+
| description | None                             |
| domain_id   | None                             |
| id          | 2c012da76e0a45929034a70640411ab8 |
| name        | access_admin                     |
| options     | {}                               |
+-------------+----------------------------------+

# 关联role到user(project)中
root@controller01:~# openstack role add  --project business --user business_user1 access_admin 


# 查看role 
root@controller01:~# openstack role list 
+----------------------------------+------------------+
| ID                               | Name             |
+----------------------------------+------------------+
| 0517df1ed58d460289a6dbeae696a023 | heat_stack_owner |
| 2c012da76e0a45929034a70640411ab8 | access_admin     |
| 3b6048bc5dad41a6bde44113de19bc1e | _member_         |
| 6ef8db43497e47caba0f9a25c60b70eb | admin            |
| 8045e17fa24f459dbe46ca283f09c997 | member           |
| d4bb27a44f084b3fbf4d4b65fa26f99a | reader           |
+----------------------------------+------------------+


# 查看user的详细信息

[
  {
    "Role": "2c012da76e0a45929034a70640411ab8",   //access_admin
    "User": "dd921ee91c564e9ab84a7bc603d240c7",
    "Group": "",
    "Project": "e45d946471044d04b9966e295b6c53c9", //
    "Domain": "",
    "System": "",
    "Inherited": false
  },
  {
    "Role": "3b6048bc5dad41a6bde44113de19bc1e",   //_member_
    "User": "dd921ee91c564e9ab84a7bc603d240c7",
    "Group": "",
    "Project": "e45d946471044d04b9966e295b6c53c9",
    "Domain": "",
    "System": "",
    "Inherited": false
  }
]

policy.yaml中添加rule

在nova的Policy.yaml中添加role为rule:access_admin

"access_admin": "role:access_admin"
#"privileges_admin": "rule:context_is_admin or rule:access_admin"  #可以用这种套娃的方式
#"os_compute_api:os-aggregates:index": "rule:privileges_admin"
"os_compute_api:os-aggregates:index": "rule:context_is_admin or rule:access_admin"  //aggregate访问
"os_compute_api:os-services:list": "rule:context_is_admin or rule:access_admin"   //os-service访问
"os_compute_api:os-aggregates:add_host": "rule:context_is_admin or rule:access_admin"   //aggregate添加主机
"os_compute_api:os-aggregates:remove_host": "rule:context_is_admin or rule:access_admin"   //aggregate移出主机

总结

一个user可以关联多个role,并且拥有这个role所拥有的权限,而这个role有什么权限,则是在各个Openstack组件的policy.yaml中定义


http://www.niftyadmin.cn/n/4946488.html

相关文章

Vue-13.NodeJs自动生成的配置和ant-design-vue集成

.browserslistrc(自动生成的) > 1% ## 适用于市场份额大于1%的浏览器 last 2 versions ## 适用于每个浏览器的最近两个版本 not dead ## 排除已不再被支持的浏览器 not ie 11 ## 排除Internet Explorer 11package.j…

PostgreSQL空值的判断

PostgreSQL空值的判断 空值判断非空判断总结 空值判断 -- 查询为空的 is null,sql简写isnull select * from employees where manager_id isnull;select * from employees where manager_id is null;非空判断 -- 查询不为空的 is not null;sql简写notnull select * from empl…

轻松解决docker容器启动闪退

docker run -p 3306:3306 --name mysql8 \ -v /usr/local/mysql/log:/var/log/mysql \ -v /usr/local/mysql/data:/var/lib/mysql \ -v /usr/local/mysql/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD666 -d mysql:8.0.32执行这个命令的时候闪退,其实这个是命令是对你…

Android Drawable转BitmapDrawable再提取Bitmap,Kotlin

Android Drawable转BitmapDrawable再提取Bitmap&#xff0c;Kotlin <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"…

对接海康门禁设备-初始化SDK和登录设备

对接海康门禁设备&#xff0c;初始化SDK /*** author czm* date 2023/2/15*/ public interface HCNetSDK extends Library {public static HCNetSDK getInstance(String sdkPath) { // sdkPath sdk 目录路径System.out.println("sdk_path " sdkPath);HCNetSDK …

千道题中精选出的几道Java集合类面试题

在Java程序员的相关面试中&#xff0c;面试官必然会考核一些专业的技术知识&#xff0c;其中java集合类面试题是必须要做准备的&#xff0c;集合的知识点是Java框架的核心&#xff0c;必然是重要考点之一&#xff0c;所以&#xff0c;熟知并掌握&#xff0c;对于日后我们的面试…

【计算机网络篇】UDP协议

✅作者简介&#xff1a;大家好&#xff0c;我是小杨 &#x1f4c3;个人主页&#xff1a;「小杨」的csdn博客 &#x1f433;希望大家多多支持&#x1f970;一起进步呀&#xff01; UDP协议 1&#xff0c;UDP 简介 UDP&#xff08;User Datagram Protocol&#xff09;是一种无连…

clickhouse Checksum doesn‘t match: 问题修复

1. 问题描述 SQL 错误 [40] [07000]: Code: 40. DB::Exception: Checksum doesnt match: corrupted data. Reference: 50e8c1efa78de2881b725d44b04be1fe. Actual: 161c99eb681ec36b83540ecdd65ad8c9. Size of compressed block: 32846. The mismatch is caused by single bit…