1.1 安装 CentOS7 说明

【CentOS7 版本】

        CentOS7 系统选择 2009 版本:CentOS-7-x86_64-DVD-2009.iso

【空白分区划分】

        在 CentOS7 安装过程中,设置分区都需要一个挂载点,这样一来就无法创建三个空白 的磁盘分区作为 cinder 服务、swift 服务和 manila 服务的存储磁盘了。

        所以我们应该在系统安装过程中留下足够的磁盘大小,系统安装完成后,使用命令 parted 划分三个新分区。 

1.2 交换机配置

        以 H3C-S5024-24P 交换机配置为例,为三层交换机配置 vlan。

        新建 vlan 100,为 vlan 100 配置 IP 地址为 192.168.100.1,作为管理网段的网关地址,并将交 换机 1-8 号端口加入到 vlan 100 中。

        新建 vlan 200,为 vlan 200 配置 IP 地址为 192.168.200.1,作为虚拟机业务网段的网关 地址,并将交换机 9-16 号端口配置为 trunk 模式,放行 vlan 200(这里直接放行所有端口)。

         新建 vlan 2,为 vlan 2 配置 IP 地址为 192.168.1.1,作为训练用 PC 终端的网关地址, 并将交换机 17-24 号端口加入到 vlan 2 中。

        配置完交换机之后,需要用网线将服务器等设备与交换机连接起来。将两台服务器的 网口一连接到交换机的 1-8 口上;将两台服务器的网口二连接到交换机的 9-16 口上;学生 的 PC 终端连接到交换机的 17-24 口。

1.3 配置网络、主机名

修改和添加/etc/sysconfig/network-scripts/ifcfg-enp*(具体的网口)文件。

(1)controller 节点

配置网络: enp8s0: 192.168.100.10

DEVICE=enp8s0

TYPE=Ethernet

ONBOOT=yes

NM_CONTROLLED=no

BOOTPROTO=static

IPADDR=192.168.100.10

PREFIX=24

GATEWAY=192.168.100.1

enp9s0:第二块网卡不需要做配置

配置主机名:

# hostnamectl set-hostname controller

按 ctrl+d 退出 重新登陆

(2)compute 节点 配置网络:

enp8s0: 192.168.100.20

DEVICE=enp8s0

TYPE=Ethernet

ONBOOT=yes

NM_CONTROLLED=no

BOOTPROTO=static

IPADDR=192.168.100.20

PREFIX=24 GATEWAY=192.168.100.1

enp9s0:第二块网卡不需要做配置

配置主机名:

# hostnamectl set-hostname compute

按 ctrl+d 退出 重新登陆

1.4 配置 yum 源

#Controller 和 compute 节点

(1)yum 源备份

#mv /etc/yum.repos.d/* /opt/

(2)创建 repo 文件

【controller】

在/etc/yum.repos.d 创建 centos.repo 源文件

[centos]

name=centos

baseurl=file:///opt/centos

gpgcheck=0

enabled=1

[iaas]

name=iaas

baseurl=file:///opt/iaas/iaas-repo

gpgcheck=0

enabled=1

【compute】

在/etc/yum.repos.d 创建 centos.repo 源文件

[centos]

name=centos

baseurl=ftp://192.168.100.10/centos

gpgcheck=0 enabled=1

[iaas]

name=iaas

baseurl=ftp://192.168.100.10/iaas/iaas-repo

gpgcheck=0

enabled=1

(3)挂载 iso 文件

【挂载 CentOS-7-x86_64-DVD-2009.iso】

[root@controller ~]# mount -o loop CentOS-7-x86_64-DVD-2009.iso /mnt/

[root@controller ~]# mkdir /opt/centos

[root@controller ~]# cp -rvf /mnt/* /opt/centos/

[root@controller ~]# umount /mnt/

【挂载 chinaskills_cloud_iaas_v2.0.3.iso】

[root@controller ~]# mount -o loop chinaskills_cloud_iaas_v2.0.3.iso /mnt/

[root@controller ~]# mkdir /opt/iaas/

[root@controller ~]# cp -rvf /mnt/* /opt/

[root@controller ~]# umount /mnt/

(4)搭建 ftp 服务器,开启并设置自启

[root@controller ~]# yum install vsftpd -y

[root@controller ~]# vi /etc/vsftpd/vsftpd.conf

添加 anon_root=/opt/

保存退出

[root@controller ~]# systemctl start vsftpd

[root@controller ~]# systemctl enable vsftpd

(5)配置防火墙和 Selinux

【controller/compute】

编辑 selinux 文件

# vi /etc/selinux/config

SELINUX=permissive

也可以使用临时生效命令,如下:

# setenforce 0

关闭防火墙并设置开机不自启

# systemctl stop firewalld.service

# systemctl disable firewalld.service

# yum remove -y NetworkManager firewalld

# yum -y install iptables-services

# systemctl enable iptables

# systemctl restart iptables

# iptables -F

# iptables -X

# iptables -Z

# service iptables save

(6)清除缓存,验证 yum 源

【controller/compute】

# yum clean all

# yum list

1.5 编辑环境变量

# controller 和 compute 节点

# yum install openstack-iaas -y

编辑文件/etc/openstack/openrc.sh,此文件是安装过程中的各项参数,根据每项参数上一行 的说明及服务器实际情况进行配置。

HOST_IP=192.168.100.10

HOST_PASS=000000

HOST_NAME=controller

HOST_IP_NODE=192.168.100.10

HOST_PASS_NODE=000000

HOST_NAME_NODE=compute

network_segment_IP=192.168.100.0/24

RABBIT_USER=openstack

RABBIT_PASS=000000

DB_PASS=000000

DOMAIN_NAME=demo

ADMIN_PASS=000000

DEMO_PASS=000000

KEYSTONE_DBPASS=000000

GLANCE_DBPASS=000000

GLANCE_PASS=000000

PLACEMENT_DBPASS=000000

PLACEMENT_PASS=000000

NOVA_DBPASS=000000

NOVA_PASS=000000

NEUTRON_DBPASS=000000

NEUTRON_PASS=000000

METADATA_SECRET=000000

INTERFACE_NAME=enp9s0 #填写外部网络网卡名称

Physical_NAME=provider

minvlan=1 maxvlan=1000

CINDER_DBPASS=000000

CINDER_PASS=000000

BLOCK_DISK=sdb1 #第一个分区

SWIFT_PASS=000000

OBJECT_DISK=sdb2 #第二个分区

STORAGE_LOCAL_NET_IP=192.168.100.20 TROVE_DBPASS=000000

TROVE_PASS=000000

HEAT_DBPASS=000000

HEAT_PASS=000000

CEILOMETER_DBPASS=000000

CEILOMETER_PASS=000000

AODH_DBPASS=000000

AODH_PASS=000000

ZUN_DBPASS=000000

ZUN_PASS=000000

KURYR_PASS=000000

OCTAVIA_DBPASS=000000

OCTAVIA_PASS=000000

MANILA_DBPASS=000000

MANILA_PASS=000000

SHARE_DISK=sdb3 #第三个分区 CLOUDKITTY_DBPASS=000000

CLOUDKITTY_PASS=000000

BARBICAN_DBPASS=000000 BARBICAN_PASS=000000

SENLIN_DBPASS=000000

SENLIN_PASS=000000

1.6 通过脚本完成基础配置

controller节点和compute节点执行脚本iaas-pre-host.sh进行安装

[root@controller ~]# iaas-pre-host.sh

安装完成后同时重启

[root@controller ~]# reboot

1.7 通过脚本安装数据库服务

controller节点执行脚本iaas-install-mysql.sh进行安装

[root@controller ~]# iaas-install-mysql.sh

2 安装 openstack 基础服务

2.1 通过脚本安装 keystone 服务

controller节点执行脚本iaas-install-keystone.sh进行安装

[root@controller ~]# iaas-install-keystone.sh

2.2 通过脚本安装 glance 服务

controller节点执行脚本iaas-install-glance.sh进行安装

[root@controller ~]# iaas-install-glance.sh

2.3 通过脚本安装 Placement 服务

controller节点执行脚本iaas-install-placement.sh进行安装

[root@controller ~]# iaas-install-placement.sh

2.4 通过脚本安装 Nova 服务

controller节点执行脚本iaas-install-nova-controller.sh进行安装

[root@controller ~]# iaas-install-nova-controller.sh

compute节点执行脚本iaas-install-nova-compute.sh进行安装

[root@compute ~]# iaas-install-nova-compute.sh

2.5 通过脚本安装 Neutron 服务

controller节点执行脚本iaas-install-neutron-controller.sh进行安装

[root@controller ~]# iaas-install-neutron-controller.sh

compute节点执行脚本iaas-install-neutron-compute.sh进行安装

[root@compute ~]# iaas-install-neutron-compute.sh

2.6 通过脚本安装 Dashboard 服务

controller节点执行脚本iaas-install-dashboard.sh进行安装

[root@controller ~]# iaas-install-dashboard.sh

3 安装 openstack 高级服务

3.1 通过脚本安装 cinder 服务

controller节点执行脚本iaas-install-cinder-controller.sh进行安装

[root@controller ~]# iaas-install-cinder-controller.sh

compute节点执行脚本iaas-install-cinder-compute.sh进行安装

[root@compute ~]# iaas-install-cinder-compute.sh

3.2 通过脚本安装 swift 服务

controller节点执行脚本iaas-install-swift-controller.sh进行安装

[root@controller ~]# iaas-install-swift-controller.sh

compute节点执行脚本iaas-install-swift-compute.sh进行安装

[root@compute ~]# iaas-install-swift-compute.sh

3.3 通过脚本安装 trove 服务

controller节点执行脚本iaas-install-trove.sh进行安装

[root@controller ~]# iaas-install-trove.sh

3.4 通过脚本安装 heat 服务

controller节点执行脚本iaas-install-heat.sh进行安装

[root@controller ~]# iaas-install-heat.sh

3.5 通过脚本安装 ceilometer 服务

controller节点执行脚本iaas-install-ceilometer-controller.sh进行安装

[root@controller ~]# iaas-install-ceilometer-controller.sh

compute节点执行脚本iaas-install-ceilometer-compute.sh进行安装

[root@compute ~]# iaas-install-ceilometer-compute.sh

3.6 通过脚本安装 aodh 服务

controller节点执行脚本iaas-install-aodh.sh进行安装

[root@controller ~]# iaas-install-aodh.sh


3.7 通过脚本安装 zun 服务

controller节点执行脚本iaas-install-zun-controller.sh进行安装

[root@controller ~]# iaas-install-zun-controller.sh

compute节点执行脚本iaas-install-zun-compute.sh进行安装

[root@compute ~]# iaas-install-zun-compute.sh

3.8 通过脚本安装 octavia 服务

controller节点执行脚本iaas-install-octavia.sh进行安装

[root@controller ~]#iaas-install-octavia.sh

3.9 通过脚本安装 manila 服务

controller节点执行脚本iaas-install-manila-controller.sh进行安装

[root@controller ~]# iaas-install-manila-controller.sh

compute节点执行脚本iaas-install-manila-compute.sh进行安装

[root@compute ~]# iaas-install-manila-compute.sh

3.10 通过脚本安装 cloudkitty 服务

controller节点执行脚本iaas-install-cloudkitty.sh进行安装

[root@controller ~]# iaas-install-cloudkitty.sh

3.11 通过脚本安装 barbican 服务

controller节点执行脚本iaas-install-barbican.sh进行安装

[root@controller ~]# iaas-install-barbican.sh

4 添加控制节点资源到云平台

4.1 修改 openrc.sh

把compute节点的IP和主机名改为controller节点的IP和主机名

HOST_IP_NODE=192.168.100.10

HOST_PASS_NODE=000000

HOST_NAME_NODE=compute

4.2 运行 iaas-install-nova-compute.sh

在控制节点运行:

iaas-install-nova-compute.sh

执行过程中需要确认登录controller节点和输入controller节点root用户密码。 


注:[root@localhost ~]# fdisk /dev/sdb