首页 > 代码库 > keystone系列四:部署keystone
keystone系列四:部署keystone
一 前言
任何软件的部署都是没有技术含量的,任何就部署讲部署的人都是江湖骗子。
部署的本质就是拷贝,粘贴,回车。我们家养了条狗,它可以胜任这件事情。
我们搞技术的,一定不能迂腐:轻信或者一概不信。
轻信者的傻逼就像是只学了上半册的葵花宝典,上半册教你欲练此功必先自宫,而下半册说的则是不自宫其实也可以。
不信者的傻逼就像是马冬什么?马什么梅?什么冬梅?
二 版本信息
官网http://docs.openstack.org/newton/install-guide-rdo/keystone.html
我们按照Newton这个版本来部署,其实跟大家讲,openstack基本保持每6个月更新一个版本,面对如此快的版本更迭,我们其实瞅准了一个版本深入研究下去就好,深入到什么层次,为社区提交代码。任何每来一个新版本就去部署一次的主都是傻叉。
三 部署keystone
参考官网http://docs.openstack.org/newton/install-guide-rdo/
系统信息
[root@localhost ~]# cat /etc/redhat-release CentOS Linux release 7.0.1406 (Core) [root@localhost ~]# uname -r3.10.0-123.el7.x86_64
step 1:准备阶段
yum -y install centos-release-openstack-newton #安装官方yum源yum -y upgrade #更新yum -y install python-openstackclient #安装工具yum -y install openstack-selinux #安装openstack-selinux包自动管理openstack组件的安全策略
step 2:部署mariadb
安装
‘‘‘keystone支持ldap和mysql作为后端Driver,用来存放用户相关信息,catalog等,这里我们选用mariadb‘‘‘yum -y install mariadb mariadb-server python2-PyMySQL
配置:/etc/my.cnf.d/openstack.cnf
[mysqld]bind-address = 192.168.31.57 #本机管理网络ipdefault-storage-engine = innodbinnodb_file_per_tablemax_connections = 4096collation-server = utf8_general_cicharacter-set-server = utf8
启动服务且设置开机启动
systemctl start mariadb.service
systemctl enable mariadb.service
初始化数据库(可有可无)
mysql_secure_installation
step 3:部署keystone
keystone关于数据库的操作
mysql -u root -p #登入数据库CREATE DATABASE keystone; #新建库keystoneGRANT ALL PRIVILEGES ON keystone.* TO ‘keystone‘@‘localhost‘ IDENTIFIED BY ‘123‘; #新建本地访问keystone库的账号GRANT ALL PRIVILEGES ON keystone.* TO ‘keystone‘@‘%‘ IDENTIFIED BY ‘123‘; #新建远程访问keystone库的账号
安装软件包
#keystone软件包名openstack-keystone#安装httpd和mod_wsgi的原因是,社区主推apache+keystone#openstack-keystone本质就是一款基于wsgi协议的web app,而httpd本质就是一个兼容wsgi协议的web server,所以我们需要为httpd安装mod_wsgi模块yum -y install openstack-keystone httpd mod_wsgi
配置:/etc/keystone/keystone.conf
#让openstack-keystone能够知道如何连接到后端的数据库keystone#mysql+pymysql:pymysql是一个python库,使用python可以操作mysql原生sql[database]connection = mysql+pymysql://keystone:‘123‘@192.168.31.57/keystone[token]provider = fernet #fernet为生成token的方式
初始化数据库keystone
#之所以要初始化,是因为python的orm对象关系映射,需要初始化来生成数据库表结构su -s /bin/sh -c "keystone-manage db_sync" keystone
keystone系列四:部署keystone
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。