1)创建虚拟机
准备自动化创建VM的脚本
checkout 用于创建 KVM Guest 的 Ansible 脚本。
代码语言:javascript复制cd ~/devenv_bootstrap/
git clone git@github.com:dhyuan/virt-infra-ansible.git
cd ~/devenv_bootstrap/virt-infra-ansible/roles
git clone https://github.com/dhyuan/ansible-role-virt-infra.git
cd ansible-role-virt-infra
git checkout -b devenv
git branch --set-upstream-to origin/devenv
git pull
基于自己的情况修改在 inventory 中定义的虚拟机参数
代码语言:javascript复制vi ~/devenv_bootstrap/virt-infra-ansible/k8s_masters.yml
vi ~/devenv_bootstrap/virt-infra-ansible/k8s_nodes.yml
如果我们希望利用 DHCP 服务让这些机器拥有固定的 IP,那么我们这里可以给虚拟机设置 mac 地址。
创建虚拟机
代码语言:javascript复制ansible-playbook ./virt-infra.yml
--limit kvmhost,k8s_masters,k8s_nodes
启动虚拟机
代码语言:javascript复制ansible-playbook ./virt-infra.yml
--limit kvmhost,k8s_masters,k8s_nodes
--extra-vars virt_infra_state=running
停止虚拟机
代码语言:javascript复制ansible-playbook ./virt-infra.yml
--limit kvmhost,k8s_masters,k8s_nodes
--extra-vars virt_infra_state=shutdown
删除虚拟机
强烈建议用 ansible 删除虚拟机,因为 KVM HOST 上的 hosts 文件、ssh 的一些配置也要修改。
代码语言:javascript复制ansible-playbook ./virt-infra.yml
--limit kvmhost,k8s_masters,k8s_nodes
--extra-vars virt_infra_state=undefined
更新虚拟机
代码语言:javascript复制ansible-playbook --ask-become-pass --inventory ./inventory ansible/update-vms.yaml
2)虚拟机准备完毕,下面开始安装docker。
在 KVMHost 上安装 docker role
代码语言:javascript复制ansible-galaxy install
--roles-path ~/.ansible/roles/
git https://github.com/haxorof/ansible-role-docker-ce.git,2.7.0
#
ansible-galaxy list
其代码保存在 ~/.ansible/roles/ansible-role-docker-ce
创建安装 docker 的 playbook
可以看到这里使用了国内docker镜像源,以提高下载速度。对于私有云环境,可以设置为自己内部镜像库地址。
代码语言:javascript复制[devops@192 virt-infra-ansible]$ cat install_docker.yml
---
- hosts: all,!kvmhost
vars:
docker_version: 19.03.8
docker_remove_pre_ce: false
docker_users: [devops]
docker_daemon_config:
registry-mirrors:
[
"http://ovfftd6p.mirror.aliyuncs.com",
"http://registry.docker-cn.com",
"http://docker.mirrors.ustc.edu.cn",
"http://hub-mirror.c.163.com",
]
insecure-registries: ["docker.mirrors.ustc.edu.cn"]
roles:
- role: ansible-role-docker-ce
[devops@192 virt-infra-ansible]$
在所有 k8s 节点上安装 docker engine。
这里的重点是使用了国内ali的docker-ce源。
代码语言:javascript复制ansible-playbook ./install_docker.yml
--limit k8s_masters,k8s_nodes -v
-e '{"docker_repository_url": {"CentOS": "http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo"}}'