环境:

免密钥,域名解析

  cat /etc/hosts

  192.168.42.120 controller

  192.168.42.121 compute

  192.168.42.122 storage

安装服务

一、安装openstack软件包

  1.安装openstack python客户端

  yum install python-openstackclient

  2.安装openstack selinux 的组件

  yum install openstack-selinux

二、数据库  

  1.安装mariadb mariadb-server python2-pyMySQL

  yum install mariadb mariadb-server python2-PyMySQL

  2.配置openstack配置文件

  vim /etc/my.cnf.d/openstack.cnf

  [mysqld] bind-address = 192.168.42.120       监听的地址

  default-storage-engine = innodb                     默认数据库引擎

  innodb_file_per_table = on

  max_connections = 4096                           最大链接数(最好写大点)

  collation-server = utf8_general_ci         字符集

  character-set-server = utf8       server端的字符集

  3.重启并设置开机自启数据库

  systemctl restart mariadb.service

  systemctl enable mariadb.service

  4.初始化数据库

  mysql_secure_installation

三、消息队列

  1.安装rabbitmq服务

  yum install rabbitmq-server

  2.重启并设置开机自启rabbitmq

  systemctl restart rabbitmq-srever.service

  systemctl enable rabbitmq-server.service  

  3.添加用户并设置权限,设置为管理员

  rabbitmqctl add_user openstack admin

  rabbitmqctl set_permissions openstack ".*" ".*" ".*"

  rabbitmqctl set_user_tags openstack administrator

  4.浏览器登录查看是否设置成功

  192.168.42.120:15672

四、memcache

  1.安装缓存系统

  yum install memcached python-memcached

  2.编辑配置文件

  vim /etc/sysconfig/mamcached

    OPTIONS="-l 127.0.0.1,::1,controller"

  写域名不写ip的原因:以后ip变化不需要修改配置文件,直接修改/etc/hosts文件即可

  3.重启并设置开机自启

  systemctl restart memcached

  systemctl enable memcached

配置身份认证服务

  一、.安装部署keystone

  1.登录数据库,创建以一个keystone数据库,并设置权限,可以第三方登录

  mysql -uroot -p0330

  create database keystone

  grant all privileges on keystone.* to keystone@localhost identified by "keystone"

  grant all privileges on keystone.* to keystone@'%' identified by "keystone"

  2.安装keystone服务(通过调用http服务对外提供服务)

  yum install openstack-keystone httpd mod_wsgi

  3.修改配置文件

  cp /etc/keystone/keystone.conf /etc/keystone/keystone.conf.bak          先复制再修改

  vim /etc/keystone/keystone.conf

  -rw-r-----. 1 root     keystone    771 6月   3 15:34 keystone.conf

[DEFAULT]
 
[assignment]
 
[auth]
 
[cache]
 
[catalog]
 
[cors]
 
[cors.subdomain]
 
[credential]
 
[database]
 
[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   用fornet组件创建token
 
[tokenless_auth]
 
[trust]

  4.同步数据库

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

  5.创建fornet配置,设置一个keystone用户和keystone组

  keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone

  6.创建keystone用户的身份信息

  keystone-manage credential_setup --keystone-user keystone --keystone-group keystone

  7.keystone服务的服务端点(必须是controller的主机名

  keystone-manage bootstrap --bootstrap-password admin \      admin是openstack用户的密码

   --bootstrap-admin-url http://controller:35357/v3/ \                  管理网的服务端点:主机名:端口号:api版本

   --bootstrap-internal-url http://controller:5000/v3/ \     内部

   --bootstrap-public-url http://controller:5000/v3/ \        公共

   --bootstrap-region-id RegionOne

  8.编辑apache服务

  vim /etc/httpd/conf/httpd.conf

    ServerName controller

  9.通过wsgi这个模块调用apache(把模块链接到keystone的配置文件夹下)

  ln -s /usr/share/keystone/wsgi-keystone.conf /etc/httpd/conf.d/

  10.重启并设置开机自启httpd  

  systemctl restart httpd

  systemctl enable httpd

  11.创建admin用户的环境变量

  vim openrc

   export OS_USERNAME=admin          宣告变量OS_USERNAME的值是admin

   export OS_PASSWORD=admin         密码是admin

   export OS_PROJECT_NAME=admin         项目是admin

   export OS_USER_DOMAIN_NAME=Default     所处在的domain域

   export OS_PROJECT_DOMAIN_NAME=Default      项目域的名字

   export OS_AUTH_URL=http://controller:35357/v3     服务端点

   export OS_IDENTITY_API_VERSION=3     API版本

二、创建domain, projects, users, and roles

每次使用openstack命令之前必须宣告环境变量

  1.创建项目

  openstack project create --domain default \ --description "Service Project" service          域名叫default  项目service

  2.创建一个名为demo的项目,域名叫default

  openstack project create --domain default \ --description "Demo Project" demo

  openstack project list                查看项目列表

  3.创建demo的用户,处在default域中,弹出一个交互式的界面

  openstack user create --domain default \ --password-prompt demo

  openstack user list                   查看用户列表

  4.创建一个user角色

  openstack role create user         普通用户

  5.将一个demo项目里的demo用户的角色设为user

  openstack role add --project demo --user demo user

  6.取消环境变量的值

  unset OS_AUTH_URL OS_PASSWORD

  7.验证

  openstack --os-auth-url http://controller:35357/v3 \             keystone的服务端点

   --os-project-domain-name default                                      登录的项目域名default

   --os-user-domain-name default \                                        用admin项目里的admin用户登录

   --os-project-name admin --os-username admin token issue          采用token的方式验证

  出现交互式界面输入admin

  以上keystone服务部署完成。

openstack部署keystone的更多相关文章

  1. openstack 之~keystone部署

    第一:版本信息 官网http://docs.openstack.org/newton/install-guide-rdo/keystone.html 我们按照Newton这个版本来部署,opensta ...

  2. openstack之keystone部署

    前言 openstack更新频率是挺快的,每六个月更新一次(命名是是以A-Z的方式,Austin,Bexar...Newton).博主建议大家先可一种版本研究,等某一版本研究透彻了,在去研究新的版本. ...

  3. Openstack组件部署 — keystone(domain, projects, users, and roles)

    目录 目录 前文列表 Create a domain projects users and roles domain projects users and roles的意义和作用 Create the ...

  4. Openstack组件部署 — Keystone Install & Create service entity and API endpoints

    目录 目录 前文列表 Install and configure Prerequisites 先决条件 Create the database for identity service 生成一个随机数 ...

  5. Openstack部署工具

    Openstack发展很猛,很多朋友都很认同,2013年,会很好的解决OpenStack部署的问题,让安装,配置变得更加简单易用. 很多公司都投入人力去做这个,新浪也计划做一个Openstack的is ...

  6. 《OpenStack部署实践》

    <OpenStack部署实践> 基本信息 作者: 张子凡 丛书名: 图灵原创 出版社:人民邮电出版社 ISBN:9787115346797 上架时间:2014-2-27 出版日期:2014 ...

  7. OpenStack之Keystone模块

    一.Keystone介绍 OpenStack Identity(Keystone)服务为运行OpenStack Compute上的OpenStack云提供了认证和管理用户.帐号和角色信息服务,并为Op ...

  8. 网易OpenStack部署运维实战

    OpenStack自2010年项目成立以来,已经有超过200个公司加入了 OpenStack 项目,目前参与 OpenStack 项目的开发人员有 17,000+,而且这些数字还在增加,作为一个开源的 ...

  9. OpenStack核心组件-keystone

    1. Keystone介绍 keystone是OpenStack的组件之一,用于为OpenStack家族中的其它组件成员提供统一的认证服务,包括身份验证.令牌的发放和校验.服务列表.用户权限的定义等等 ...

随机推荐

  1. python常用模块:包的使用、init作用、相对导入绝对导入与内置函数

    今天主要讲的内容有: 一.包的详解二.相对导入和绝对导入三.内置模块补充 一.包的详解 1.包是什么 包其实也是一个模块,只不过是一个大的模块下包含一堆模块的载体 本质上也是一个文件夹,与普通文件的区 ...

  2. 9.0.网络编程_IO 通信模型

    5. IO 通信模型 网络通信的本质是网络间的数据 IO.只要有 IO,就会有阻塞或非阻塞的问题,无论这个 IO 是网络的,还是硬盘的.原因在于程序是运行在系统之上的, 任何形式的 IO 操作发起都需 ...

  3. Sass的混合-@mixin,@include

    1,无参数,有参数和带默认值参数的@mixin声明sass文件内容: //带参数,默认50@mixin opa($opa:50){ opacity: $opa / 100; filter:alpha( ...

  4. Python的函数式编程: map, reduce, sorted, filter, lambda

    Python的函数式编程 摘录: Python对函数式编程提供部分支持.由于Python允许使用变量,因此,Python不是纯函数式编程语言. 函数是Python内建支持的一种封装,我们通过把大段代码 ...

  5. UVa101 The Blocks Problem(不定长数组vector)

    The Blocks Problem 书上的一道例题,代码思路比较清晰,可以看懂. 相关知识: 若a是一个vector,则: a.size():读取它的大小 a.resize():改变大小 a.pus ...

  6. bom操作,事件与jquery

    BOM操作中 window关键字 可以不写 DOM操作 学习如何查找节点 如何查找标签 选择器 事件 当符合某个条件下 自动触发的动作/响应 js绑定事件的方式 方式1 不推荐使用 <butto ...

  7. Docker安装过程

    安装 Docker 源自:http://www.runoob.com/docker/centos-docker-install.html 从 2017 年 3 月开始 docker 在原来的基础上分为 ...

  8. RAID的多种实现

    RAID的诞生 由加利福尼亚大学伯克利分校(University of California-Berkeley)在1988年,发表的文章:"A Case for Redundant Arra ...

  9. Shell登陆

    Shell登录信息 注:只对本地终端起作用,远程终端不起作用(也就是说这个文件对远程登录是无效的). 修改后: 输出: 注:这里在配置文件中添加\l之后会显示终端(这里为终端1),按住Alt+F2可以 ...

  10. HDU - 3586 Information Disturbing 树形dp二分答案

    HDU - 3586 Information Disturbing 题目大意:从敌人司令部(1号节点)到前线(叶子节点)的通信路径是一个树形结构,切断每条边的联系都需要花费w权值,现在需要你切断前线和 ...