kolla-ansible部署openstack的all-in-one环境(stein版)

1. 初始化系统环境

1.1 系统准备

2 network interfaces
8GB main memory
40GB disk space

1.2 关闭selinux

vi /etc/selinux/config
SELINUX=disabled

1.3 关闭防火墙

systemctl stop firewalld
​
systemctl disable firewalld

1.4 关闭libvirtd服务

systemctl stop libvirtd.service 
​
systemctl disable libvirtd.service

1.5 更新yum源以及内核

curl -o /etc/yum.repos.d/CentOS-Base.repo / http://mirrors.aliyun.com/repo/Centos-7.repo
​
# 清理缓存
yum makecache
​
yum update

2. 安装docker

curl -sSL https://get.docker.io | bash
设置共享:
tee /etc/systemd/system/docker.service.d/kolla.conf <<-'EOF'
[Service]
MountFlags=shared
EOF
修改docker镜像源
sudo vi /etc/docker/daemon.json 
​
{
"registry-mirrors": [
"https://kfwkfulq.mirror.aliyuncs.com",
"https://2lqq34jg.mirror.aliyuncs.com",
"https://pee6w651.mirror.aliyuncs.com",
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com"
],
"dns": ["8.8.8.8","8.8.4.4"]
}
重启docker:
systemctl restart docker

3. 安装依赖:

yum install git
​
yum install -y epel-release  
​
yum install -y python-pip 
​
pip install -U pip 
​
yum install python-devel libffi-devel gcc openssl-devel libselinux-python

4. 安装ansible

yum install ansible

5. 从github 获取Kolla和Kolla-Ansible

git clone https://github.com/openstack/kolla -b stable/stein
​
git clone https://github.com/openstack/kolla-ansible -b stable/stein

# 如果已有镜像,只执行第二步即可

6. 安装依赖

# 手动安装kolla-ansible
python kolla-ansible/setup.py install
​
pip install -r ./kolla/requirements.txt 
​
pip install -r ./kolla-ansible/requirements.txt

7. 拷贝配置文件

cp -r ./kolla-ansible/etc/kolla /etc/kolla 
​
cp kolla-ansible/ansible/inventory/* .

# 单节点默认使用all-in-one不用做修改,多节点部署需要修改multinode

检查playbook文件配置是否正确

# 单节点
ansible -i all-in-one all -m ping
​
# 多节点
ansible -i multinode all -m ping

8. 生成随机密码

kolla-genpwd
使用kolla提供的密码生成工具自动生成,如果密码不填充,后面的部署环境检查时不会通过。

   为了后面登录方便,可以自定义keystone_admin_password密码,这里改为admin

vi /etc/kolla/passwords.yml

keystone_admin_password:admin

9. 修改globals.yml

vi /etc/kolla/globals.yml

# 指定镜像的系统版本
kolla_base_distro: "centos"

# 指定安装的方式,source为源码
kolla_install_type: "source"

# openstack版本
openstack_release: "stein"

# OpenStack使用的网络接口
network_interface: "[Bond0]"

# 宿主机IP
kolla_internal_address: "[172.28.3.101]"

# Neutron外部网络,必须是没有绑定ip的可用网卡,否则实例无法访问外部网络
neutron_external_interface: "[enp26s0f1]"

# 如果单点部署,高可用设为no
enable_haproxy: "no"

enable_placement: "yes"

# 使用cinder存储
enable_cinder: "yes"
enable_glance: "yes"
enable_magnum: "yes"
enable_heat: "yes"

# 如果使用lvm,需先创建cinder-volumes的卷组
enable_cinder_backend_lvm: "yes"

创建卷组的方法如下:

1. dd if=/dev/zero of=./disk.img count=200 bs=512MB

2. losetup -f

3. losetup /dev/loop0 disk.img

4. pvcreate /dev/loop0

5. vgcreate cinder-volumes /dev/loop0

10. 下载镜像

部署时,会检查本地有没有镜像,有的话,使用本地,没有,自动拉取,由于镜像特别大,先下载镜像到本地

kolla-ansible pull

拉取镜像的方法可以参考这篇博客:

https://xuchao918.github.io/2018/05/07/%E5%A6%82%E4%BD%95%E8%8E%B7%E5%8F%96Kolla%E7%9A%84OpenStack%E9%95%9C%E5%83%8F/

11. 开始部署

11.1 带有kolla的引导服务器部署依赖关系

kolla-ansible -i ./all-in-one bootstrap-servers

11.2 对主机执行预部署检查

kolla-ansible -i ./all-in-one prechecks

11.3 执行OpenStack部署

kolla-ansible -i ./all-in-one deploy

12. 后续的配置

12.1 安装openstack CLI客户端:

pip install python-openstackclient

12.2 OpenStack需要一个openrc文件,其中设置了admin用户的凭证,依次执行:

kolla-ansible post-deploy 

. /etc/kolla/admin-openrc.sh

12.3 在浏览器输入IP即可访问,界面如图所示:

 部署时的常见错误汇总在这里:

https://www.cnblogs.com/chaofan-/p/11715402.html

原文地址:https://www.cnblogs.com/chaofan-/p/11714741.html