linux kvm服务,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创建的虚拟机而已

#这里提供虚拟机设置截图

55fd2b2273b5a8b4531f72773c469d6e.gif

1.JPG (105.46 KB, 下载次数: 0)

虚拟机CUP虚拟化开启

2020-7-12 10:38 上传

2:配置yum源

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

4:[root@localhost ~]# systemctl start libvirtd                                                                //启动libvirtd服务

5:[root@localhost ~]# ln -s /usr/libexec/qemu-kvm /usr/bin/qemu-kvm                        //将usr/libexec/qemu-kvm链接为usr/bin/qemu-kvm

6:创建NAT模式KVM虚拟机

[root@localhost ~]# chmod 777 /root/qume-ifup-NAT                                                 //给予脚本执行权限(很多东西都可能是由于权限从而导致无法启动或使用的)

7:[root@localhost ~]# 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

1.JPG

(105.46 KB, 下载次数: 2)

2020-7-12 10:40 上传

bdea3cdfc23f0ffcd8d939d1761025e0.gif

6589598f1a9e053326bdd97ddb840118.gif

55fd2b2273b5a8b4531f72773c469d6e.gif

你可能感兴趣的:(linux,kvm服务)