ML
    • Recent
    • Categories
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    How do you setup KVM networking on a desktop or laptop

    IT Discussion
    kvm networking
    9
    23
    3.9k
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • RomoR
      Romo
      last edited by

      MacVTap driver considerations
      https://www.ibm.com/support/knowledgecenter/linuxonibm/liaag/wkvm/wkvm_c_net_conmac.htm


      From purely a performance perspective, based on the workloads tested and the Linux and KVM levels measured, the MacVTap driver consistently demonstrated higher throughputs and better CPU efficiency.

      The MacVTap driver provides exceptional transactional throughput and operations/sec results (up to 10-50%) better than either of the two software bridges. Additionally, throughput of MacVTap scales up with load more quickly compared to using a software bridge. This means that MacVTap is more CPU efficient, consuming less CPU resources to complete the same amount of work. Stated another way, MacVTap can do more work using the same amount of CPU resources.

      Although MacVTap is the best performing, it suffers from a couple of issues that may limit the use cases where it would be a suitable choice.

      The first limitation is that MacVTap can not readily enable network communication between the KVM host and any of the KVM guests using MacVTap.

      • This issue can be overcome in two different ways. The first way to avoid this limitation is to use a special hardware switch that supports hairpin mode to connect the IBM z Systems to the outside world. However, hairpin mode is not a common feature in most hardware switches and those switches that do have this feature tend to be significantly more expensive.

      • The second way to enable KVM host to guest communications is by having multiple network interfaces in the KVM host. Configure the second KVM host interface on the same segment with a different subnet from the first host interface. MacVTap only restricts traffic flow to the same subnet shared between host and guest. While this method works w/o purchasing additional costly hardware, it still requires that a second interface be available and appropriately configured in the KVM host and each KVM guest.

      A second limitation of MacVTap is that it must attach to a physical host interface. MacVTap, unlike software bridges, provides no way to enable KVM guests to communicate without first being attached to a host interface which is active and externally facing. In other words, KVM guests using MacVTap will be external facing and exposed to external network traffic. This is not necessarily a bad thing. It just doesn't provide KVM host only isolation and connectivity for KVM guests that other choices allow.

      1 Reply Last reply Reply Quote 1
      • RomoR
        Romo
        last edited by Romo

        Macvtap modes:

        1. Virtual Ethernet Port Aggregator mode
          In this mode, which is the default, data between endpoints on the same lower device are sent via the lower device (Ethernet card) to the physical switch the lower device is connected to. This mode requires that the switch supports ‘Reflective Relay’ mode, also known as ‘Hairpin’ mode. Reflective Relay means the switch can send back a frame on the same port it received it on

        2. Bridge mode
          When the MacVTap device is in Bridge mode, the endpoints can communicate directly without sending the data out via the lower device. When using this mode, there is no need for the physical switch to support Reflective Relay mode.

        3. Private mode
          In Private mode the nodes on the same MacVTap device can never talk to each other, regardless if the physical switch supports Reflective Relay mode or not. Use this mode when you want to isolate the virtual machines connected to the endpoints from each other, but not from the outside network.

        1 Reply Last reply Reply Quote 1
        • matteo nunziatiM
          matteo nunziati @JaredBusch
          last edited by matteo nunziati

          @JaredBusch I run some production machines with macvtap/VEPA: they cannot talk with host or to each other but I'm too lazy and my env is small so it is ok.

          I use this as:

          • I do not need the VM to talk with the host via LAN
          • everytime a VM has to talk to another VM I use internal virtual network to avoid virt2virt network traffic outside the host.
            this also allows me to contact the host via the internal LAN (which should be there on 192.168.100.0/24)
            0_1493309781161_Immagine.png
            [sorry details in Italian]

          side note: what actually happens is than in a macvtap interface traffic can't re-enter the NIC: if you had 2 NICs, VMs on NIC1 can talk to other VMs or host via NIC2.

          this should be ok for creating a bridge

          matteo nunziatiM 1 Reply Last reply Reply Quote 1
          • matteo nunziatiM
            matteo nunziati @matteo nunziati
            last edited by matteo nunziati

            @matteo-nunziati more accurate: VM can re-enter the host, the host can't re-enter in VMs. just double-checked.

            1 Reply Last reply Reply Quote 0
            • stacksofplatesS
              stacksofplates
              last edited by stacksofplates

              I kind of have a mix. Most are macvtap over a bond and I just set up a private network between the host and VMs. I set reservations with libvirt for the VMs.

              I have a couple with full bridge, but since I'm managing the systems from outside of the host, it really doesn't affect my workflow. The only thing that really changes is I use the private network for grabbing updates from my repo server. But if you are downloading updates and installing from the internet, this will make no difference to you.

              1 Reply Last reply Reply Quote 1
              • stacksofplatesS
                stacksofplates @Romo
                last edited by

                @Romo said in How do you setup KVM networking on a desktop or laptop:

                @JaredBusch said in How do you setup KVM networking on a desktop or laptop:

                @Romo That is what I was thinking also.

                By default this is the list of options.

                0_1493304460124_upload-a8eb022b-9d3d-41d1-ab17-62b529bcac96

                So I assume, I need to make a bridge first as I did not see any other settings.

                Yes, you have create your bridge first so that it appears in virt-manager.

                Virt-manager can create a bridge for you, but you have to disable NetworkManager and use network instead. IIRC Birthday-manager has some issues with NetworkManager.

                JaredBuschJ 1 Reply Last reply Reply Quote 1
                • JaredBuschJ
                  JaredBusch @stacksofplates
                  last edited by

                  @stacksofplates said in How do you setup KVM networking on a desktop or laptop:

                  Birthday-manager

                  Hahahahahah

                  stacksofplatesS 1 Reply Last reply Reply Quote 2
                  • stacksofplatesS
                    stacksofplates @JaredBusch
                    last edited by

                    @JaredBusch said in How do you setup KVM networking on a desktop or laptop:

                    @stacksofplates said in How do you setup KVM networking on a desktop or laptop:

                    Birthday-manager

                    Hahahahahah

                    Idk how I missed that one hahaha.

                    1 Reply Last reply Reply Quote 0
                    • FATeknollogeeF
                      FATeknollogee
                      last edited by

                      Any further updates here?

                      What is the "cleanest" method available so vm's can "talk" to the host?

                      F JaredBuschJ 2 Replies Last reply Reply Quote 0
                      • F
                        Francesco Provino @FATeknollogee
                        last edited by

                        @FATeknollogee said in How do you setup KVM networking on a desktop or laptop:

                        Any further updates here?

                        What is the "cleanest" method available so vm's can "talk" to the host?

                        Bridge. But sometimes is messy with the wifi in my experience, so maybe is better to use ZeroTier for a testing environment.

                        1 Reply Last reply Reply Quote 0
                        • FATeknollogeeF
                          FATeknollogee @Emad R
                          last edited by

                          @msff-amman-Itofficer said in How do you setup KVM networking on a desktop or laptop:

                          @Romo said in How do you setup KVM networking on a desktop or laptop:

                          I usually use the Linux Bridge since it provides the features I require and they are relatively simple to set up.

                          macvtap should provide better performance cause it is the evolution of Linux bridge, and I use Fedora Virt-Manager to setup this and connect to KVM

                          @Francesco-Provino Why would macvtap have better performance vs bridge?

                          1 Reply Last reply Reply Quote 0
                          • JaredBuschJ
                            JaredBusch @FATeknollogee
                            last edited by JaredBusch

                            @FATeknollogee said in How do you setup KVM networking on a desktop or laptop:

                            Any further updates here?

                            What is the "cleanest" method available so vm's can "talk" to the host?

                            I ended up just staying on macvtap. I never did any further troubleshooting.

                            0_1496240731940_upload-24668984-2bad-47a6-ad88-1a74591f736a

                            I only use this Windows 10 VM for occasional power email sessions in Outlook when organizing 5 accounts worth of email. Usually once a week.

                            stacksofplatesS 1 Reply Last reply Reply Quote 0
                            • stacksofplatesS
                              stacksofplates @JaredBusch
                              last edited by stacksofplates

                              @JaredBusch said in How do you setup KVM networking on a desktop or laptop:

                              @FATeknollogee said in How do you setup KVM networking on a desktop or laptop:

                              Any further updates here?

                              What is the "cleanest" method available so vm's can "talk" to the host?

                              I ended up just staying on macvtap. I never did any further troubleshooting.

                              0_1496240731940_upload-24668984-2bad-47a6-ad88-1a74591f736a

                              I only use this Windows 10 VM for occasional power email sessions in Outlook when organizing 5 accounts worth of email. Usually once a week.

                              You'll get better performance if you install the VirtIO drivers and use that instead of rtl8139. Whether you will notice it or not for that VM, idk.

                              1 Reply Last reply Reply Quote 0
                              • 1
                              • 2
                              • 1 / 2
                              • First post
                                Last post