skyline-apiserver/kolla/README-zh_CN.md
yangshaoxue f47fa7dcd5 Integration with Kolla and Kolla-Ansible
1. Add kolla and kolla-ansible integrated patch
2. Add README to introduce how we can build skyline image with kolla
and deploy skyline with kolla-ansible
3. Add kolla folder as irrelevant files into jobs

Change-Id: I0cc7e9ddd62fc3e20564bf8a0d98d5c7b8f8abac
2021-10-19 16:11:07 +08:00

4.9 KiB
Raw Blame History

Kolla Ansible 部署

环境准备

部署环境配置建议:
2个网络接口
8GB内存
100GB磁盘
ubuntu20.04 / centos8

  • kolla : https://github.com/openstack/kolla
  • kolla-ansible : https://github.com/openstack/kolla-ansible
  • kolla skyline patch包 : https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-xxxxxxx.diff
  • kolla-ansible skyline patch包 : https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-ansible-xxxxxxx.diff

kolla build docker image

  • 若部署环境未安装 kolla

    cd /opt
    git clone https://github.com/openstack/kolla
    curl https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-xxxxxxx.diff -o kolla.diff
    cd /opt/kolla
    git apply --check /opt/kolla.diff
    git apply /opt/kolla.diff
    sudo pip3 install /opt/kolla
    
  • 若部署环境已安装 kolla

    获取 kolla 安装目录

    KOLLA_PACKAGE_PATH=$(python3 -c "import kolla;from pathlib import Path;print(Path(kolla.__file__).parents[1])")
    KOLLA_DATA_FILES_PATH=$(python3 -c "import kolla;from pathlib import Path;print(Path(kolla.__file__).parents[4].joinpath('share/kolla'))")
    

    安装 kolla patch 包

    curl https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-xxxxxxx.diff -o /opt/kolla.diff
    cd ${KOLLA_PACKAGE_PATH}
    git apply --check --include='kolla/*' /opt/kolla.diff
    git apply --include='kolla/*' /opt/kolla.diff
    cd ${KOLLA_DATA_FILES_PATH}
    git apply --check --include='docker/*' /opt/kolla.diff
    git apply --include='docker/*' /opt/kolla.diff
    

skyline 镜像构建

注 : skyline 镜像目前仅支持 ubuntu-source-skyline 版本

  • -b:基础镜像类型
  • -t:安装方式
  • -n:命名空间
  • --tag:标签
  • --registry:docker仓库
  • --push:镜像构建之后自动推送
kolla-build -b ubuntu -t source -n kolla --tag master --registry 127.0.0.1:4000 --push skyline

kolla-ansible install

kolla-ansible 安装

  • 若部署环境未安装 kolla-ansible

    cd /opt
    git clone https://github.com/openstack/kolla-ansible
    curl https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-ansible-xxxxxxx.diff -o kolla-ansible.diff
    cd /opt/kolla-ansible
    git apply --check /opt/kolla-ansible.diff
    git apply /opt/kolla-ansible.diff
    sudo pip3 install /opt/kolla-ansible
    
  • 若部署环境已安装 kolla-ansible

    获取 kolla-ansible 安装目录

    KOLLA_ANSIBLE_DATA_FILES_PATH=$(python3 -c "import kolla_ansible;from pathlib import Path;print(Path(kolla_ansible.__file__).parents[4].joinpath('share/kolla-ansible'))")
    

    安装 kolla-ansible patch 包

    curl https://opendev.org/skyline/skyline-apiserver/src/branch/master/kolla/kolla-ansible-xxxxxxx.diff -o /opt/kolla-ansible.diff
    cd ${KOLLA_ANSIBLE_DATA_FILES_PATH}
    git apply --check --include='ansible/*' /opt/kolla-ansible.diff
    git apply --include='ansible/*' /opt/kolla-ansible.diff
    

配置文件

  • 若没有配置文件(globals.yml/passwords.yml/all-in-one/multinode),复制配置文件并生成密码

    sudo mkdir -p /etc/kolla
    sudo chown $USER:$USER /etc/kolla
    cp -r kolla-ansible/etc/kolla/* /etc/kolla
    cp kolla-ansible/ansible/inventory/* .
    kolla-genpwd
    
  • 若已有配置文件,则需要手动更改

    • 编辑 all-in-onemultinode 并增加以下配置项

      [skyline:children]
      control
      
    • 编辑 /etc/kolla/passwords.yml 并增加以下配置项,自定义密码或使用 kolla-genpwd 命令生成以下配置密码

      skyline_database_password:
      skyline_keystone_password:
      

创建并编辑 /etc/ansible/ansible.cfg 文件

[defaults]
host_key_checking=False
pipelining=True
forks=100

编辑 /etc/kolla/globals.yml 文件根据构建的skyline镜像更改配置项

network_interface: "eth0"
neutron_external_interface: "eth1"
kolla_internal_vip_address: "192.168.10.250"
enable_skyline: "yes"
docker_registry: "127.0.0.1:4000"
docker_namespace: "kolla"
kolla_base_distro: "ubuntu"
kolla_install_type: "source"

skyline 部署

注 : 环境需已安装 Openstack 基础模块

kolla-ansible 进行 skyline 部署,选择 all-in-onemultinode 配置文件

kolla-ansible -i ./all-in-one bootstrap-servers -t skyline
kolla-ansible -i ./all-in-one prechecks -t skyline
kolla-ansible -i ./all-in-one deploy -t skyline

FAQ

在 skyline 镜像构建 和 skyline 部署过程中出现本地仓库 "connect: connection refused" 错误

编辑 /etc/docker/daemon.json 文件,删除以下配置项

bridge: "none"

重启 docker 服务

sudo service docker restart

启动本地镜像 registry

docker run -d --name registry --restart=always -p 4000:5000 -v registry:/var/lib/registry registry:2