kubeasz/docs/setup/offline_install.md

2.2 KiB
Raw Blame History

离线安装集群

kubeasz 2.0.1 开始支持完全离线安装,目前已测试 Ubuntu1604|1804 CentOS7 Debian9|10 系统。

离线文件准备

在一台能够访问互联网的服务器上执行:

# 下载工具脚本easzup举例使用kubeasz版本2.0.3
export release=2.0.3
curl -C- -fLO --retry 3 https://github.com/easzlab/kubeasz/releases/download/${release}/easzup
chmod +x ./easzup
# 使用工具脚本下载
./easzup -D

执行成功后,所有文件均已整理好放入目录/etc/ansilbe,只要把该目录整体复制到任何离线的机器上,即可开始安装集群,离线文件包括:

  • kubeasz 项目代码 --> /etc/ansible
  • kubernetes 集群组件二进制 --> /etc/ansible/bin
  • 其他集群组件二进制etcd/CNI等--> /etc/ansible/bin
  • 操作系统基础依赖软件包haproxy/ipvsadm/ipset/socat等--> /etc/ansible/down/packages
  • 集群基本插件镜像coredns/dashboard/metrics-server等--> /etc/ansible/down

离线文件不包括:

  • 管理端 ansible 安装,但可以使用 kubeasz 容器运行 ansible 脚本
  • 其他更多 kubernetes 插件镜像

离线安装

上述下载完成后,把/etc/ansible整个目录复制到目标离线服务器相同目录,然后在离线服务器上运行:

# 离线安装 docker检查本地文件正常会提示所有文件已经下载完成
./easzup -D

# 启动 kubeasz 容器
./easzup -S

# 设置参数,启用离线安装
sed -i 's/^INSTALL_SOURCE.*$/INSTALL_SOURCE: "offline"/g' /etc/ansible/roles/chrony/defaults/main.yml
sed -i 's/^INSTALL_SOURCE.*$/INSTALL_SOURCE: "offline"/g' /etc/ansible/roles/ex-lb/defaults/main.yml
sed -i 's/^INSTALL_SOURCE.*$/INSTALL_SOURCE: "offline"/g' /etc/ansible/roles/kube-node/defaults/main.yml
sed -i 's/^INSTALL_SOURCE.*$/INSTALL_SOURCE: "offline"/g' /etc/ansible/roles/prepare/defaults/main.yml

# 进入容器执行安装,参考 https://github.com/easzlab/kubeasz/blob/master/docs/setup/quickStart.md
docker exec -it kubeasz easzctl start-aio

# 或者按照文档 https://github.com/easzlab/kubeasz/blob/master/docs/setup/00-planning_and_overall_intro.md 集群规划后安装
#ansible-playbook 90.setup.yml