一、Keystone介绍

  keystone 是OpenStack的组件之一,用于为OpenStack家族中的其它组件成员提供统一的认证服务,包括身份验证、令牌的发放和校验、服务列表、用户权限的定义等等。云环境中所有的服务之间的授权和认证都需要经过 keystone. 因此 keystone 是云平台中第一个即需要安装的服务。

作为 OpenStack 的基础支持服务,Keystone 做下面这几件事情:
  1.管理用户及其权限
  2.维护 OpenStack Services 的 Endpoint
  3.Authentication(认证)和 Authorization(鉴权)

学习 Keystone,得理解下面这些概念:

User:
  1.User 指代任何使用 OpenStack 的实体,可以是真正的用户,其他系统或者服务。
  2.当 User 请求访问 OpenStack 时,Keystone 会对其进行验证。Horizon 在Identity->Users 管理 User
  3.除了 admin 和 demo,OpenStack 也为 nova、cinder、glance、neutron 服务创建了相应的 User。 admin 也可以管理这些 User。

Credentials:
  Credentials 是 User 用来证明自己身份的信息,可以是:
  1. 用户名/密码
  2. Token
  3. API Key
  4. 其他高级方式

Authentication:
  Authentication 是 Keystone 验证 User 身份的过程。User 访问 OpenStack 时向 Keystone 提交用户名和密码形式的 Credentials,Keystone 验证通过后会给 User 签发一个 Token 作为后续访问的 Credential。

Token:
  Token 是由数字和字母组成的字符串,User 成功 Authentication 后 Keystone 生成 Token 并分配给 User。
  1.Token 用做访问 Service 的 Credential
  2.Service 会通过 Keystone 验证 Token 的有效性
  3.Token 的有效期默认是 24 小时

Project:
  Project 用于将 OpenStack 的资源(计算、存储和网络)进行分组和隔离。

  根据 OpenStack 服务的对象不同,Project 可以是一个客户(公有云,也叫租户)、部门或者项目组(私有云)
  这里请注意:
  1.资源的所有权是属于 Project 的,而不是 User。
  2.在 OpenStack 的界面和文档中,Tenant / Project / Account 这几个术语是通用的,但长期看会倾向使用 Project
  3.每个 User(包括 admin)必须挂在 Project 里才能访问该 Project 的资源。 一个User可以属于多个 Project。
  4.admin 相当于 root 用户,具有最高权限

Service:
  OpenStack 的 Service 包括 Compute (Nova)、Block Storage (Cinder)、Object Storage (Swift)、Image Service (Glance) 、Networking Service (Neutron) 等。每个 Service 都会提供若干个 Endpoint,User 通过 Endpoint 访问资源和执行操作。

Endpoint:
  Endpoint 是一个网络上可访问的地址,通常是一个 URL。Service 通过 Endpoint 暴露自己的 API。 Keystone 负责管理和维护每个 Service 的 Endpoint。

Role:

  安全包含两部分:Authentication(认证)和 Authorization(鉴权)
  Authentication 解决的是“你是谁?”的问题
  Authorization 解决的是“你能干什么?”的问题
  Keystone 借助 Role 实现 Authorization:

二、Keystone基本架构

Token: 用来生成和管理token

Catalog:用来存储和管理service/endpoint

Identity:用来管理tenant/user/role和验证

Policy:用来管理访问权限

三、Keystone(认证服务)安装

1、条件:在安装和配置Identity服务之前,必须创建数据库
  1)登录数据库
  # mysql -uroot -proot
  2)创建keystone数据库:
  MariaDB [(none)]> CREATE DATABASE keystone;
  3)授予对keystone数据库的适当访问权限:  

MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' IDENTIFIED BY 'KEYSTONE_DBPASS';
MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%' IDENTIFIED BY 'KEYSTONE_DBPASS';
# 将KEYSTONE_DBPASS密码设置为自己认为合适的密码

  4)退出数据库访问客户端,exit

2、安装和配置组件
  1)运行以下命令以安装软件包
    # yum install openstack-keystone httpd mod_wsgi
  2)编辑/etc/keystone/keystone.conf文件并完成以下操作

[DEFAULT]

[assignment]

[auth]

[cache]

[catalog]

[cors]

[cors.subdomain]

[credential]

[database]
connection = mysql+pymysql://keystone:KEYSTONE_DBPASS@node1/keystone#数据库用户,用户密码,主机名,数据库名 [domain_config] [endpoint_filter] [endpoint_policy] [eventlet_server] [federation] [fernet_tokens] [healthcheck] [identity] [identity_mapping] [kvs] [ldap] [matchmaker_redis] [memcache] [oauth1] [oslo_messaging_amqp] [oslo_messaging_kafka] [oslo_messaging_notifications] [oslo_messaging_rabbit] [oslo_messaging_zmq] [oslo_middleware] [oslo_policy] [paste_deploy] [policy] [profiler] [resource] [revoke] [role] [saml] [security_compliance] [shadow_users] [signing] [token]
provider = fernet [tokenless_auth] [trust]

  3)同步Identity服务数据库

  # su -s /bin/sh -c "keystone-manage db_sync" keystone

  4)初始化Fernet密钥存储库  

# keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone#为keystone服务创建一个keystone用户
# keystone-manage credential_setup --keystone-user keystone --keystone-group keystone#为keystone用户设置身份信息

  5)引导身份服务

# keystone-manage bootstrap --bootstrap-password ADMIN_PASS \#设置keystone用户的密码
--bootstrap-admin-url http://node1:35357/v3/ \#管理地址端点
--bootstrap-internal-url http://node1:5000/v3/ \#私网地址端点
--bootstrap-public-url http://node1:5000/v3/ \#公网地址端点
--bootstrap-region-id RegionOne#地址的域为RegionOne
# 替换ADMIN_PASS为管理用户的合适密码

3、配置Apache HTTP服务器

  1)编辑/etc/httpd/conf/httpd.conf文件
  ServerName node1 #(本地主机名)
  2)创建/usr/share/keystone/wsgi-keystone.conf文件的链接
  # ln -s /usr/share/keystone/wsgi-keystone.conf /etc/httpd/conf.d/

4、完成安装
  1)启动Apache HTTP服务并将其配置为在系统引导时启动
  # systemctl enable httpd.service
  # systemctl start httpd.service
  2)配置管理帐户
# vim openrc

export OS_USERNAME=admin#登录的用户名
export OS_PASSWORD=ADMIN_PASS#keystone用户的密码
export OS_PROJECT_NAME=admin#项目的名称
export OS_USER_DOMAIN_NAME=Default#用户的默认池
export OS_PROJECT_DOMAIN_NAME=Default#项目的默认池
export OS_AUTH_URL=http://node1:35357/v3#管理的端点地址
export OS_IDENTITY_API_VERSION=3#api接口的版本为3
# 替换ADMIN_PASS为keystone-install-configure命令中使用的密码 。keystone-manage bootstrap

二、OpenStack—keystone组件介绍与安装的更多相关文章

  1. 五、OpenStack—nova组件介绍与安装

    一.nova介绍 Nova 是 OpenStack 最核心的服务,负责维护和管理云环境的计算资源.OpenStack 作为 IaaS 的云操作系统,虚拟机生命周期管理也就是通过 Nova 来实现的. ...

  2. OpenStack—neutron组件介绍与安装

    neutron介绍 Neutron 概述:传统的网络管理方式很大程度上依赖于管理员手工配置和维护各种网络硬件设备:而云环境下的网络已经变得非常复杂,特别是在多租户场景里,用户随时都可能需要创建.修改和 ...

  3. 六、OpenStack—neutron组件介绍与安装

    一.neutron介绍 Neutron 概述:传统的网络管理方式很大程度上依赖于管理员手工配置和维护各种网络硬件设备:而云环境下的网络已经变得非常复杂,特别是在多租户场景里,用户随时都可能需要创建.修 ...

  4. 四、OpenStack—glance组件介绍与安装

    一.glance介绍 Glance是Openstack项目中负责镜像管理的模块,其功能包括虚拟机镜像的查找.注册和检索等. Glance提供Restful API可以查询虚拟机镜像的metadata及 ...

  5. 微服务系列(二)GRPC的介绍与安装

    微服务系列(二)GRPC的介绍与安装 1.GPRC简介 GRPC是Google公司基于Protobuf开发的跨语言的开源RPC框架.GRPC基于HTTP/2协议设计,可以基于一个HTTP/2链接提供多 ...

  6. Openstack keystone组件详解

    OpenStack Keystone Keystone(OpenStack Identity Service)是 OpenStack 框架中负责管理身份验证.服务规则和服务令牌功能的模块.用户访问资源 ...

  7. openstack各组件介绍

    Nova:计算服务,通过虚拟化技术,实现虚拟机的创建,管理,删除,是openstack中最核心的服务. Neutron:网络服务,为虚拟机提供网络连接服务,就像物理机的交换机和路由器一样 Glance ...

  8. vue学习笔记(二)——简单的介绍以及安装

    学习编程需要的是 API+不断地练习^_^ Vue官网:https://cn.vuejs.org/ 菜鸟教程:http://www.runoob.com/vue2/vue-tutorial.html ...

  9. Jmeter(二) Jmeter组件介绍

    一.测试计划 测试的起点,同时也是其他所有组件的容器 二.线程(用户) Setup 线程组:一种特殊类型的线程,可用于执行预测试操作.即执行测试前进行定期线程组的执行 Teardown 线程组:一种特 ...

随机推荐

  1. fastjson存在乱序的问题

    现象及原因 通常来讲,在使用json数据格式时一般不需要要求数据有序.但凡事都有例外,针对查询时序数据这样一个场景,就必须要求服务器端返回的数据是按时间有序的,否则前端在进行数据展示时就会有问题. 项 ...

  2. webpack打包理解

    webpack打包理解(将所有依赖文件打包到一个文件中) 由于前端代码变得越来越多,越来越复杂, 纯粹脚本化的代码书写方式已经不能满足工程化得需求. 前端模块被抽象出来, 不仅仅包括js模块, 其它如 ...

  3. JetBrain server certificate is not trusted 弹出框

    To get rid of the pop up message go to below location and click on Accept non-trusted certificates a ...

  4. 深入理解display属性——前端布局常用重要属性

    小注:display属性在网页布局中非常常见,但经常用到的仅仅是block.inline-block.inline和none等寥寥几个属性值,下面本人将详细介绍display属性的各个方面 定义 di ...

  5. APK改之理 手游修改改编安卓程序工具安装使用教程

    APK改之理 手游修改改编安卓程序工具安装使用教程 --APK破解付费程序 apk改之理是pc平台上一款非常好用的apk反编译工具,他将反编译以及签名等功能集中在一起,并且拥有非常人性化的操作界面,如 ...

  6. arguments.callee.caller

    1.Arguments Arguments是一个类似数组但不是数组的对象,说它类似数组是因为其具有数组一样的访问性质及方式,可以由arguments[n]来访问对应的单个参数的值,并拥有数组长度属性l ...

  7. python元组类型的变量以及字符串类型的变量作为参数进行传值

    今天做selenium元素对象剥离时(我把元素对象都放到了元组类型的变量中,格式:user = (“id”,“X-Auto-2”)),遇到一个元组变量,以及str字符串变量一起作为参数传值的问题,发现 ...

  8. SQL Server 2008 下载及版本说明

    一.下载地址 SQL Server 2008 R2 Enterprise下载地址来源网络整理:MSDN网址,参考: 选中下面链接,放在迅雷中即可下载: ed2k://|file|cn_sql_serv ...

  9. 将mysql中的一张表中的一个字段数据根据条件导入另一张表中

    添加字段:alter table matInformation add facid varchar(99)  default ''; 导入数据:update matInformation m set ...

  10. js 本地缓存localStorage

    .localStorage - 没有时间限制的数据存储 ,,]; localStorage.setItem("stor",arr); console.log(localStorag ...