此文是对尝试 https://github.com/csmart/virt-infra-ansible 的记录。
我们的目标是用 Ansible 快速搭建出一个 miniCloud 环境,以方便以后部署基于 K8S 的各种生产力工具。虽然 VMware vSphere 很好用,但因为 lisence 及价格的因素,KVM 是最适合拿来使用的 Hypervisor。
在宿主机上需要以下软件:
- Ansible
- KVM
- KVM 用户空间工具
- SSH keys
- Guest Image
可运行以下命令准备环境:
代码语言:javascript复制 # Create SSH key if you don't have one
ssh-keygen
# libvirtd
sudo yum groupinstall -y "Virtualization Host"
sudo systemctl enable --now libvirtd
# Ansible
sudo yum install -y epel-release
sudo yum install -y python36
pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple --user ansible
# Other deps
sudo yum install -y
git
genisoimage
libguestfs-tools-c
libosinfo
python3
python3-libvirt
python3-lxml
python3-pip
libselinux-python3
qemu-img
virt-install
国内用户为了使用 yum 时有更快的下载速度,可以设置 yum 国内镜像源。
代码语言:javascript复制mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
pip 使用 -i https://pypi.tuna.tsinghua.edu.cn/simple 参数使用国内源。
确定要操作的网络接口及名称:
代码语言:javascript复制export NET_DEV=em1
sudo nmcli con |egrep -w "${NET_DEV}"
export NM_NAME=em1
通过 ip 命令创建网桥:
代码语言:javascript复制sudo ip link add name br0 type bridge
sudo ip addr add 192.168.1.10/24 dev br0
sudo ip link set dev em1 master br0 ; sudo ip addr del 192.168.1.10/24 dev em1 ; sudo ip link set br0 up
如果修改之后 ping baidu.com 不通,可以坚持一下路由表。确认是否有 default 路由、em1 是否还在路由表里等。
代码语言:javascript复制route -v
sudo ip route add default via 192.168.1.10 dev br0
sudo ip route del 192.168.1.0/24 dev em1
也可以用 nmci 创建网桥 br0 并把物理网卡 em1 插到网桥上。
代码语言:javascript复制sudo nmcli con add ifname br0 type bridge con-name br0
sudo nmcli con add type bridge-slave ifname "${NET_DEV}" master br0
也可以通过 brctl 创建网桥:
代码语言:javascript复制brctl addbr br0
brctl addif br0 em1
接下来就可以运行一下命令自动创建 KVM Guests 了。
代码语言:javascript复制ansible-playbook --limit kvmhost,simple ./virt-infra.yml
用virt-manager查看创建的guests。
Reference:
https://github.com/csmart/virt-infra-ansible