背景
今年 8 月份左右,打折價買了一個阿里雲主機,比平常便宜了 2000 多塊。買了之后,本想作為一個博客網站的,畢竟國內的服務器訪問肯定快一些。滿心歡喜的下單之后,卻發現 http 服務,外網怎么也無法訪問。各種搜,最終在文檔中,終於看見:必須要買彈性公網 IP,並且綁定到阿里雲主機上,才可以用作web服務器。而且要求,阿里雲主機必須是未綁定過 IP 的。不過很不幸,我當時下單時,已經勾選了使用公網IP。本來想着解綁然后重新綁定下,應該就可以了。然而,已經綁定過公網IP的,是不允許再改綁彈性公網IP的。欲哭無淚,這個服務器,也就閑置了幾個月。
最近接觸了些內網穿透的知識,我突然想到,是不是借助內網穿透,也可以把我的阿里雲主機給暴露出來?畢竟內網穿透,使用的是 Linux 一些基礎知識,算不上很極客的技術,應該是具有通用性的。經驗證,竟然真的可行! 特記錄下來,獻給有同樣遭遇的有緣人。
使用 revel 搭建一個簡單的 Web 服務器
需要先搭建一個 Web 服務器,以供測試用。如果你選擇其他方式搭建 web 服務器,可直接跳過這一節。
下載最新版本 go
可以在 Go 下載頁,查看最新的穩定版本,來替換 go1.9.2.linux-amd64.tar.gz :
wget https://redirector.gvt1.com/edgedl/go/go1.9.2.linux-amd64.tar.gz
tar -C /usr/local -xzf go1.9.2.linux-amd64.tar.gz
如果已經安裝過 Go,可能需要先移除:
apt remove golang-go
在 ~/.profile 中,添加:
export PATH=$PATH:/usr/local/go/bin
在 ~/.bash_profile 中,添加:
export GOPATH=$HOME/go
$HOME/go 表示你想用作 $GOPATH 的文件夾。
設置完后,最好重啟下 shell 終端,以使信息生效。
直接從 github 下載 golang.org/x/sys 和 golang.org/x/net 源碼
golang.org下的包,直接安裝,在無法科學上網時,有極大概率會失敗。作為一種替代手段,我們可以直接從 github 下載對應的源碼到 $GOPATH 對應路徑。
# 創建包存儲路徑
mkdir $GOPATH/src/golang.org/x
#安裝git
apt install git
#下載 revel 依賴的包源碼。
git clone https://github.com/golang/net $GOPATH/src/golang.org/x/net
git clone https://github.com/golang/sys $GOPATH/src/golang.org/x/sys
# 安裝 revel
go get -u github.com/revel/cmd/revel
# revel 命令,需要在 $GOPATH 中執行
cd $GOPATH/src
# 創建並運行一個web應用
revel new hello-go-web
revel run hello-go-web
frp 配置
有關 frp 配置的細節,請參考 借助 frp 隨時隨地訪問自己的樹莓派。此處只貼出關鍵配置文件。
在公網能訪問的服務器上配置 frps 服務器端
[common]
bind_port = 7000
vhost_http_port =80
dashboard_port = dashboard_port_number
dashboard_user = dashboard_user_name
dashboard_pwd = dashboard_pwd_value
privilege_token = privilege_token_value
subdomain_host = example.com
注意: example.com 要換為自己的域名。
域名泛解析
將泛域名 *.example.com 解析到 frps 所在服務器的 IP 地址。這樣,你不需要頻繁修改 DNS 配置了。此處我們是打算把某個子域名解析到我們的阿里雲主機上。如果你想直接把根域名解析到服務器上,參考:通過自定義域名訪問部署於內網的 web 服務
在只能內網訪問的阿里雲主機上配置 fprc 客戶端
[common]
server_addr = your_server_IP
server_port = 7000
privilege_token = privilege_token_value
login_fail_exit = false
[ssh-aliyun]
type = tcp
local_IP = 127.0.0.1
local_port = 22
remote_port = remote_port_number
use_encryption = true
use_compression = true
[web-show]
type = http
local_port = 9000
subdomain = show
注意:9000 表示web服務器的本地端口,請根據需要替換;show,表示子域名,配置成功后,可以通過 show.example.com 訪問自己的 web 網頁了。
使用 Systemd 實現自動啟動 revel
使用 Systemd 實現自動啟動 frp,可以直接看 借助 frp 隨時隨地訪問自己的樹莓派 相關部分,不再贅述。此處着重說下 revel 自啟動的配置:
# 編寫 frp service 文件,以 centos7 為例,適用於 debian
mkdir /usr/lib/systemd/system/
vim /usr/lib/systemd/system/revel-hello-go-web.service
# 內容如下
變更內容:
[Unit]
DescrIPtion=/revel-hello-go-web
After=network.target
[Service]
Environment=PATH=$PATH:/usr/local/go/bin
Environment=GOPATH=/root/go
TimeoutStartSec=30
ExecStart=/root/go/bin/revel run hello-go-web
ExecStop=/bin/kill $MAINPID
Restart=on-failure
RestartSec=42s
[Install]
WantedBy=multi-user.target
# 啟動 revel-hello-go-web 並設置開機啟動
systemctl enable revel-hello-go-web
systemctl start revel-hello-go-web
systemctl status revel-hello-go-web
# 部分服務器上,可能需要加 .service 后綴來操作,即:
systemctl enable revel-hello-go-web.service
systemctl start revel-hello-go-web.service
systemctl status revel-hello-go-web.service
# 重新加載:
systemctl daemon-reload
注意:
- /root/go 要替換為自己電腦 $GOPATH 的真實路徑。
- 此處的 sytemd 的配置中, Environment 環境變量,必須設置,否則報錯