Forticlient专线多用户共享

在远程办公期间,有那么一些同事总是有奇奇怪怪的想法,比如:“我怎么能从云服务器访问家里电脑”,“我怎么通过VPN访问云服务器”,“我怎么这样,怎么那样”;下面就分享一个奇怪的上网方案。

背景概述

国内某搜索引擎大家都知道,有用资料基本查不出来,全特么广告,这时就需要访问一下海外的某搜索引擎等等,所以就购买了某公司的商用专线产品,实现天津到新加坡网络加速,优点:价格便宜,速度快;缺点:只支持端到端的拨号连接(Forticlient),并且每个客户端都单独收费。所以就衍生出“能不能将一个客户端通过某种方式共享给多人使用”,作为公司“专业网管”也就只能硬着头皮尝试一下了,功夫不负有心人,还是可以跑通的。

安装流程

环境描述

  • 操作系统:Ubuntu 1204
  • VPN客户端:Openforticlient、Wireguard

Openforticlient

github仓库:https://github.com/adrienverge/openfortivpn.git

安装
apt install openfortivpn
配置

openforticlient配置文件

# cat /etc/openfortivpn/config.conf
# config file for openfortivpn, see man openfortivpn(1)
host = <vpn提供商提供>
port = <vpn提供商提供>
username = <vpn提供商提供>
password = <vpn提供商提供>
set-routes = 0
#set-dns = 0
#pppd-use-peerdns = 0
# X509 certificate sha256 sum, trust only this one!
trusted-cert = 25a0d500f10d6bbe06f0761bcc7a023d6174b82ddab4e4c2ccf9763f1b44748f

openforticlient systemd文件

$cat /etc/systemd/system/openfortivpn.service
[Unit]
Description=OpenfortiVPN daemon
Documentation=OpenfortiVPN daemon
After=network.target

[Service]
Type=simple
ExecStart= /usr/local/bin/openfortivpn -c /etc/openfortivpn/config.conf
Restart=on-failure

[Install]
WantedBy=multi-user.target

启动:

systemctl start openfortivpn.service

wireguard

安装
apt install wireguard
wiregard配置文件

$ cat /etc/wireguard/wg0.conf


[Interface]
Address = 192.168.8.1/24
SaveConfig = true
PostUp = iptables -A FORWARD -i wg0 -j ACCEPT; iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE
PostDown = iptables -D FORWARD -i wg0 -j ACCEPT; iptables -t nat -D POSTROUTING -o ppp0 -j MASQUERADE
ListenPort = 51821
PrivateKey = kOQgWsV9CJ6gob/VOt8+t/Yba9rFmHMwbZp8St5c8kU=

[Peer]
PublicKey = VC4H1P273gsHu6ebyL2gS0j3JDrewM85vcRWld5OuG8=
AllowedIPs = 192.168.8.10/32

3、服务器路由表/接口转发配置

sudo ip rule add from 192.168.8.0/24 table 10
sudo ip route add default dev ppp0 table 10
sudo ip route add 172.16.8.0/22 dev eth0 table 10
sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

查看路由表状态:

iptables -vnL -t  nat
ip route show table 10

附:

有时VPN链接过多或者forticlient无故掉线需要重新拨号,所以就写了一个脚本监控它,其实也可以用Supervisor等服务替代以下脚本。

进程重启脚本

#!/bin/bash
systemctl restart openfortivpn.service
if test $? -eq 0; then
    sleep 5
    sudo ip rule del from 192.168.8.0/24 table 10
    sudo ip route del default dev ppp0 table 10
    sudo ip route del 172.16.8.0/22 dev eth0 table 10
    sudo  iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE

    sudo ip rule add from 192.168.8.0/24 table 10
    sudo ip route add default dev ppp0 table 10
    sudo ip route add 172.16.8.0/22 dev eth0 table 10
    sudo  iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
fi
systemctl restart wg-quick@wg0.service

检测openfortivpn运行状态脚本

#!/bin/bash
check() {
    fortivpn_status=`systemctl is-active openfortivpn.service > /dev/null 2>&1 && echo 0 || echo 1`
}
while true; do
    check
    if [ $fortivpn_status -ne 0 ]; then
        systemctl restart openfortivpn.service
        if test $? -eq 0; then
            sleep 5
            sudo ip rule del from 192.168.8.0/24 table 10
            sudo ip route del default dev ppp0 table 10
            sudo ip route del 172.16.8.0/22 dev eth0 table 10
            sudo  iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE

            sudo ip rule add from 192.168.8.0/24 table 10
            sudo ip route add default dev ppp0 table 10
            sudo ip route add 172.16.8.0/22 dev eth0 table 10
            sudo  iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
        fi
        systemctl restart wg-quick@wg0.service
    fi
    sleep 30
done

systemd启动文件

[root@vpn01 system]# cat  check_openfortivpn.service
[Unit]
Description=rinetd check

[Service]
WorkingDirectory=/opt
ExecStart=/bin/bash restartVPN.sh
Restart=always

[Install]
WantedBy=multi-user.target

wiregard可以使用wg-portal进行用户管理。

wiregard客户端下载:

Windows

https://download.wireguard.com/windows-client/wireguard-amd64-0.0.30.msi

Mac(app store非中国区可安装)

https://itunes.apple.com/us/app/wireguard/id1451685025?ls=1&mt=12
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容