主机和qemu虚拟机互相访问_kvm虚拟机下载

主机和qemu虚拟机互相访问_kvm虚拟机下载安装qemu/kvmyuminstallqemu-imgqemu-kvmqemu-kvm-toolsvirt-managervirt-viewervirt-v2vvirt-toplibvirtlibvirt-pythonlibvirt-clientpython-virtinstbridge-utilstunctl接下来就可以通过命令或者界面操虚拟机命令…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

安装 qemu/kvm

yum install qemu-img qemu-kvm qemu-kvm-tools virt-manager virt-viewer virt-v2v virt-top libvirt libvirt-python libvirt-client python-virtinst bridge-utils tunctl

接下来就可以通过命令或者界面操 虚拟机

命令操作可参考虚拟化之KVM virsh常用命令篇 – 某电商首席日志工程师 – 博客园

安装成功后界如下

主机和qemu虚拟机互相访问_kvm虚拟机下载主机和qemu虚拟机互相访问_kvm虚拟机下载

虚拟机与宿主机 通信

使用桥接方式

先在宿主集卡安装命令如下:

yum install bridge-utils.x86_64

(1)在宿主机创建一个桥接virbr0,并分配给其一个ip

brctl addbr virbr0
ifconfig br0 192.168.122.1

宿主机器ifconfig

主机和qemu虚拟机互相访问_kvm虚拟机下载

(2)宿主机中把一个 网卡和桥接口绑定

brctl addif virbr0 p9p1

查看

主机和qemu虚拟机互相访问_kvm虚拟机下载

但是自己测试宿主机不绑定也可以

(3)设置虚拟机通过桥接virbr0与宿主机桥接

主机和qemu虚拟机互相访问_kvm虚拟机下载

(4)在虚拟机中给一个网卡分配ip,ip必须和virbr0的ip在一个网段

主机和qemu虚拟机互相访问_kvm虚拟机下载主机和qemu虚拟机互相访问_kvm虚拟机下载

创建完就可以 和宿主机 互相ping了或者ssh了

网上资料如下:

   原文https://blog.csdn.net/u013451404/article/details/84929816

我们继续来讨论怎么将虚拟机中的网络桥接到宿主机的物理网卡。虚拟机使用桥接方式上网的示意图如下(注:本图是借用来的,如有侵权请联系我删除,感谢!),多个虚拟机都可以承载在宿主机的一个网卡上,每个虚拟机都可以有一个独立的ip地址,虚拟机可以访问外部网络,外部网络的设备也可以访问虚拟机。

虚拟机桥接宿主机的示意图

1、用ifconfig命令查看一下宿主机物理网卡对应的接口,我的服务器中有一个名为ens5的接口对应我的网卡。

    [linux@Centos ~]$ ifconfig ens5
    ens5: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            ether 1c:c1:de:9b:e9:ff  txqueuelen 1000  (Ethernet)
            RX packets 4  bytes 316 (316.0 B)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 12  bytes 928 (928.0 B)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
            device interrupt 17  
     
    [linux@Centos ~]$

2、在宿主机中安装网桥管理工具bridge-utils

yum install bridge-utils.x86_64

3、在宿主机中创建一个名为br0的桥接接口

sudo brctl addbr br0

4、在宿主机中将ens5添加到桥接组br0中

sudo brctl addif br0 ens5

5、检查桥接配置是否成功,可以看到ens5已经添加到了br0中了

    [linux@Centos qemu]$ sudo brctl show
    bridge name    bridge id        STP enabled    interfaces
    br0        8000.1cc1de9be9ff    no        ens5
    virbr0        8000.52540099455c    yes        virbr0-nic
    [linux@Centos qemu]$

6、为br0接口添加一个ip地址,我配置的是10.0.0.3

    [linux@Centos qemu]$ sudo ifconfig br0 10.0.0.3
    [linux@Centos qemu]$ sudo ifconfig
    br0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 10.0.0.3  netmask 255.0.0.0  broadcast 10.255.255.255
            inet6 fe80::1ec1:deff:fe9b:e9ff  prefixlen 64  scopeid 0x20<link>
            ether 1c:c1:de:9b:e9:ff  txqueuelen 1000  (Ethernet)
            RX packets 0  bytes 0 (0.0 B)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 7  bytes 578 (578.0 B)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
     
    ens5: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            ether 1c:c1:de:9b:e9:ff  txqueuelen 1000  (Ethernet)
            RX packets 0  bytes 0 (0.0 B)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 7  bytes 578 (578.0 B)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
            device interrupt 17  

7、验证宿主机桥接接口是否可以正常通信,ens5接口连接的对端设备的地址是10.0.0.10,我们在宿主机上ping一下这个地址,如果桥接配置成功是可以通过桥接接口ping通对端的,对端也可以ping能我们br0的10.0.0.3

    [linux@Centos ~]$ ping 10.0.0.10
    PING 10.0.0.10 (10.0.0.10) 56(84) bytes of data.
    64 bytes from 10.0.0.10: icmp_seq=1 ttl=64 time=0.557 ms
    64 bytes from 10.0.0.10: icmp_seq=2 ttl=64 time=0.534 ms
    ^C
    — 10.0.0.10 ping statistics —
    2 packets transmitted, 2 received, 0% packet loss, time 1000ms
    rtt min/avg/max/mdev = 0.534/0.545/0.557/0.026 ms
    [linux@Centos ~]$

8、用virsh edit CentOS命令修改我们的虚拟机的配置,添加一个桥接类型的网卡,并且桥接到br0口,添加文本如下,更多XML文件格式说明参考https://libvirt.org/formatdomain.html

        <interface type=’bridge’>
          <source bridge=’br0’/>
          <target dev=’vnet1’/>
          <mac address=”00:11:22:33:44:55″/>
        </interface>

9、用virsh start CentOS命令打开我们的虚拟机,登录虚拟机系统后可以看到虚拟机中多了一个MAC地址为00:11:22:33:44:55的网卡,在我的虚拟机里它叫eth2。

备注:此时打开虚拟机可能会报桥接口通信失败,进而导致虚拟机打开失败,则需要输入如下命令允许虚拟机使用桥接通信。

echo “allow br0” >> /etc/qemu-kvm/bridge.conf

下面是虚拟机开机后的网口信息:

    [root@localhost ~]# ifconfig -a
    eth1      Link encap:Ethernet  HWaddr 52:54:00:97:86:46  
              BROADCAST MULTICAST  MTU:1500  Metric:1
              RX packets:0 errors:0 dropped:0 overruns:0 frame:0
              TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
              collisions:0 txqueuelen:1000
              RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)
     
    eth2      Link encap:Ethernet  HWaddr 00:11:22:33:44:55  
              BROADCAST MULTICAST  MTU:1500  Metric:1
              RX packets:0 errors:0 dropped:0 overruns:0 frame:0
              TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
              collisions:0 txqueuelen:1000
              RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)
              Interrupt:10 Base address:0xa000
     
    lo        Link encap:Local Loopback  
              inet addr:127.0.0.1  Mask:255.0.0.0
              inet6 addr: ::1/128 Scope:Host
              UP LOOPBACK RUNNING  MTU:65536  Metric:1
              RX packets:0 errors:0 dropped:0 overruns:0 frame:0
              TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
              collisions:0 txqueuelen:0
              RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b)
     
    [root@localhost ~]#

10、为eth2配置一个ip地址,并ping宿主机和宿主机的ens5连接的对端设备,测试通信是否正常。可以看到我这里无论是ping10.0.0.10和是10.0.0.3都是可以正常ping通的,说明虚拟机与宿主机和宿主机的对端设备通信都是正常的。至此就完成了为虚拟机桥接到宿主机物理网卡的所有工作。

    [root@localhost ~]# ifconfig eth2 10.0.0.5
    eth2: link up, 100Mbps, full-duplex, lpa 0x05E1
    [root@localhost ~]#
    [root@localhost ~]# ping 10.0.0.10
    PING 10.0.0.10 (10.0.0.10) 56(84) bytes of data.
    64 bytes from 10.0.0.10: icmp_seq=1 ttl=64 time=2.09 ms
    64 bytes from 10.0.0.10: icmp_seq=2 ttl=64 time=1.02 ms
     
    — 10.0.0.10 ping statistics —
    2 packets transmitted, 2 received, 0% packet loss, time 1851ms
    rtt min/avg/max/mdev = 1.023/1.557/2.092/0.535 ms
    [root@localhost ~]#
    [root@localhost ~]# ping 10.0.0.3
    PING 10.0.0.3 (10.0.0.3) 56(84) bytes of data.
    64 bytes from 10.0.0.3: icmp_seq=1 ttl=64 time=0.625 ms
    64 bytes from 10.0.0.3: icmp_seq=2 ttl=64 time=0.815 ms
    64 bytes from 10.0.0.3: icmp_seq=3 ttl=64 time=0.817 ms
     
    — 10.0.0.3 ping statistics —
    3 packets transmitted, 3 received, 0% packet loss, time 2360ms
    rtt min/avg/max/mdev = 0.625/0.752/0.817/0.092 ms
 

 
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171594.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 8大轻型网管工具,网络管理好帮手「建议收藏」

    8大轻型网管工具,网络管理好帮手「建议收藏」  从设备发现到系统、网络和流量可视性,这些轻型的网管工具非常实用。在网络和服务器世界,重点是可视性、可视性、可视性,如果你不知道你的网络和服务器在每天每秒正在做什么,你很可能会出问题。幸运的是,这里有很多好工具(商业和开源工具)来帮助你满足需求。  在本文中我们提供了一些很好用的网管工具,这些工具适合各种规模的网络。从网络和服务器监控到趋势、图形,甚至是交换和路由器配置备份,这些工具都可以帮…

    2022年10月6日
    2
  • 使用Python检测符号及乱码字符

    使用Python检测符号及乱码字符最近在进行关键词的分析,中间涉及到对一些特殊的字符进行过滤的需求。包括带符号的(有部分还是SQL注入),并且存在一部分乱码的问题。梳理下来供后续使用。检测字符串是否包含特殊符号方案一:通过字符匹配的方式进行判定defif_contain_symbol(keyword):symbols=”~!@#$%^&*()_+-*/<>,.[]\/”forsymbolinsymbols:ifsymbolinkeyword:

    2022年5月4日
    45
  • 菜鸟的数学建模之路(四):BP神经网络

    个人理解BP神经网络属于人工智能范畴,在我看来它更多的是一个用于预测的工具,尽管它的用处还不仅于此。在数学建模上,很多时候,题目提供了很多历史数据,我经常用这些历史数据,用BP神经网络训练它,利用训练好的BP神经网络,来预测接下来的未知的值。BP神经网络关于该神经网络的繁多的理论这里就不去深究了,百度一查一大把,一堆的理论反正我是看不下去的,所以这里只是讲如何把BP神经网络当成一个工具来用,…

    2022年4月9日
    60
  • 初识kafka

    初识kafka

    2021年11月27日
    59
  • DHCP协议介绍

    DHCP协议介绍DHCP(DynamicHostConfigurationProtocol:动态主机设置协议)DHCP是一个局域网协议DHCP是应用UDP协议的应用层协议DHCP的作用主要是为临时加入局域网的设备提供一个临时的IP地址DHCP协议提供了即插即用联网的功能,使得我们的设备在不同的地方时(例如:家、公司、户外等),不需要自行地配置IP地址就可以进行网络的连接,只要用了DHCP协议,就可以在不同的地方使用不同的网络如下图中,如果配置自动获得IP地址,就相当于启用DHCP协议,会允许我们自动地从

    2022年5月24日
    51
  • python 图片重命名_python批量重命名文件

    python 图片重命名_python批量重命名文件一个简单的python脚本,用于图片批量重命名,非常简单但是也非常使用!

    2025年9月7日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号