OpenStack Kolla-Ansible部署Octavia负载均衡服务
书接上回 OpenStack Kolla-Ansible部署Swift文件存储 对接Ceph RadosGW,Proxmox
本章我们继续来完成OpenStack示例配置组件之Container Optimized中的Octavia负载均衡服务,OpenStack Kolla-Ansible部署Octavia负载均衡服务
Octavia 以服务的形式提供负载均衡。本指南涵盖了为 Amphora 驱动程序配置 Octavia。有关详细信息,请参阅Octavia 文档。安装指南是一个有用的参考。
1. 启用 Octavia
进入部署机,找到 /etc/kolla/globals.yml,并设置
1 | enable_octavia: "yes" |
2. 自动生成证书
1 | kolla-ansible octavia-certificates |
证书和密钥将在 /etc/kolla/config/octavia.
3. 重新部署
1 | kolla-ansible -i ./multinode deploy --tags common,horizon,octavia |
4. 构建Amphora镜像
4.1 安装依赖
1 | sudo apt -y install debootstrap qemu-utils git kpartx |
4.2 获取 Octavia 源代码
建议用国内git平台镜像一份
1 | # 官网命令(不建议) |
4.3 安装diskimage-builder
1 | python3 -m venv dib-venv |
4.4 镜像源
下一步需要下载大量文件,需要克隆几个仓库,建议使用jihulab.com。如果网关有魔法可以跳过这一步。
下面是需要设置的部分环境变量
- DIB_REPOLOCATION_amphora_agent(将安装在映像中的 amphora-agent 代码的位置)
默认值:https ://opendev.org/openstack/octavia
- DIB_REPOLOCATION_octavia_lib(将安装在映像中的 octavia-lib 代码的位置)
默认值:https ://opendev.org/openstack/octavia-lib
- DIB_PYPI_MIRROR_URL
- DIB_REPOLOCATION_upper_constraints(upper-constraints.txt依赖包)
默认值:https://opendev.org/openstack/requirements/raw/branch/master/upper-constraints.txt
- DIB_DISTRIBUTION_MIRROR(所选基本操作系统的镜像 URL)
注意,这个镜像url是给Ubuntu用的,必须是http。推荐使用中国科学技术大学镜像(http)
导出环境变量
1 | export DIB_REPOLOCATION_amphora_agent=https://jihulab.com/eric-gitta-moore/octavia.git |
4.5 创建 Amphora 镜像
1 | cd octavia/diskimage-create |
构建成功输出如下
1 | 2023-02-07 07:17:59.379 | Converting image using qemu-img convert |
完成后执行,注意切换python虚拟环境
1 | kolla-ansible post-deploy |
4.5.1 常见问题
有可能会碰到依赖版本冲突,整理日志之后如下
1 | 2023-02-07 05:26:03.331 | ERROR: Cannot install octavia because these package versions have conflicting dependencies. |
或者
1 | 2023-02-07 06:58:49.465 | ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 119.9/119.9 kB 341.3 kB/s eta 0:00:00 |
这个之后需要手动编辑 upper-constraints.txt
先把文件下载过来
1 | wget https://jihulab.com/eric-gitta-moore/requirements/-/raw/stable/yoga/upper-constraints.txt -O /tmp/upper-constraints.txt |
然后编辑 upper-constraints.txt
注释冲突的软件包
1 | # oslo.cache===2.10.1 |
修改环境变量
1 | export DIB_REPOLOCATION_upper_constraints=file:///tmp/upper-constraints.txt |
重新构建镜像
5. 激活octavia授权
1 | . /etc/kolla/octavia-openrc.sh |
6. 在 Glance 中注册镜像
1 | openstack image create amphora-x64-haproxy.qcow2 --container-format bare --disk-format qcow2 --private --tag amphora --file /root/octavia/diskimage-create/amphora-x64-haproxy.qcow2 --property hw_architecture='x86_64' --property hw_rng_model=virtio |
7. 验证结果
7.1 验证命令行
列出所有负载均衡器
1 | openstack loadbalancer list |
如果出现
1 | openstack: 'loadbalancer' is not an openstack command. See 'openstack --help'. |
安装python-octaviaclient
1 | pip install python-octaviaclient |
没报错就可以了