国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務器 > Web服務器 > 正文

詳解基于docker搭建lanproxy內網穿透服務

2024-09-01 13:54:29
字體:
來源:轉載
供稿:網友

文檔更新說明

2018年04月06日 v1.0

內網穿透相信是后端開發者經常遇到的需求,可是怎么實現呢?其實有現成的服務:花生殼、ngrok等,但是,最近花生殼宣布,免費版的內網穿透將不支持80端口映射了,而免費版的ngrok也不夠穩定,于是乎,我就開始需找新的解決方案了

本文使用了docker、nginx,要全部搞懂的話需要一定的后端基礎(當然,基本上入個門就可以了),個人認為還是有一定閱讀門檻的,但是你如果只是想把服務搭建起來,按照步驟來做是不難的

1、概述

內網穿透其實就是用服務器做一個中轉,將請求轉發,本文記錄了在 ubuntu 16.04 上,基于 docker 搭建的內網穿透服務

1.1、原理

內網穿透的原理如下圖所示:

  1. 用戶訪問我們的服務器,這個服務器是有公網IP的,所以用戶可以無壓力訪問
  2. 服務器與本地電腦保持長鏈接,當有請求的時候,服務器將請求轉發到我們的本地電腦
  3. 本地電腦將響應回復給服務器
  4. 服務器將響應回復給用戶

docker,lanproxy,內網穿透服務

1.2、實現

要搭建內網穿透,我們得完成兩個任務

在公網能訪問的服務器上運行我們的內網穿透服務; 在本地電腦上面運行內網穿透客戶端。

當然,你可以自己根據原理實現一套,不過我們有現成的三方開源工具,可以幫我們實現這一套功能。這個就是我們今天的主角 lanproxy 。

2、實現步驟

現成的工具已經找到,接下來就是簡單的搭建一下了,搭建過程分為服務端和本地電腦端

2.1、服務端流程:

  1.  在服務器上安裝 dockernginx
  2. 在服務器上通過 docker 運行 lanproxy server
  3. 將域名解析到我們的服務器
  4. 配置 nginx 反向代理
  5. 打開 lanproxy 后臺頁面,添加客戶端和映射信息

2.2、本地電腦流程:

  1. 運行要被映射的服務
  2. 運行本地電腦映射客戶端程序( lanproxy client )

下面開始服務端的配置:

2.1.1、在服務器上安裝 dockernginx

nginx 的安裝是很簡單的,一個命令就搞定

docker 也可以使用腳本安裝,也是一句命令的事

# 1、安裝nginx$ sudo apt-get install nginx# 2、安裝docker$ curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun# 可選步驟,建docker源修改為阿里云$ sudo mkdir -p /etc/docker$ sudo tee /etc/docker/daemon.json <<-'EOF'{ # 下面的鏈接需要到阿里云后臺查看,每個人的加速地址是不一樣的 "registry-mirrors": ["https://abcdefg.mirror.aliyuncs.com"]}EOF$ sudo systemctl daemon-reload$ sudo systemctl restart docker

2.1.2 在服務器上通過 docker 運行 lanproxy server

服務安裝完畢之后,就可以用docker跑服務了,可以自己寫一個 Dockerfile ,這里,我就把自己寫的放出來吧,大家可以拿去用著,gayhub 傳送門

這里我修改了 proxy-server-0.1 的部分文件,因為在 docker 中,需要保存服務前臺運行,否則容器會被 kill 掉,而官網默認的啟動腳本是后臺啟動的,把 bin/startup.sh 里面的啟動命令修改成前臺啟動即可(去掉nohub和后面的1&2 &)

# 1、克隆docker配置,如果要修改配置可以編輯 conf/config.properties 文件,配置方法見lanproxy官網$ git clone https://github.com/fengqiangboy/lanproxy-docker.git lanproxy-docker# 2、build docker鏡像$ cd lanproxy-docker$ sudo bash build_container.sh# 3、運行docker容器$ bash run_container.sh

2.1.3 將域名解析到我們的服務器

需要兩個域名,一個用來訪問我們的 lanproxy 后臺,一個用來訪問我們需要內網穿透的服務

例如:

lanproxy.fengqiangboy.com -> 用來訪問lanproxy后端test.fengqiangboy.com -> 用來訪問內網穿透服務

2.1.4配置 nginx 反向代理

將兩個域名解析到我們的服務器之后,再通過反向代理,將其反代到我們的lanproxy端口

下面配置的最終效果就是:

  1. 我們可以通過 lanproxy.fengqiangboy.com 訪問 lanproxy
  2. 我們可以通過 test.fengqiangboy.com 訪問本地電腦映射的服務

lanproxy.fengqiangboy.com.conf:

server {  listen 80;  # 這里使用自己的域名  server_name lanproxy.fengqiangboy.com;  charset utf-8;  location / {    proxy_set_header  X-Real-IP $remote_addr;    proxy_set_header  Host   $http_host;    # 這里根據你的lanproxy配置,改成 config.server.port的值    proxy_pass    http://127.0.0.1:8090;    client_max_body_size 35m;    proxy_http_version 1.1;    proxy_set_header Upgrade $http_upgrade;    proxy_set_header Connection "upgrade";  }}

test.fengqiangboy.com.conf:

server {  listen 80;  # 這里使用自己的域名  server_name test.fengqiangboy.com;  charset utf-8;  location / {    proxy_set_header  X-Real-IP $remote_addr;    proxy_set_header  Host   $http_host;    # 這里根據你的lanproxy配置,改成 外網接口 的值,在lanproxy后臺網頁上配置,后面配置    proxy_pass    http://127.0.0.1:50000;    client_max_body_size 35m;    proxy_http_version 1.1;    proxy_set_header Upgrade $http_upgrade;    proxy_set_header Connection "upgrade";  }}

2.1.5 打開 lanproxy 后臺頁面,添加客戶端和映射信息

  1. 打開 http://lanproxy.fengqiangboy.com
  2. 用前面 conf/config.properties 文件中配置的賬號和密碼登錄后臺
  3. 添加一個客戶端,記住客戶端密鑰
  4. 添加完客戶端之后添加一個配置,配置如下圖

docker,lanproxy,內網穿透服務

到此,服務端的配置就完成了。下面開始本地電腦的配置。

2.2.1 運行要被映射的服務

既然要把內網的服務映射出去,那首先就要把本地電腦的服務跑起來吧,不然拿什么來映射?這里就很多操作方法了,各個語言都不一樣,把自己的服務跑起來就行

2.2.2 運行本地電腦映射客戶端程序( lanproxy client )

這里有兩個方法,一個方法是使用官網提供的 go 版本,不需要安裝 java 環境在本地電腦上,另外一種是使用官網提供的 java 版本,這里我使用 java 版本的。

克隆 lanproxy 代碼到本地電腦

$ git clone https://github.com/ffay/lanproxy.git lanproxy

打包 lanproxy

打包之前需要確保你安裝了 maven

$ cd lanproxy$ mvn package

修改配置文件信息

打包完成之后,客戶端文件會出現在 distribution/proxy-client-0.1 目錄下,打開之后有是個文件夾: binconfliblog ,配置信息在 conf/config.properties 文件內,根據前面服務端的配置信息修改一下。

# 這里是在lanproxy后臺配置的密鑰client.key=key# 配置ssl信息,根據服務端的配置填寫ssl.enable=truessl.jksPath=test.jksssl.keyStorePassword=123456# 服務器的ipserver.host=163.162.161.160#根據服務端配置,開啟ssl的話填寫ssl的端口,否則填寫普通端口server.port=4993

啟動客戶端

客戶端信息配置完成之后就可以啟動客戶端了

# mac/linux使用這個$ bash bin/startup.sh# Windows 直接運行 bin/startup.bat

訪問測試

按照前面的配置,這時候我們應該是可以通過 test.fengqiangboy.com 來訪問我們的內網服務了的,用瀏覽器打開看看

docker,lanproxy,內網穿透服務

3、一點補充

為什么要使用docker?

使用docker主要是為了不破壞服務端環境,只是給 lanproxy 安裝了一個 jdk8 的環境,不影響其他服務繼續運行;而且使用 docker 還可以很方便的轉移到其它機器上面部署,只要把 Dockerfile 拷貝過去就可以了。

這樣搭建,服務器重啟的話需要手動重啟 lanproxy 嗎?

不需要,在服務端啟動 docker 容器的腳本下,我添加了 --restart unless-stopped 參數,只要 docker 服務啟動了,容器就會跟著啟動,如果你不需要這個需求,可以去掉這個參數

為什么不用花生殼?

前不久看到花生殼的公告,說從4月1日開始,免費版將不提供80端口映射,實際上我用這個映射最大的需求就是做微信調試,去掉80端口就不能做微信調試了,不滿足我的需求了,當然,花生殼還是不錯的,如果能滿足你的需求,還是可以省時省力完成內網穿透的

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到服務器教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 垦利县| 孟连| 酒泉市| 营山县| 宁夏| 遂昌县| 韶山市| 交口县| 越西县| 河曲县| 呼和浩特市| 惠安县| 汉川市| 新野县| 昆山市| 古丈县| 晋城| 丹寨县| 濮阳市| 隆子县| 潮安县| 呼和浩特市| 呼图壁县| 若尔盖县| 丰宁| 五河县| 太湖县| 登封市| 商丘市| 上林县| 临颍县| 中江县| 合江县| 集安市| 碌曲县| 全椒县| 荆门市| 蓬溪县| 安仁县| 舒城县| 如东县|