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

[经验分享] 正式进入搭建OpenStack

[复制链接]

尚未签到

发表于 2017-6-26 15:38:14 | 显示全部楼层 |阅读模式
  部署mariadb数据库
  控制节点:
  yum install mariadb mariadb-server python2-PyMySQL -y
  编辑:
  /etc/my.cnf.d/openstack.cnf
  [mysqld]
  bind-address = 控制节点管理网络ip
  default-storage-engine = innodb
  innodb_file_per_table
  max_connections = 4096
  collation-server = utf8_general_ci
  character-set-server = utf8
  启服务:
  systemctl enable mariadb.service
  systemctl start mariadb.service
  #初始化mysql
  mysql_secure_installation
  部署消息队列rabbitmq(验证方式:http://IP:15672/ 用户:guest 密码:guest)
  控制节点:
  yum install rabbitmq-server -y
  启动服务:
  systemctl enable rabbitmq-server.service
  systemctl start rabbitmq-server.service
  新建rabbitmq用户密码:
  rabbitmqctl add_user openstack 123456
  为新建的用户openstack设定权限:
  rabbitmqctl set_permissions openstack ".*" ".*" ".*"
  部署memcached缓存(为keystone服务缓存tokens)
  控制节点:
  yum install memcached python-memcached -y
  启动服务:
  systemctl enable memcached.service
  systemctl start memcached.service
  认证服务keystone部署
  一:安装和配置服务
  1.建库建用户
  mysql -u root -p
  CREATE DATABASE keystone;
  GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost' \
  IDENTIFIED BY '123456';
  GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%' \
  IDENTIFIED BY '123456';
  GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'控制节点IP或主机名' \
  IDENTIFIED BY '123456';
  flush privileges;
  2、安装keystone和mod_wsgi
  yum install openstack-keystone httpd mod_wsgi -y
  3、编辑/etc/keystone/keystone.conf
  [DEFAULT]
  admin_token = 123456 #建议用命令制作token:openssl rand -hex 10
  [database]
  connection = mysql+pymysql://keystone:123456@controller/keystone
  [token]
  provider = fernet
  #Token Provider:UUID, PKI, PKIZ, or Fernet #http://blog.csdn.net/miss_yang_cloud/article/details/49633719
  4.同步修改到数据库
  su -s /bin/sh -c "keystone-manage db_sync" keystone
  5.初始化fernet keys
  keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone
  6.配置apache服务
  编辑:/etc/httpd/conf/httpd.conf
  ServerName controller
  编辑:/etc/httpd/conf.d/wsgi-keystone.conf
  新增配置



Listen 5000
Listen 35357
<VirtualHost *:5000>
WSGIDaemonProcess keystone-public processes=5 threads=1 user=keystone group=keystone display-name=%{GROUP}
WSGIProcessGroup keystone-public
WSGIScriptAlias / /usr/bin/keystone-wsgi-public
WSGIApplicationGroup %{GLOBAL}
WSGIPassAuthorization On
ErrorLogFormat "%{cu}t %M"
ErrorLog /var/log/httpd/keystone-error.log
CustomLog /var/log/httpd/keystone-access.log combined
<Directory /usr/bin>
Require all granted
</Directory>
</VirtualHost>
<VirtualHost *:35357>
WSGIDaemonProcess keystone-admin processes=5 threads=1 user=keystone group=keystone display-name=%{GROUP}
WSGIProcessGroup keystone-admin
WSGIScriptAlias / /usr/bin/keystone-wsgi-admin
WSGIApplicationGroup %{GLOBAL}
WSGIPassAuthorization On
ErrorLogFormat "%{cu}t %M"
ErrorLog /var/log/httpd/keystone-error.log
CustomLog /var/log/httpd/keystone-access.log combined
<Directory /usr/bin>
Require all granted
</Directory>
</VirtualHost>

  7.启动服务:
  systemctl enable httpd.service
  systemctl restart httpd.service #因为之前自定义基于http协议的yum源时已经启动过了httpd,所以此处需要restart
  二:创建服务实体和访问端点
  1.实现配置管理员环境变量,用于获取后面创建的权限
  export OS_TOKEN=123456
  export OS_URL=http://controller:35357/v3
  export OS_IDENTITY_API_VERSION=3
  2.基于上一步给的权限,创建认证服务实体(目录服务)
  openstack service create \
  --name keystone --description "OpenStack Identity" identity
  3.基于上一步建立的服务实体,创建访问该实体的三个api端点
  openstack endpoint create --region RegionOne \
  identity public http://controller:5000/v3
  openstack endpoint create --region RegionOne \
  identity internal http://controller:5000/v3
  openstack endpoint create --region RegionOne \
  identity admin http://controller:35357/v3
  三:创建域,租户,用户,角色,把四个元素关联到一起
  建立一个公共的域名:
  openstack domain create --description "Default Domain" default
  管理员:admin
  openstack project create --domain default \
  --description "Admin Project" admin
  openstack user create --domain default \
  --password-prompt admin
  openstack role create admin
  openstack role add --project admin --user admin admin
  普通用户:demo
  openstack project create --domain default \
  --description "Demo Project" demo
  openstack user create --domain default \
  --password-prompt demo
  openstack role create user
  openstack role add --project demo --user demo user
  为后续的服务创建统一租户service
  解释:后面每搭建一个新的服务都需要在keystone中执行四种操作:1.建租户 2.建用户 3.建角色 4.做关联
  后面所有的服务公用一个租户service,都是管理员角色admin,所以实际上后续的服务安装关于keysotne
  的操作只剩2,4
  openstack project create --domain default \
  --description "Service Project" service
  四:验证操作:
  编辑:/etc/keystone/keystone-paste.ini
  在[pipeline:public_api], [pipeline:admin_api], and [pipeline:api_v3] 三个地方
  移走:admin_token_auth
  unset OS_TOKEN OS_URL
  openstack --os-auth-url http://controller:35357/v3 \
  --os-project-domain-name default --os-user-domain-name default \
  --os-project-name admin --os-username admin token issue
  Password:
  五:新建客户端脚本文件
  管理员:admin-openrc
  export OS_PROJECT_DOMAIN_NAME=default
  export OS_USER_DOMAIN_NAME=default
  export OS_PROJECT_NAME=admin
  export OS_USERNAME=admin
  export OS_PASSWORD=123456
  export OS_AUTH_URL=http://controller:35357/v3
  export OS_IDENTITY_API_VERSION=3
  export OS_IMAGE_API_VERSION=2
  普通用户demo:demo-openrc
  export OS_PROJECT_DOMAIN_NAME=default
  export OS_USER_DOMAIN_NAME=default
  export OS_PROJECT_NAME=demo
  export OS_USERNAME=demo
  export OS_PASSWORD=123456
  export OS_AUTH_URL=http://controller:5000/v3
  export OS_IDENTITY_API_VERSION=3
  export OS_IMAGE_API_VERSION=2
  效果:
  source admin-openrc
  [iyunv@controller01 ~]# openstack token issue
DSC0000.png

运维网声明 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-388244-1-1.html 上篇帖子: openstack 部署笔记--nova 下篇帖子: OpenStack里的三种存储
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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