openstack的部署与云主机实例

参考官网:https://docs.openstack.org/mitaka/zh_CN/install-guide-rdo/environment.html

实验环境:
控制节点:controller:192.168.43.11, 2CPU,4GB内存,20GB 存储(最少5G)

计算节点: compute: 172.25.1.2 ,2 CPU, 2GB内存, 20GB 存储(最少10G)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.openstack部署

1.1 环境搭建

1.控制节点服务器主机网络

[root@server1 ~]# cd /boot/grub2/
[root@server1 grub2]# ls
device.map  fonts  grub.cfg  grubenv  i386-pc  locale
[root@server1 grub2]# vim grub.cfg

inux16 /vmlinuz-3.10.0-957.el7.x86_64 root=UUID=8d5190d9-d50b-49f4-a64e-7a985e53dc81 ro crashkernel=auto rhgb quiet LANG=en_US.UTF-8 net.ifnames=0

提供者网络接口使用一个特殊的配置,不分配给它IP地址。配置第二块网卡作为提供者网络:
将其中的 INTERFACE_NAME替换为实际的接口名称。

[root@controller ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth0
BOOTPROTO=none
NAME=eth0
DEVICE=eth0
ONBOOT=yes
IPADDR=192.168.43.11
GATEWAY=192.168.43.1
NETMASK=255.255.255.0
DNS1=114.114.114.114
[root@controller ~]# cat /etc/sysconfig/network-scripts/ifcfg-eth1
BOOTPROTO=none
DEVICE=eth1
ONBOOT=yes
[root@controller ~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
172.25.1.250 foundation1.ilt.example.com
192.168.43.11 controller
192.168.43.12 computer1
192.168.43.13 block1

在这里插入图片描述
在这里插入图片描述


2.网络时间协议(NTP)

设置所有节点的时间与宿主机同步
在这里插入图片描述
[root@controller ~]#vim /etc/chrony.conf宿主机设置虚拟机时间同步

# Please consider joining the pool (http://www.pool.ntp.org/join.html).
server ntp1.aliyun.com iburst

# Allow NTP client access from local network.
allow 172.25/16

在这里插入图片描述
在这里插入图片描述


在controller中
[root@controller ~]#yum install chrony -y
[root@controller ~]#vim /etc/chrony.conf

# Please consider joining the pool (http://www.pool.ntp.org/join.html).
server 192.168.43.10 iburst

systemctl enable chronyd.service --now
chronyc sources -v

在这里插入图片描述
在这里插入图片描述


3.安装OpenStack包

[root@controller ~]#yum upgrade在主机上升级包
[root@controller ~]#yum install python-openstackclient安装 OpenStack 客户端

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


4.安装SQL数据库

[root@controller ~]#yum install mariadb mariadb-server python2-PyMySQL安装软件包
[root@controller ~]#vim /etc/my.cnf.d/openstack.cnf

[mysqld]
bind-address = 172.25.1.1 ###设置 ``bind-address``值为控制节点的管理网络IP地址以使得其它节点可以通过管理网络访问数据库
default-storage-engine = innodb ###设置如下键值来启用一起有用的选项和 UTF-8 字符集
innodb_file_per_table
max_connections = 4096
collation-server = utf8_general_ci
character-set-server = utf8

[root@controller ~]#systemctl enable mariadb.service --now启动数据库服务,并将其配置为开机自启
[root@controller ~]#mysql_secure_installation初始化数据库


在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


5.消息队列

[root@controller ~]# yum install rabbitmq-server安装包
[root@controller ~]# systemctl enable rabbitmq-server.service --now启动消息队列服务并将其配置为随系统启动
[root@controller ~]# rabbitmqctl add_user openstack openstack添加 openstack 用户及免密
[root@controller ~]# rabbitmqctl set_permissions openstack ".*" ".*" ".*"给“openstack”用户配置写和读权限

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


6.Memcached

[root@controller ~]# yum install memcached python-memcached安装软件包

[root@controller ~]# vim /etc/sysconfig/memcached
[root@controller ~]# cat /etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
#OPTIONS="-l 127.0.0.1,::1" ##禁用
[root@controller ~]# systemctl enable memcached.service --now

[root@controller ~]# systemctl enable memcached.service --now启动Memcached服务,并且配置它随机启动
在这里插入图片描述
在这里插入图片描述


1.2 认证服务

1.配置组件

keystone提供授权管理和服务目录。

[root@controller ~]# mysql -p
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 12
Server version: 10.1.20-MariaDB MariaDB Server
Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> CREATE DATABASE keystone;
Query OK, 1 row affected (0.00 sec)
MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'localhost'  IDENTIFIED BY 'keystone';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> GRANT ALL PRIVILEGES ON keystone.* TO 'keystone'@'%'  IDENTIFIED BY 'keystone';
Query OK, 0 rows affected (0.00 sec)
MariaDB [(none)]> ^DBye
[root@controller ~]# mysql -u keystone -p keystone
Enter password: 
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 13
Server version: 10.1.20-MariaDB MariaDB Server
Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [keystone]> ^DBye

在这里插入图片描述


[root@controller ~]# yum install openstack-keystone httpd mod_wsgi安装包
[root@controller ~]# openssl rand -hex 10生成一个随机值在初始的配置中作为管理员的令牌
[root@controller ~]# vim /etc/keystone/keystone.conf

[DEFAULT]
admin_token = ADMIN_TOKEN

[database]
connection = mysql+pymysql://keystone:keystone@controller/keystone

[token]
provider = fernet

su -s /bin/sh -c "keystone-manage db_sync" keystone初始化身份认证服务的数据库
keystone-manage fernet_setup --keystone-user keystone --keystone-group keystone初始化Fernet keys


在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


2.配置 Apache HTTP 服务器

[root@controller ~]# vim /etc/httpd/conf/httpd.conf

ServerName controller ##配置``ServerName`` 选项为控制节点

在这里插入图片描述
创建文件
[root@controller ~]# vim /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>

[root@controller ~]# systemctl enable httpd.service --now
在这里插入图片描述

  • 4
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值