利用kolla-ansible,手动准备OpenStack环境
前期准备
- 本文环境
控制节点:controller
计算节点:node1
OpenStack版本:Ussuri
操作系统:CentOS 8.2
- 最小配置要求
8G内存,40G硬盘,双网卡
- 更改主机名
控制节点
hostnamectl set-hostname controller
计算节点
hostnamectl set-hostname node1
- 主机名解析
编辑/etc/hosts,增加条目(所有节点)
192.168.174.133 controller
192.168.174.134 node1
- 创建cinder-volumes卷组(可选,用于LVM)
所有计算节点,准备一个分区用来创建vg,这里创建一个sdb1的主分区
fdisk /dev/sdb
n -> ... -> w # 依次选择
// 刷新分区表
partprobe
// 创建pv
pvcreate /dev/sdb1
// 创建vg
vgcreate cinder-volumes /dev/sdb1
- 安装依赖
cd /etc/yum.repos.d/
mv CentOS-Base.repo CentOS-Base.repo.bak
wget -O CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-8.repo
yum clean all
yum makecache
yum install epel-release
yum update
yum install make gcc zlib-devel openssl-devel python3-devel libffi-devel python3-libselinux
1. 安装Python3
wget https://www.python.org/ftp/python/3.7.9/Python-3.7.9.tgz
tar -xf Python-3.7.9.tgz
cd Python-3.7.9/
./configure --with-ssl
make -j 4 && make install
2. 准备Python虚拟环境(推荐,非必须)
- 创建虚拟环境
# // (/PATH/TO/venv,这里使用/usr/lib/python3/venv)
python3 -m venv /usr/lib/python3/venv
source /usr/lib/python3/venv/bin/activate
- 升级pip
pip install -U pip
如果启用了虚拟环境,后续所有操作需要在虚拟环境下进行
参考:
https://docs.openstack.org/kolla-ansible/ussuri/user/virtual-environments.html
3. 安装docker
- 安装docker服务(所有节点)
cd /etc/yum.repos.d/
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
// CentOS8 需要升级containerd.io版本
yum install https://mirrors.aliyun.com/docker-ce/linux/centos/7/x86_64/edge/Packages/containerd.io-1.2.13-3.1.el7.x86_64.rpm
yum install docker-ce docker-ce-cli
systemctl enable docker.service
systemctl start docker.service
- 镜像加速
执行以下命令,修改docker源
tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://reg-mirror.qiniu.com", "https://hub-mirror.c.163.com/"]
}
EOF
- 安装python docker模块
pip install docker
4. 安装kolla-ansible
- 安装ansible
yum install ansible
- 安装kolla-ansible
可选择源码安装,或pip安装,这里使用pip
pip install 'ansible<2.10'
pip install kolla-ansible
- 创建kolla配置目录
sudo mkdir -p /etc/kolla
sudo chown $USER:$USER /etc/kolla
- 拷贝yml配置文件
cp -r /usr/lib/python3/venv/share/kolla-ansible/etc_examples/kolla/* /etc/kolla
- 拷贝all-in-one、multinode 清单文件到当前目录(任意工作目录,这里是在root目录下)
cd /root
cp /usr/lib/python3/venv/share/kolla-ansible/ansible/inventory/* .
- 编辑/etc/ansible/ansible.cfg
[defaults]
host_key_checking=False
pipelining=True
forks=100
5. ansible初始配置
- 打开当前目录multinode文件
修改IP、用户名和密码,并对需要安装的内容进行调整
[control]
10.0.0.[10:12] ansible_user=root ansible_password=123456 ansible_become=true
# Ansible supports syntax like [10:12] - that means 10, 11 and 12.
# Become clause means "use sudo".
[network:children]
control
# when you specify group_name:children, it will use contents of group specified.
[compute]
10.0.0.[13:14] ansible_user=root ansible_password=123456 ansible_become=true
[monitoring] 10.0.0.10
# This group is for monitoring node.
# Fill it with one of the controllers' IP address or some others.
[storage:children] compute [deployment] localhost ansible_connection=local become=true # use localhost and sudo
.. (略)
- 检查inventory配置
ansible -i multinode all -m ping
6. 配置passwords.yml
/etc/kolla/passwords.yml里的初始密码为空,通过下面命令生成随机密码
kolla-genpwd
此时,如有需要可以手动编辑passwords.yml文件,更改组件初始密码,如keystone_admin_password。
7. 配置global.yml
global.yml是Kolla-Ansible的主配置文件,编辑/etc/kolla/globals.yml文件。
- 修改镜像选项
kolla_base_distro:默认为"centos",如果是其他发行版需要手动更改。
kolla_install_type:默认为”binary“
- 修改网络选项
network_interface:管理网络接口,默认为“eth0”
neutron_external_interface:Neutron外部网络,可以是vlan或flat类型。需要激活并且不配置IP。
kolla_internal_vip_address:管理的浮动IP,连接到network_interface,需要设置一个管理网络中未被使用的地址。
--enable_*:额外启用的服务,如enable_cinder。
--enable_cinder_backend_*: 在启用了cinder后需要至少启用一个cinder后端,如enable_cinder_backend_lvm。
8. 部署
- 确保libvirtd服务停止
systemctl stop libvirtd
- 检查kolla部署依赖
kolla-ansible -i ./multinode bootstrap-servers -e ' ansible_python_interpreter=/etc/kolla/venv/bin/python3'
-e 表示加的一些配置,这里指定使用的python解释器
- 主机预部署检查
kolla-ansible -i ./multinode prechecks -e 'ansible_python_interpreter=/usr/lib/python3/venv/bin/python3'
- 安装
kolla-ansible -i ./multinode deploy -e 'ansible_python_interpreter=/usr/lib/python3/venv/bin/python3'