使用DevStack执行OpenStack Juno多节点安装过程总结
目前安装 OpenStack 常见的方案有 Redhat 的 RDO 和社区的 DevStack。
当然,也可以手动安装,可以参考:github.com/ChaimaGhribi/OpenStack-Juno-Installation/blob/master/OpenStack-Juno-Installation.rst
其中,RDO 功能比较强大,运行也稳定,可以在一个节点上通过一个 answer 文件直接部署多个节点,搭建一套 OpenStack 环境。但是可惜,在 Ubuntu 上还不支持。
DevStack 支持 Ubuntu、Fedora 等环境,需要在每个节点上单独执行,适合进行实验。目前常见的教程一般都是讲解 DevStack 单节点安装。本文讲解最新的 Juno 版本在多节点上的安装过程。
网络环境
两台机器,分为控制节点(同时也作为网络节点)和计算节点。
控制节点
eth0: 9.186.100.77/24 作为管理网络(同时也是公共网络)。 eth1: 10.0.100.77/24 作为内部网络接口。
计算节点
eth0: 9.186.100.88/24 作为管理网络(同时也是公共网络)。 eth1: 10.0.100.88/24 作为内部网络接口。
配置 stack 用户
创建 stack 用户
sudo groupadd stack sudo useradd -g stack -s /bin/bash -d /opt/stack -m stack
添加 stack 用户权限。
sudo echo "stack ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
切换到 stack 用户
sudo su - stack
下载代码
下载 devstack 代码,并切换到 stable/juno 分支。
sudo apt-get install git -y git clone https://git.openstack.org/openstack-dev/devstack -b stable/juno
编写运行配置文件
在 devstack 根目录下,编写 local.conf。
控制节点的 local.conf
[[local|localrc]] HOST_IP=9.186.100.77 # management network PUBLIC_INTERFACE=eth0 #public network FIXED_RANGE=10.0.100.0/24 #FIXED_NETWORK_SIZE=4096 FLOATING_RANGE=9.186.100.0/24 PUBLIC_NETWORK_GATEWAY=9.186.100.1 MULTI_HOST=1 LOGFILE=/opt/stack/logs/stack.sh.log # Credentials ADMIN_PASSWORD=admin MYSQL_PASSWORD=secret RABBIT_PASSWORD=secret SERVICE_PASSWORD=secret SERVICE_TOKEN=abcdefghijklmnopqrstuvwxyz # enable neutron-ml2-vxlan disable_service n-net enable_service q-svc,q-agt,q-dhcp,q-l3,q-meta,q-metering,q-lbaas,neutron,tempest,heat # OFFLINE=True
计算节点的 local.conf
[[local|localrc]] HOST_IP=9.186.100.88 # management IP FIXED_RANGE=10.0.100.0/24 #FIXED_NETWORK_SIZE=4096 FLOATING_RANGE=9.186.100.0/24 MULTI_HOST=1 LOGFILE=/opt/stack/logs/stack.sh.log # Credentials ADMIN_PASSWORD=admin MYSQL_PASSWORD=secret RABBIT_PASSWORD=secret SERVICE_PASSWORD=secret SERVICE_TOKEN=abcdefghijklmnopqrstuvwxyz # Service information SERVICE_HOST=9.186.100.77 MYSQL_HOST=9.186.100.77 RABBIT_HOST=9.186.100.77 GLANCE_HOSTPORT=9.186.100.77:9292 Q_HOST=9.186.100.77 KEYSTONE_AUTH_HOST=9.186.100.77 KEYSTONE_SERVICE_HOST=9.186.100.77 CEILOMETER_BACKEND=mongodb DATABASE_TYPE=mysql ENABLED_SERVICES=n-cpu,n-net,n-api,c-sch,c-api,c-vol # vnc config NOVA_VNC_ENABLED=True NOVNCPROXY_URL="http://9.186.100.77:6080/vnc_auto.html" VNCSERVER_LISTEN=$HOST_IP VNCSERVER_PROXYCLIENT_ADDRESS=$VNCSERVER_LISTEN # OFFLINE=True
执行配置
执行命令
./stack.sh
会输出各项操作的结果。日志会写到 stack.sh.log 文件。
其它事项
停止 OpenStack 的各个服务(DevStack 默认每个服务都在一个 screen 中以进程方式运行,可以通过 screen -x stack 进入查看)。
./unstack.sh
清除安装。
./clean.sh
有时候有些文件可能清除不干净,手动执行
sudo rm -rf /etc/libvirt/qemu/inst* sudo virsh list | grep inst | awk '{print $1}' | xargs -n1 virsh destroy
安装过程中可能会报某些包版本不满足的问题,手动安装后。
例如报 six 包版本过低。
sudo pip install six --upgrade
重新安装,执行如下命令即可。