Linux上用IP轉發使內部網路連接互聯網

来源:https://www.cnblogs.com/qxfy/archive/2019/12/11/12022545.html
-Advertisement-
Play Games

IP轉發的概念: 使 Linux 機器像路由器一樣將數據從一個網路發送到另一個網路。所以,它能作為一個路由器或者代理伺服器,實現將一個連接的互聯網或者網路連接共用給多個客戶端機器。 1. 啟用 IPv4 轉發 首先,我們需要在我們的 Linux 操作系統上啟用 IPv4 轉發。要做到這點,我們需要使 ...


IP轉發的概念:

使 Linux 機器像路由器一樣將數據從一個網路發送到另一個網路。所以,它能作為一個路由器或者代理伺服器,實現將一個連接的互聯網或者網路連接共用給多個客戶端機器。

1. 啟用 IPv4 轉發

首先,我們需要在我們的 Linux 操作系統上啟用 IPv4 轉發。要做到這點,我們需要使用root用戶在 shell 或終端下執行下麵的命令。

#echo 1 > /proc/sys/net/ipv4/ip_forward

臨時IP轉發

註意:上面的命令能馬上啟用ip轉發,但只是臨時的,直到下一次重啟。要永久啟用,我們需要使用我們慣用的文本編輯器打開 /etc/sysctl.conf 文件。

#vim /etc/sysctl.conf

然後,增加net.ipv4.ip_forward = 1 到文件中,或者刪除那行的註釋,保存並退出文件。

net.ipv4.ip_forward= 1

運行下麵的命令啟用更改。

#sysctl -p /etc/sysctl.conf

 

2. 配置 Iptables 防火牆

我們需要允許特定的(或者所有的)數據包通過我們的路由器。在這之前,我們要知道連接我們 Linux 的網路設備的介面名稱。我們可以通過在終端或者 shell 運行以下命令獲得介面名稱。

#ifconfig -a

這裡,在我們的機器中, eth0 是連接到互聯網或者網路的網卡介面, wlan2 是我們要使用 iptables 從 eth0 轉發數據包的介面。要實現轉發,我們需要運行以下命令。

#iptables -A FORWARD -i wlan2 -o eth0 -j ACCEPT

註意:請用你 Linux 機器中的可用設備名稱替換 wlan2 和 eth0。

現在,由於netfilter/iptables是一個無狀態的防火牆,我們需要讓 iptables 允許已建立的連接通過。要做到這點,我們要運行下麵的命令。

 

3. 配置 NAT

然後,最後我們需要通過執行下麵的命令修改發送到互聯網的數據包的源地址為 eth0。

#iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE


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

-Advertisement-
Play Games
更多相關文章
  • 建議20、使用泛型集合來替代非泛型集合 http://www.cnblogs.com/aehyok/p/3384637.html 這裡有一篇文章,是我之前專門來介紹泛型的。我們應儘量的使用泛型集合。因為泛型的確有它的好處: 1、提供了類型安全,在編譯期間就可以檢查錯誤 2、更重要的是大部分情況下泛型 ...
  • 前言 軟體開發過程中,不可避免會用到集合,C#中的集合表現為數組和若幹集合類。不管是數組還是集合類,它們都有各自的優缺點。如何使用好集合是我們在開發過程中必須掌握的技巧。不要小看這些技巧,一旦在開發中使用了錯誤的集合或針對集合的方法,應用程式將會背離你的預想而運行。 本文已更新至http://www ...
  • 1. UWP中的其它裁剪方案 之前在 "這篇文章" 里,我介紹瞭如何使用 "UIElement.Clip" 裁剪UIElement的內容,使用代碼如下: 在 "另一篇文章里" 我介紹瞭如何使用 "CanvasActiveLayer" 裁剪Win2D內容,使用代碼如下: 這兩種方式都有他們的局限:Ca ...
  • Linux使用Nginx Yum存儲庫上安裝Nginx,適用於Red Hat Enterprise Linux和CentOS系統。 1、添加設置Nginx Yum存儲庫 在CentOS中首次安裝Nginx時,需要添加Nginx軟體包,使用以下命名,添加安裝 sudo yum install yum- ...
  • 一,認識/etc/passwd和/etc/shadow 1. /etc/passwd :文件中保存系統中所有的用戶和用戶的主要信息. 在命令行輸入 cat /etc/passwd | head (‘ | ’ 為管道符,作用是把前面的的命令輸出在輸入給後面的命令 ) 由圖所示 /etc/passwd/ ...
  • RabbitMQ安裝 一、安裝環境介紹 本文的使用的Linux是centOS6.5 64位的mini版。只安裝了JDK8.其他的環境都沒有安裝。賬號是 root 二、erlang安裝 RabbitMQ是使用Erlang開發,所以安裝RabbitMQ前需要先安裝Erlang。 1.下載源文件 官網 下 ...
  • centos6安裝redis-2.8.19.tar.gz1、檢查安裝依賴程式yum install gcc-c++yum install -y tclyum install wget 2、獲取安裝文件wget http://download.redis.io/releases/redis-2.8.1 ...
  • MRAM是一種利用電子自旋的磁性提供非易失性而不會磨損的存儲器。MRAM將信息存儲在與硅電路集成的磁性材料中,從而在單個無限耐用的設備中提供SRAM的速度和Flash的非易失性。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...