该系列文章为制作KVM虚拟机镜像的同时配置静态IP,为用户直接提供好固定IP,无需手动配置

系列文章目录

  1. Ubuntu16.04
  2. Ubuntu18.04
  3. Centos6
  4. Centos7


软件环境

  • 服务器操作系统:Ubuntu 16.04
  • 内核版本:4.15.0-142-generic
  • QEMU版本:2.5.0
  • virt-manager版本:1.3.2

一、安装Centos7

在搭建好KVM环境的服务器上通过Centos7的iso文件安装好一台虚拟机

二、镜像定制化

1. 关闭防火墙

systemctl stop firewalld.service
systemctl disable firewalld.service

2. 关闭selinux

编辑/etc/selinux/config文件,并修改以下内容

SELINUX=disabled

3. 使用qemu-ga管理虚拟机

安装配置完以下软件后关闭虚拟机

yum install qemu-guest-agent
systemctl start qemu-guest-agent 
systemctl enable qemu-guest-agent

在服务器上修改虚拟机的xml文件

sudo virsh edit centos7(虚拟机名称)

在xml文件中添加以下内容后重启虚拟机

<channel type="unix">
  <source mode="bind"/>
  <target type="virtio" name="org.qemu.guest_agent.0"/>
</channel>

在服务器上测试qemu-ga是否可以使用,执行以下命令看是否能输出虚拟机的IP地址

sudo virsh qemu-agent-command centos7(虚拟机名称) '{"execute":"guest-network-get-interfaces"}'

4. 配置console

在虚拟机进行以下配置

  • 修改/etc/default/grub文件,添加console=ttyS0,115200到GRUB_CMDLINE_LINUX参数
GRUB_CMDLINE_LINUX="crashkernel=auto rd.lvm.lv=cl/root rd.lvm.lv=cl/swap rhgb quiet console=ttyS0,115200”
  • 在虚拟机中执行以下命令后重启虚拟机
systemctl start serial-getty@ttyS0.service
systemctl enable serial-getty@ttyS0.service
  • 测试console是否能用,在服务器中执行以下命令看能否连接到虚拟机
sudo virsh console centos7(虚拟机名称)

三、进行静态IP配置

主要的思路主要是通过cloud-init工具,在虚拟机创建的时候进行初始化操作,执行脚本文件配置自动配置静态IP,以下操作在虚拟机中完成

1. 安装cloud-init

yum install cloud-init

2. 重命名其他配置文件

进入/etc/cloud/cloud.cfg.d,将该目录的所有以.cfg结尾的文件重命名,这样做的原因为cloud-init在执行初始化的时候会执行/etc/cloud/下所有以.cfg结尾的文件,并以最后一个为准,所以其他文件会导致我们的配置文件执行失败

sudo mv 05_logging.cfg 05_logging.cfg.bak

3. 修改cloud-init配置文件

进入/etc/cloud/,备份并修改cloud.cfg文件

sudo cp cloud.cfg cloud.cfg.bak
sudo vim cloud.cfg

将cloud.cfg中的所有内容修改为以下内容,该文件以yaml格式为准,需要注意格式

datasource_list: [ None ]

runcmd: 
  - sh /etc/cloud/network_static.sh

# The modules that run in the 'init' stage
cloud_init_modules:
 - migrator
 - seed_random
 - bootcmd
 - write-files
 - growpart
 - resizefs
 - disk_setup
 - mounts
 - set_hostname
 - update_hostname
 - update_etc_hosts
 - ca-certs
 - rsyslog
 - users-groups
 - ssh

# The modules that run in the 'config' stage
cloud_config_modules:
# Emit the cloud config ready event
# this can be used by upstart jobs for 'start on cloud-config'.
 - emit_upstart
 - snap
 - ssh-import-id
 - locale
 - set-passwords
 - grub-dpkg
 - apt-pipelining
 - apt-configure
 - ubuntu-advantage
 - ntp
 - timezone
 - disable-ec2-metadata
 - runcmd
 - byobu

# The modules that run in the 'final' stage
cloud_final_modules:
 - package-update-upgrade-install
 - fan
 - landscape
 - lxd
 - ubuntu-drivers
 - puppet
 - chef
 - mcollective
 - salt-minion
 - reset_rmc
 - refresh_rmc_and_interface
 - rightscale_userdata
 - scripts-vendor
 - scripts-per-once
 - scripts-per-boot
 - scripts-per-instance
 - scripts-user
 - ssh-authkey-fingerprints
 - keys-to-console
 - phone-home
 - final-message
 - power-state-change

以下为部分重要内容的解释:

1. datasource_list: [ None ]:设置获取源信息的数据源为空,如果不设置,则默认到外网下载,会导致虚拟机初始化失败
2. runcmd: 在配置模块中执行以下命令,即在初始化的时候执行我们编写的网络配置脚本文件进行静态IP配置
    - sh /etc/cloud/network_static.sh

4. 编写网络配置脚本文件

进入/etc/cloud,创建network_static.sh脚本文件并写入以下内容:

interface=eth0
ip=$(ifconfig $interface | grep inet | grep -v 127.0.0.1 | grep -v inet6 | awk -F " " '{print $2}')
mask=$(ifconfig $interface | grep netmask | awk -F " " '{print $4}')
route=$(route -n | grep $interface | awk 'NR==1' | awk '{print $2}')

echo "DEVICE=$interface
BOOTPROTO=static
IPADDR=$ip
NETMASK=$mask
GATEWAY=$route
ONBOOT=yes
TYPE=Ethernet
DNS1=8.8.8.8" | tee /etc/sysconfig/network-scripts/ifcfg-eth0 | cat > /dev/null

service network restart

该脚本适用于虚拟机包含单个网卡的情况,多块网卡没有进行测试,其中interface参数需要根据自己的实际情况进行修改,进行以上操作后关闭虚拟机

四、将虚拟机制作成镜像

在服务器上执行以下操作进行标准镜像的创建

1. 清理镜像内的缓存信息

sudo virt-sysprep -d centos7(虚拟机名称)

2. 压缩镜像文件

进入到虚拟机镜像存储的位置,进行压缩操作

sudo virt-sparsify --compress centos7.qcow2 Centos7.qcow2

3. KVM虚拟机配置静态IP——Centos7配置完成

参考内容

  1. Centos镜像定制:链接
  2. cloud-init使用:链接
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐