设为首页 收藏本站
查看: 986|回复: 0

[经验分享] 云计算之openstack(N版)keystone镜像服务最佳实践

[复制链接]
发表于 2018-5-31 10:34:27 | 显示全部楼层 |阅读模式
1.openstack简介
Openstack是一个项目,该项目支持所有类型的云环境的一个开源云计算平台,该项目的目的是为了实现简单,大规模可扩展性,以及丰富功能集,来自世界各地的云计算专家项目作出贡献。Openstack提供了一个基础架构即服务(Iaas)并通过各种配套服务的解决方案,每个服务提供一个应用编程接口来完成整个openstack的结合。
架构图如下:
   DSC0000.png
相关服务介绍:
服务名称

项目名称

描述

Dashboard
Horizon
基于openstackAPI接口使用Django开发的web管理
Compute
Nova
通过虚拟化技术提供计算资源池
Networking
Neutron
实现了虚拟机的网络资源管理
Storage(存储)

Object Storage
Swift
对象存储,适用于“一次写入、多次读取”
Block Storage
Cinder
块存储,提供存储资源池
Share Service(共享服务)

Identity Service
Keystone
认证服务
Image Service
Glance
提供虚拟镜像的注册和存储管理
Telemetry
Ceilometer
提供监控和数据采集、计算服务
Higher-level services(高层服务)

Orchestration
Heat
自动化部署的组件
DatabaseService
Trove
提供数据库应用服务
部署服务示例图如下:
   DSC0001.png


2.openstack的搭建部署
2.1部署环境说明
2.1.1基础实验环境:
软硬件:VMware 12pro  CentOS7.2 ;
两台虚拟机分别作为控制节点和计算节点;
控制节点:2核处理器,4GB内存,50G硬盘
计算节点:1核处理器,2GB内存,50G硬盘
计算节点开启虚拟机化功能以便创建虚拟机。
服务的部署架构图如下:
   DSC0002.png
2.1.2网络时间协议(NTP)
确保两台主机的时间同步:ntpdatetime1.aliyun.com
2.1.3两个节点需要安装的包
启用OpenStack库
yum installcentos-release-openstack-newton –y
安装openstack客户端
yum install python-openstackclient  –y
RHEL和 CentOS 默认启用 SELinux 。安装 openstack-selinux 包实现对OpenStack服务的安全策略进行自动管理:
yum install openstack-selinux –y
注意:测试证明,不要升级包,由于更新了一个新的内核会导致后面无法虚拟机创建失败。
2.2基础服务的部署
2.2.1基础服务介绍
基础服务:MySQL、RabbitMQ和Memcached
MySQL的使用主要是openstack各个组件存储,生产环境需要做集群;RabbitMQ为分布式消息队列,用于组件之间的通信,支持集群;
RabbitMQ为分布式消息队列,用于组件之间的通信,支持集群,除了Horizon和KeyStone,其它组件需要连接RabbitMQ;
Memcached:各类服务的身份认证机制使用Memcached缓存令牌。缓存服务memecached通常运行在控制节点。在生产部署中,我们推荐联合启用防火墙、认证和加密保证它的安全。
都是部署在控制节点上。


2.2.2MySQL部署
a软件包安装
yum install -ymariadb mariadb-server python2-PyMySQL
b.创建并编辑/etc/my.cnf.d/openstack.cnf
[mysqld]
bind-address =192.168.56.11
default-storage-engine= innodb
innodb_file_per_table
max_connections =4096
collation-server =utf8_general_ci
character-set-server= utf8
c.完成安装

  • 启动数据库服务,并将配置设置为开机自启
systemctl enablemariadb.service
systemctl startmariadb.service

  • 为了保证数据库服务的安全性,运行``mysql_secure_installation``脚本。特别需要说明的是,为数据库的root用户设置一个适当的密码。
mysql_secure_installation


2.2.3Rabbitmq部署
a.软件包的安装
yum install -y rabbitmq-server
b.启动消息队列服务并将其配置为随系统启动
systemctl enablerabbitmq-server.service
systemctl startrabbitmq-server.service
c.添加openstack用户
rabbitmqctladd_user openstack openstack(密码)
d.给``openstack``用户配置写和读权限
rabbitmqctlset_permissions openstack ".*" ".*" ".*"
e.启动RabbitMQ_Web插件,管理界面监听15672端口
rabbitmq-pluginsenable rabbitmq_management
   DSC0003.png
  
2.2.4memcached的部署
  a.软件包安装
yum installmemcached python-memcached -y
  b.修改配置
vim/etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS="-l192.168.56.11,::1"
  c.启动Memcached服务,并且配置它随机启动。
systemctl enablememcached.service
systemctl startmemcached.service
  
2.3认证服务
2.3.1keystone概况
  Keystone包含用户认证和服务目录。
  a.用户与认证:用户权限与用户行为跟踪;
  User:用户 ,它是用一个数字代表使用openstack云服务的一个人,系统或服务。身份验证服务将会验证传入的由用户声明将调用的请求。
  Project(tenant):项目,早期称为租户,它是各个服务中的一些可以访问的资源集合或者说叫资源组,它是一个容器,用于组织和隔离资源,或标示对象。
  一个租户可以有多个用户。
  一个用户可以属于一个或多个租户
  用户对租户和操作权限由租户中担任的角色来决定。
  Token:令牌
  Role:角色,roles代表一组用户可以访问的资源权限,例如Nova中的虚拟机、glance中的镜像。Users可以被添加到任意一个全局的或项目内的角色中,在全局的role中,用户的role权限作用于所有的租户,即可以对所有的租户执行role规定的权限;在租户内的role中,用户仅能在当前租户内执行role规定的权限。
  
  b服务目录:提供一个服务目录,包含所有服务项目与相关API端点
  Service:服务 如Nova、glance、swift根据前三个概念(user,tenant,role)一个服务可以确认当前用户是否具有访问其资源的权限。但是当一个user尝试着访问其租户内的service时,他必须知道这个service是否存在以及如何访问这个service
  Endpoint:端点,我们可以理解它是一个服务暴露出来的访问点,如果需要访问一个服务,则必须知道他的endpoint。Endpoint的每个URL都对应一个服务实例的访问地址,并且具有public、private和admin这三种权限。Public URL可以被全局访问,private URL只能被局域网访问,admin URL被从常规的访问中分离。
  
  
2.3.2keystone的配置与安装
  a.创建相关数据库并授权
create database keystone;
grant all on keystone.* to 'keystone'@'localhost' identified by 'keystone';
grant all on keystone.* to 'keystone'@'%' identified by 'keystone';
  
  b.keystone相关软件包安装
yum install–y openstack-keystone httpd mod_wsgi
  
  c. 编辑文件 /etc/keystone/keystone.conf
[database]#配置数据库访问
connection =mysql+pymysql://keystone:keystone@192.168.56.11/keystone
[memcache]#缓存的连接
servers =192.168.56.11:11211
[token]#配置Fernet UUID令牌的提供者
provider = fernet
driver = memcache
  
  d初始化身份认证服务的数据库
su -s /bin/sh -c"keystone-manage db_sync" keystone
  验证
mysql -h192.168.56.11 -ukeystone -pkeystone -e "use keystone;show tables;"
  
  e初始化Fernet key
keystone-managefernet_setup --keystone-user keystone --keystone-group keystone
keystone-managecredential_setup --keystone-user keystone --keystone-group keystone
  
  f引导标识服务
keystone-managebootstrap --bootstrap-password admin \
--bootstrap-admin-urlhttp://192.168.56.11:35357/v3/ \
--bootstrap-internal-urlhttp://192.168.56.11:35357/v3/ \
--bootstrap-public-urlhttp://192.168.56.11:5000/v3/ \
--bootstrap-region-idRegionOne
  
2.3.3配置Apache http服务器
  a配置http;配置``ServerName`` 选项为控制节点
vim/etc/httpd/conf/httpd.conf
ServerName192.168.56.11:80
  
  b创建一个链接到``/usr/share/keystone/wsgi-keystone.conf``文件
ln -s/usr/share/keystone/wsgi-keystone.conf /etc/httpd/conf.d/
  
  c启动 Apache HTTP 服务并配置其随系统启动
systemctl enablehttpd.service
systemctl starthttpd.service
  
  d配置admin账户
exportOS_USERNAME=admin
exportOS_PASSWORD=admin
exportOS_PROJECT_NAME=admin
exportOS_USER_DOMAIN_NAME=default
exportOS_PROJECT_DOMAIN_NAME=default
exportOS_AUTH_URL=http://192.168.56.11:35357/v3
exportOS_IDENTITY_API_VERSION=3
  
  
2.3.4创建一个域,项目,用户和角色
  使用一个你添加到你的环境中每个服务包含独有用户的service 项目。创建``service``项目:
openstack projectcreate --domain default \
--description"Service Project" service
  常规(非管理)任务应该使用无特权的项目和用户。作为例子,本指南创建demo 项目和用户。
  创建``demo`` 项目:
openstack projectcreate --domain default \
--description"Demo Project" demo
  创建``demo`` 用户:
openstack usercreate --domain default \
--password-promptdemo
  创建 user 角色:
openstack rolecreate user
  把demo用户加到demo项目授予user用户
openstack role add--project demo --user demo user
  
  
2.3.5验证
  a撤销临时环境变量``OS_AUTH_URL``和``OS_PASSWORD``
unset OS_AUTH_URLOS_PASSWORD
  
  b作为 admin 用户,请求认证令牌
openstack--os-auth-url http://192.168.56.11:35357/v3 --os-project-domain-name default--os-user-domain-name default --os-project-name admin --os-username admin tokenissue
  
  c作为``demo`` 用户,请求认证令牌
openstack--os-auth-url http://192.168.56.11:5000/v3 --os-project-domain-name default--os-user-domain-name default --os-project-name demo --os-username demo tokenissue
  
2.3.6创建 OpenStack 客户端环境脚本
  创建 admin 和``demo``项目和用户创建客户端环境变量脚本。本实验的接下来的部分会引用这些脚本,为客户端操作加载合适的的凭证。
  
  a.编辑`` admin-openstack ``文件并且增加以下内容
exportOS_PROJECT_DOMAIN_NAME=default
exportOS_USER_DOMAIN_NAME=default
export OS_PROJECT_NAME=admin
exportOS_USERNAME=admin
exportOS_PASSWORD=admin
exportOS_AUTH_URL=http://192.168.56.11:35357/v3
exportOS_IDENTITY_API_VERSION=3
exportOS_IMAGE_API_VERSION=2
  
  b编辑文件 demo-openstack 并添加如下内容
exportOS_PROJECT_DOMAIN_NAME=default
exportOS_USER_DOMAIN_NAME=default
exportOS_PROJECT_NAME=demo
exportOS_USERNAME=demo
exportOS_PASSWORD=demo
exportOS_AUTH_URL=http://192.168.56.11:5000/v3
exportOS_IDENTITY_API_VERSION=3
exportOS_IMAGE_API_VERSION=2
  
  c使用脚本
  1)加载``admin-openrc``文件来身份认证服务的环境变量位置和``admin``项目和用户证书
sourceadmin-openstack
  
  2)请求认证令牌:
openstack tokenissue
+------------+----------------------------------------------------------------------------------------------------------------------------------------------+
| Field | Value |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------+
| expires |2016-12-20 06:36:58+00:00 |
| id |gAAAAABYWMN6VL02m9TtQtV0DxmaFtZqWD142fi7ggLdT_bcQXfs395O2T9q- |
| |UElJZPk_5y7QttNNpiaUb7Ant90C1w8Dnm7D7aE8ILD0DLnexqAgJD0HXQYrk9g6ajGq_sZMZixOdwK_yhR7-m3kIlbPeh_qvVtHHY9QjIh2RzkO79wFZ-uTvg|
| project_id |98e702c0165641d5b8833dce373373b2 |
| user_id |37a18975b18f484c8861d2ed4de048cb |
+------------+----------------------------------------------------------------------------------------------------------------------------------------------+
  

  以上图片版权以及内容为赵班长授课以及官网。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-483369-1-1.html 上篇帖子: Openstack 实战讲解之 下篇帖子: 云计算之openstack(N版)glance镜像服务最佳实践
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表