Source From Here
Preface
tun/tap 驅動程序實現了虛擬網卡的功能,tun 表示虛擬的是點對點設備,tap 表示虛擬的是以太網設備,這兩種設備針對網絡包實施不同的封裝。 利用 tun/tap 驅動,可以將 tcp/ip 協議棧處理好的網絡分包傳給任何一個使用 tun/tap 驅動的進程,由進程重新處理後再發到物理鏈路中。 開源項目 openvpn ( http://openvpn.sourceforge.net)和 Vtun( http://vtun.sourceforge.net ) 都是利用 tun/tap 驅動實現的隧道封裝。
Tun/Tap 驅動程序工作原理
做為虛擬網卡驅動,Tun/Tap 驅動程序的數據接收和發送並不直接和真實網卡打交道, 他在 Linux 內核中添加了一個TUN/TAP虛擬網絡設備的驅動程序和一個與之相關連的字符設備 /dev/net/tun,字符設備 tun 作為用戶空間和內核空間交換數據的接口。當內核將數據包發送到虛擬網絡設備時,數據包被保存在設備相關的一個隊列中,直到用戶空間程序通過打開的字符設備 tun 的描述符讀取時,它才會被拷貝到用戶空間的緩衝區中,其效果就相當於,數據包直接發送到了用戶空間。通過系統調用 write 發送數據包時其原理與此類似。
在 Linux下,要實現 內核空間 和 用戶空間 數據的交互,有多種方式:可以通用 socket 創建特殊套接字,利用套接字實現數據交互;通過 proc 文件系統創建文件來進行數據交互;還可以使用設備文件的方式,訪問設備文件會調用設備驅動相應的例程,設備驅動本身就是 內核空間 和 用戶空間 的一個接口,Tun/tap驅動就是利用設備文件實現 用戶空間 和 內核空間 的數據交互。
從結構上來說,Tun/tap 驅動並不單純是實現網卡驅動,同時它還實現了字符設備驅動部分。以字符設備的方式連接用戶空間和內核空間。下面是示意圖:
Tun/tap 驅動程序中包含兩個部分,一部分是字符設備驅動,還有一部分是網卡驅動部分。利用網卡驅動部分接收來自 TCP/IP 協議棧的網絡分包並發送或者反過來將接收到的網絡分包傳給協議棧處理,而字符驅動部分則將網絡分包在 用戶空間和內核空間 之間傳送,模擬物理鏈路的數據接收和發送。Tun/tap 驅動很好的實現了兩種驅動的結合。
Tun/Tap網卡創建
確認內核是否支持 tun/tap
確認內核是否有 tun 模塊:
加載內核模塊:
執行以上命令後,出現如上輸出,說明模塊加載成功.
創建和配置虛擬網卡
確認是否有 tunctl 命令,如果沒有通過 yum 安裝即可:
經過如上操作後,虛擬網卡已經建立和配置好了。
作為系統服務隨系統自動啟動創建虛擬網卡
編寫配置腳本(符合 chkconfig 規範):
可以根據具體需求修改此腳本. 加入到系統服務中:
操作完成後,就可以像其他標準服務一樣,通過 service config_tap start 來進行創建和啟動操作.
This is a blog to track what I had learned and share knowledge with all who can take advantage of them
標籤
- [ 英文學習 ]
- [ 計算機概論 ]
- [ 深入雲計算 ]
- [ 雜七雜八 ]
- [ Algorithm in Java ]
- [ Data Structures with Java ]
- [ IR Class ]
- [ Java 文章收集 ]
- [ Java 代碼範本 ]
- [ Java 套件 ]
- [ JVM 應用 ]
- [ LFD Note ]
- [ MangoDB ]
- [ Math CC ]
- [ MongoDB ]
- [ MySQL 小學堂 ]
- [ Python 考題 ]
- [ Python 常見問題 ]
- [ Python 範例代碼 ]
- [心得扎記]
- [網路教學]
- [C 常見考題]
- [C 範例代碼]
- [C/C++ 範例代碼]
- [Intro Alg]
- [Java 代碼範本]
- [Java 套件]
- [Linux 小技巧]
- [Linux 小學堂]
- [Linux 命令]
- [ML In Action]
- [ML]
- [MLP]
- [Postgres]
- [Python 學習筆記]
- [Quick Python]
- [Software Engineering]
- [The python tutorial]
- 工具收集
- 設計模式
- 資料結構
- ActiveMQ In Action
- AI
- Algorithm
- Android
- Ansible
- AWS
- Big Data 研究
- C/C++
- C++
- CCDH
- CI/CD
- Coursera
- Database
- DB
- Design Pattern
- Device Driver Programming
- Docker
- Docker 工具
- Docker Practice
- Eclipse
- English Writing
- ExtJS 3.x
- FP
- Fraud Prevention
- FreeBSD
- GCC
- Git
- Git Pro
- GNU
- Golang
- Gradle
- Groovy
- Hadoop
- Hadoop. Hadoop Ecosystem
- Java
- Java Framework
- Java UI
- JavaIDE
- JavaScript
- Jenkins
- JFreeChart
- Kaggle
- Kali/Metasploit
- Keras
- KVM
- Learn Spark
- LeetCode
- Linux
- Lucene
- Math
- ML
- ML Udemy
- Mockito
- MPI
- Nachos
- Network
- NLP
- node js
- OO
- OpenCL
- OpenMP
- OSC
- OSGi
- Pandas
- Perl
- PostgreSQL
- Py DS
- Python
- Python 自製工具
- Python Std Library
- Python tools
- QEMU
- R
- Real Python
- RIA
- RTC
- Ruby
- Ruby Packages
- Scala
- ScalaIA
- SQLAlchemy
- TensorFlow
- Tools
- UML
- Unix
- Verilog
- Vmware
- Windows 技巧
- wxPython
訂閱:
張貼留言 (Atom)
[Git 常見問題] error: The following untracked working tree files would be overwritten by merge
Source From Here 方案1: // x -----删除忽略文件已经对 git 来说不识别的文件 // d -----删除未被添加到 git 的路径中的文件 // f -----强制运行 # git clean -d -fx 方案2: 今天在服务器上 gi...
-
前言 : 為什麼程序管理這麼重要呢?這是因為: * 首先,本章一開始就談到的,我們在操作系統時的各項工作其實都是經過某個 PID 來達成的 (包括你的 bash 環境), 因此,能不能進行某項工作,就與該程序的權限有關了。 * 再來,如果您的 Linux 系統是個...
-
屬性 : 系統相關 - 檔案與目錄 語法 : du [參數] [檔案] 參數 | 功能 -a | 顯示目錄中個別檔案的大小 -b | 以bytes為單位顯示 -c | 顯示個別檔案大小與總和 -D | 顯示符號鏈結的來源檔大小 -h | Hum...
-
來源自 這裡 說明 : split 是 Perl 中非常有用的函式之一,它可以將一個字串分割並將之置於陣列中。若無特別的指定,該函式亦使用 RE 與 $_ 變數 語法 : * split /PATTERN/,EXPR,LIMIT * split /...
沒有留言:
張貼留言