kvm網路,docker網路,,vm網路

来源:https://www.cnblogs.com/qw77/p/18148602
-Advertisement-
Play Games

一:vmware網路 1:概念的介紹 虛擬網路編輯器:控制的就是虛擬機的網段的 window中的適配器:更這個虛擬網路編輯器連在一起的,是同一個網段,通常是分配的.1的IP地址 2:橋接模式 原理:就是將虛擬機的物理網卡橋接到物理主機上面,實現了訪問外網的操作 圖解: 操作:就是將虛擬機的ip地址, ...


一:vmware網路

1:概念的介紹

 虛擬網路編輯器:控制的就是虛擬機的網段的

window中的適配器:更這個虛擬網路編輯器連在一起的,是同一個網段,通常是分配的.1的IP地址

2:橋接模式

原理:就是將虛擬機的物理網卡橋接到物理主機上面,實現了訪問外網的操作

圖解:

 操作:就是將虛擬機的ip地址,dns以及網關設置與物理機一樣的範圍

 

3:nat模式

原理:有一個虛擬nat設備和一個虛擬的dhcp伺服器,宿主機的物理網卡與虛擬機的虛擬nat設備進行連接,用於虛擬機與宿主機的訪問和訪問外網,vm A8這個與vmnet8進行相連接,用於宿主機與虛擬機進行通信,所以的話虛擬機並不是依靠的vm A8來進行訪問外網的

 4:僅主機模式

原理:宿主機網卡與vmA8與vmnet1進行相連,直接與宿主機進行通信,就是去除了虛擬nat設備,將虛擬機與外網進行隔開,使得虛擬機成為了一個獨立的系統

但是呢,虛擬機還是可以進訪問外網的操作

 

配置僅主機模式訪問外網的操作:
將主機網卡共用給vma1網卡,從而達到虛擬機聯網的目的

 然後將僅主機的的網關和dns配置為vmA8一樣的ip即可,從而實現了僅主機能夠訪問外網的操作

 

二:docker網路

 docker網路就比較的簡單了,因為只有一個橋接模式是常用的話,

1:橋接模式

在創建容器的時候,會自動的創建一對虛擬機介面,vethp介面,一個是容器的網卡,另外一個連接在網橋上面,用於容器內部與宿主機進行通信的,

交流:容器與網橋進行相連,沒有與宿主機的物理網卡相連,只是通過nat地址轉換轉發到了宿主機的物理網卡上面,出去進行通信而已,因此外面是無法進行訪問裡面的

圖解:

 原理:通過nat映射到物理網卡上面,轉發出去

創建一個自定義的橋接網卡

#創建107網段的網橋
[root@docker ~]# docker network  create  --driver bridge  --subnet 192.168.107.0/24 --gateway 192.168.107.254  n1
c1e94324a60995ade0b565988f11460ac033bf3c0f47f554b825877f73719343
[root@docker ~]# docker network ls
NETWORK ID     NAME      DRIVER    SCOPE
95ea57899057   bridge    bridge    local
c5b31c95c38d   host      host      local
c1e94324a609   n1        bridge    local
5f83cbf951eb   none      null      local
[root@docker ~]# docker network inspect n1
[
    {
        "Name": "n1",
        "Id": "c1e94324a60995ade0b565988f11460ac033bf3c0f47f554b825877f73719343",
        "Created": "2024-04-26T15:24:03.017479332+08:00",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "192.168.107.0/24",
                    "Gateway": "192.168.107.254"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {},
        "Options": {},
        "Labels": {}
    }
]
#創建一個容器,進行綁定的操作
[root@docker ~]# docker run -tid --name q1 --network n1 centos /bin/bash
f1c8c9dcc52caa71889851e9b358abcb98f72aaa17761c453ccf008131525c8a
[root@docker ~]# docker network inspect  n1 | grep  -A4 -i containers
        "Containers": {
            "f1c8c9dcc52caa71889851e9b358abcb98f72aaa17761c453ccf008131525c8a": {
                "Name": "q1",
                "EndpointID": "8684a410a0d0639790841d0009bf8415f12344212c550c262dce2369507a6f8f",
                "MacAddress": "02:42:c0:a8:6b:01",

#進入容器,進行訪問外網的操作
[root@docker ~]# docker exec -ti q1 /bin/bash
[root@f1c8c9dcc52c /]# ip a   
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
7: eth0@if8: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default 
    link/ether 02:42:c0:a8:6b:01 brd ff:ff:ff:ff:ff:ff link-netnsid 0
    inet 192.168.107.1/24 brd 192.168.107.255 scope global eth0
       valid_lft forever preferred_lft forever
[root@f1c8c9dcc52c /]# ping www.baidu.com
PING www.a.shifen.com (180.101.50.188) 56(84) bytes of data.
64 bytes from 180.101.50.188 (180.101.50.188): icmp_seq=1 ttl=127 time=32.9 ms
64 bytes from 180.101.50.188 (180.101.50.188): icmp_seq=2 ttl=127 time=47.2 ms

#當然外網無法進行訪問容器,因為裡面是通過nat進行轉發到宿主機物理網卡上面去的,所以外網無法進行訪問

 

三:kvm網路

kvm網路就比較有趣了,nat模式和橋接模式

1:nat模式

原理:nat模式就是在宿主機上面創建一個網橋,設置為nat模式,然後會自動的創建2個虛擬介面(也就是網卡),一個是網橋的配置文件,另外一個是nic網卡的配置文件(未啟用的狀態),2個mac地址是相同的,也就是本質是相同的,,一個用於連接虛擬機和網橋的,實現通信,nic的作用就是nat地址轉換,轉發到宿主機的物理網卡上面去,進行訪問外網,但是外網就訪問不了虛擬機了,所以的話,有一定的局限性

步驟:使用已有的網橋配置文件來進行操作

#複製nat網橋的配置文件,並更改
[root@server networks]# cp default.xml  nat1.xml
[root@server networks]# vim nat1.xml 
[root@server networks]# cat nat1.xml 
<network>
  <name>nat1</name>
  <bridge name="nat1"/>
  <forward/>
  <ip address="192.168.107.1" netmask="255.255.255.0">
    <dhcp>
      <range start="192.168.107.2" end="192.168.107.254"/>
    </dhcp>
  </ip>
</network>

#使用命令來進行定義配置文件
#創建了nat網橋後,會生成一個網橋的配置文件,還有一個就是nic這個配置文件
[root@server networks]# virsh  net-define  nat1.xml 
從 nat1定義網路nat1.xml

[root@server networks]# virsh net-list --all
 名稱               狀態     自動開始  持久
----------------------------------------------------------
 default              活動     是           是
 nat1                 不活躍  否           是

[root@server networks]# virsh  net-start nat1 
網路 nat1 已開始

[root@server networks]# virsh net-autostart nat1 
網路nat1標記為自動啟動

[root@server networks]# virsh  net-list
 名稱               狀態     自動開始  持久
----------------------------------------------------------
 default              活動     是           是
 nat1                 活動     是           是

[root@server networks]# brctl show
bridge name	bridge id		STP enabled	interfaces
nat1		8000.525400b5fa52	yes		nat1-nic
virbr0		8000.5254002e1c32	yes		virbr0-nic

#啟動虛擬機,訪問外網
[root@server networks]# brctl show
bridge name	bridge id		STP enabled	interfaces
nat1		8000.525400b5fa52	yes		nat1-nic
							vnet0
virbr0		8000.5254002e1c32	yes		virbr0-nic

當然外網無法進行訪問,虛擬機,因為是nat模式

2:橋接模式

原理:創建一個網橋出來,也會自動的創建一個網橋的配置文件,創建虛擬機的時候,會自動的虛擬出2個介面,一個在宿主機上面,一個在虛擬機上面,綁定了物理網卡,外網和虛擬機可以互相通信

使用nmcli命令來進行創建:

#創建一個網橋,創建一個物理網卡,並且綁定到網橋上面
[root@server libvirt]# nmcli connection add type bridge autoconnect yes  ifname br0 con-name br0 autoconnect yes 
連接 "br0" (c46f8b8a-e19d-4b5b-9fde-2e8d7f6b801b) 已成功添加。
[root@server libvirt]# nmcli connection add type bridge-slave autoconnect yes ifname ens32 con-name ens107 master br0 
連接 "ens107" (21acab68-7e80-4675-ba2f-0e9c73f9dceb) 已成功添加。
[root@server libvirt]# brctl show
bridge name	bridge id		STP enabled	interfaces
br0		8000.000c292a28fd	yes		ens32
virbr0		8000.5254002e1c32	yes		virbr0-nic

#配置網橋的ip地址,與宿主機的ip地址一樣才行,這就相當於是宿主機的ip地址
[root@server network-scripts]# nmcli connection modify br0 ipv4.method manual  ipv4.addresses 172.25.250.10/24 ipv4.gateway 172.25.250.254 ipv4.dns 119.29.29.29 
[root@server network-scripts]# systemctl restart network

[root@server network-scripts]# ping www.baidu.com
PING www.a.shifen.com (183.2.172.42) 56(84) bytes of data.
64 bytes from 183.2.172.42 (183.2.172.42): icmp_seq=1 ttl=128 time=32.3 ms
^C

#啟動虛擬機,訪問外網
[root@server network-scripts]# brctl show
bridge name	bridge id		STP enabled	interfaces
br0		8000.000c292a28fd	yes		ens32
							vnet0
virbr0		8000.5254002e1c32	yes		virbr0-nic

#能訪問外網,只不是有點慢而已
#外面也能訪問裡面,也能進行通信即可

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...