yangheng48 发表于 2020-7-12 10:48

linux学习笔记—使用KVM服务创建虚拟机

环境:单节点规划,将cirros-0.3.3-x86_64-disk.img镜像与qemu-ifup-NAT脚本文件上传到root目录下    #由于我没有0.3.3所以用0.3.4代替,大家可以使用IDM下载器去官网下载0.3.3版本
小生在代码后面提供qemu-ifup-NAT脚本源码,也不劳费大家去github上找了


1:grep -E '(svm|vmx)' /proc/cpuinfo                                                                                 //查看CPU是否支持虚拟化(这一步大家不必在乎返回结果)
#若物理CPU支持虚拟化,需要在虚拟机设置:处理器虚拟化Intel ,且需要在BIOS中开启VT,如果不支持也没关系,不影响下面操作,只是开不了KVM创建的虚拟机而已
#这里提供虚拟机设置截图



2:配置yum源

3:@localhost ~]# yum install -y qemu-kvm openssl libvirt                                      //使用yum命令安装KVM的主要组件及工具

4:# systemctl start libvirtd                                                                //启动libvirtd服务

5:# ln -s /usr/libexec/qemu-kvm /usr/bin/qemu-kvm                        //将usr/libexec/qemu-kvm链接为usr/bin/qemu-kvm

6:创建NAT模式KVM虚拟机
# chmod 777 /root/qume-ifup-NAT                                               //给予脚本执行权限(很多东西都可能是由于权限从而导致无法启动或使用的)

7:# qemu-kvm -m 1024 file=/root/cirros-0.3.4-x86_64-disk.img,if=virtio -net nic,model=virtio -net tap,script=/root/qemu-ifup-NAT -nographic -vnc:1                                                                        //通过qemu-kvm命令启动KVM虚拟机——#注意自己的路径和镜像版本

8:验证
#创建虚拟机完成后,cirros用户登录虚拟机,输入用户名为cirros,密码为cubswin:)。然后输入ip a命令查询IP地址,最后输入route -n命令查询路由表即可完成
需要注意,若物理CPU支持VT虚拟化,则做在第7步创建启动过程即可,使用ip a 查看是否有这个IP地址即可——192.168.122.1

9:qemu-ifup-NAT脚本源码

#!/bin/bash
# qemu-ifup script for QEMU/KVM with NAT netowrk mode

# set your bridge name
BRIDGE=virbr0                                                                                               

# Network information
NETWORK=192.168.122.0
NETMASK=255.255.255.0
# GATEWAY for internal guests is the bridge in host
GATEWAY=192.168.122.1
DHCPRANGE=192.168.122.2,192.168.122.254

# Optionally parameters to enable PXE support
TFTPROOT=
BOOTP=

function check_bridge()
{
        if brctl show | grep "^$BRIDGE" &> /dev/null; then
                return 1
        else
                return 0
        fi
}

function create_bridge()
{
          brctl addbr "$BRIDGE"
          brctl stp "$BRIDGE" on
          brctl setfd "$BRIDGE" 0
          ifconfig "$BRIDGE" "$GATEWAY" netmask "$NETMASK" up
}

function enable_ip_forward()
{
        echo 1 > /proc/sys/net/ipv4/ip_forward
}

function add_filter_rules()
{
        iptables -t nat -A POSTROUTING -s "$NETWORK"/"$NETMASK" \
                ! -d "$NETWORK"/"$NETMASK" -j MASQUERADE
}

function start_dnsmasq()
{
        # don't run dnsmasq repeatedly
        ps -ef | grep "dnsmasq" | grep -v "grep" &> /dev/null
        if [ $? -eq 0 ]; then
                echo "Warning:dnsmasq is already running. No need to run it again."
                return 1
        fi

        dnsmasq \
                --strict-order \
                --except-interface=lo \
                --interface=$BRIDGE \
                --listen-address=$GATEWAY \
                --bind-interfaces \
                --dhcp-range=$DHCPRANGE \
                --conf-file="" \
                --pid-file=/var/run/qemu-dnsmasq-$BRIDGE.pid \
                --dhcp-leasefile=/var/run/qemu-dnsmasq-$BRIDGE.leases \
                --dhcp-no-override \
                ${TFTPROOT:+"--enable-tftp"} \
                ${TFTPROOT:+"--tftp-root=$TFTPROOT"} \
                ${BOOTP:+"--dhcp-boot=$BOOTP"}
}

function setup_bridge_nat()
{
        check_bridge "$BRIDGE"
        if [ $? -eq 0 ]; then
                create_bridge
        fi
        enable_ip_forward
        add_filter_rules "$BRIDGE"
        start_dnsmasq "$BRIDGE"
}

# need to check $1 arg before setup
if [ -n "$1" ]; then
        setup_bridge_nat
        ifconfig "$1" 0.0.0.0 up
        brctl addif "$BRIDGE" "$1"
        exit 0
else
        echo "Error: no interface specified."
        exit 1
fi

waltzofjack 发表于 2020-7-12 10:59

nin zhen deqian xu

那年夏天52 发表于 2020-7-12 11:13

我觉得有点水了

我爱小彤 发表于 2020-7-12 11:30

直接docker
页: [1]
查看完整版本: linux学习笔记—使用KVM服务创建虚拟机