网易首页 > 网易号 > 正文 申请入驻

openvpn:如何实现双网互通

0
分享至

实现目标

  • client内部网络(192.168.66.x)和openvpn服务器所在网络(10.3.0.x)实现互通

一、环境

  1. 1. 架构
    ens160:x.x.x.x-ens32:10.3.0.100(vpn server) – 10.3.0.x
    <–>
    eth0:192.168.66.181(vpn client) – 192.168.66.x

  2. 2. 软件版本

    • system : centos7.2

    • openvpn : 2.4.6-1.el7

二、安装部署

  1. 1. openvpn server安装(10.3.0.100)

    wget https://git.io/vpn -O openvpn-install.sh && bash openvpn-install.sh
    备用地址:wget http://d.guohao.space/vpn/openvpn-install.sh -O openvpn-install.sh && bash openvpn-install.sh

    I need to ask you a few questions before starting the setup.

    You can leave the default options and just press enter if you are ok with them.

    First, provide the IPv4 address of the network interface you want OpenVPN

    listening to.

    IP address: x.x.x.x

    Which protocol do you want for OpenVPN connections?

    1) UDP (recommended)

    2) TCP

    Protocol [1-2]: 2

    What port do you want OpenVPN listening to?

    Port: 31194

    Which DNS do you want to use with the VPN?

    1) Current system resolvers

    2) 1.1.1.1

    3) Google

    4) OpenDNS

    5) Verisign

    DNS [1-5]: 1

    Finally, tell me your name for the client certificate.

    Please, use one word only, no special characters.

    Client name: client

    Okay, that was all I needed. We are ready to set up your OpenVPN server now.

    Press any key to continue...

    # 这回车后会安装相关的包,生成客户端配置文件,并启动vpn服务

    ...

    ...

    Finished!

    Your client configuration is available at: /root/client.ovpn

    • IP address
      对外提供服务的公网ip

    • Client name
      客户端名称,这里就用默认的client,创建新用户时可以再运行这个脚本创建

    • /root/client.ovpn
      这个客户端的配置文件,用户名是由上面Client name确定。后面客户端要用到该文件

  2. 2. vpn server端配置

    # cat /etc/openvpn/server.conf

    port 31194

    proto tcp

    dev tun

    sndbuf 0

    rcvbuf 0

    ca ca.crt

    cert server.crt

    key server.key

    dh dh.pem

    auth SHA512

    tls-auth ta.key 0

    topology subnet

    server 10.8.0.0 255.255.255.0

    ifconfig-pool-persist ipp.txt

    # push "redirect-gateway def1 bypass-dhcp" 改为

    push "route 10.3.0.0 255.255.255.0"

    # push "dhcp-option DNS 114.114.114.114"

    keepalive 10 120

    cipher AES-256-CBC

    user nobody

    group nobody

    persist-key

    persist-tun

    status openvpn-status.log

    verb 3

    crl-verify crl.pem

    配置说明:

    • server
      vpn网络网段,这个可自定义,用默认的也可以

    • push “redirect-gateway def1 bypass-dhcp”
      vpn server向客户端推送路由信息,默认的配置会使客户端所有流量都经过vpn,这不是我们想要的,只有到内网的才路由到vpn

    • push “dhcp-option DNS 114.114.114.114”
      直接去掉,如果有内部dns服务器的话要改成内部的dns

    修改完记得重启vpn服务
    systemctl restart openvpn@server

  3. 3. client 端安装配置

    • 安装
      yum install openvpn

    • 配置
      把之前server端生成的client.ovpn放置到/etc/openvpn/client/client.ovpn,执行下面命令启动客户端程序
      openvpn --daemon --cd /etc/openvpn/client/ --config client.ovpn --log-append /var/log/openvpn.log

    • 查看
      ip addr会到多了个tun0网络,这个就是vpn网络

      # ip addr

      ...

      ...

      8: tun0: <POINTOPOINT,MULTICAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN group default qlen 100

      link/none

      inet 10.8.0.2/24 brd 10.8.0.255 scope global tun0

      valid_lft forever preferred_lft forever

      ip route 可以看到推送过来的路由 10.3.0.0/8

      # ip route

      default via 192.168.66.2 dev eth0 proto static metric 100

      10.8.0.0/24 dev tun0 proto kernel scope link src 10.8.0.2

      10.3.0.0/24 via 10.8.0.1 dev tun0

      192.168.66.0/24 dev eth0 proto kernel scope link src 192.168.66.181 metric 100

      如果没看到相关信息,查看日志/var/log/openvpn.log。

    • 测试
      ping 10.8.0.1
      ping通的话说明和vpn服务端成功连接

  4. 4. 实现客户端访问内部网络(server端操作)
    完成上面操作,可实现client访问vpn服务器,但是还没办法访问vpn服务器所在的网络,继续做如下操作

    • 开启服务器的网络转发功能
      查看是否已经开启了转发,1是开启
      sysctl -a|grep '\.forwarding'

      net.ipv4.conf.all.forwarding = 0

      net.ipv4.conf.default.forwarding = 0

      net.ipv4.conf.ens160.forwarding = 0

      net.ipv4.conf.ens32.forwarding = 0

      net.ipv4.conf.lo.forwarding = 0

      net.ipv4.conf.tun0.forwarding = 0

      如果上面grep结果已经是= 1 就说明已经开启,不用做下面操作了
      /etc/sysctl.conf 对应的值由0改为1,没有的话在最后添加如下行

      net.ipv4.ip_forward = 1

      执行命令生效,执行下面命令后再查看就是 = 1了
      sysctl -p

    • 在vpn服务器上做snat,修改到内网时的源ip为vpn服务器的ip,不然流量回不来了
      firewall-cmd --direct --add-rule ipv4 nat POSTROUTING 0 -s 192.168.66.0/24 -o ens32 -j SNAT --to-source 10.3.0.100

    完成上面两部操作后即可实现客户端访问vpn服务器端的内部10.3.0.0/24网络,ping个同段的其他机器测试

  5. 5. 指定客户端ip
    有时候我们喜欢给客户端分配ip而不是动态获得,做下面配置

    • 指定客户端配置文件路径

      # /etc/openvpn/server.conf 中加入下面一行

      client-config-dir ccd

    • 创建用户配置文件

      # /etc/openvpn/ccd/client

      ifconfig-push 10.8.0.10 255.255.255.0

      指定了client客户的ip是10.8.0.10

    重启openvpn服务生效

  6. 6. 配置双网互通
    通过上面操作可以实现192.168.66.181访问10.3.0.x网络主机,但是192.168.66.x(配置了10.3.0.x路由到192.168.66.181)的机器并不能通过192.168.66.181访问到10.3.0.x网络,还需要做如下配置

    • 本地添加192.168.66.x路由

      # /etc/openvpn/server.conf 中添加如下3行

      client-to-client

      # client 路由

      route 192.168.66.0 255.255.255.0 10.8.0.10

    • client声明自己的路由

      # cat /etc/openvpn/ccd/client

      ifconfig-push 10.8.0.10 255.255.255.0

      iroute 192.168.66.0 255.255.255.0

      注意是iroute不是route
      重启后即可看到本地多了192.168.66.x路由,客户端192.168.66.x可以通过192.168.66.181访问10.3.0.x网络了

    • 10.3.0.x访问192.168.66.x
      道理和192.168.66.181访问10.3.0.x一样,需要做snat
      firewall-cmd --direct --add-rule ipv4 nat POSTROUTING 0 -s 10.3.0.0/24 -o eth0 -j SNAT --to-source 192.168.66.181

  7. 7. 当然还要考虑高可用,这个根据实际情况搞

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
看到卢鑫玉浩“分道扬镳”,我才知道张鹤擎加入德云社,有多正确

看到卢鑫玉浩“分道扬镳”,我才知道张鹤擎加入德云社,有多正确

圈里的甜橙子
2024-11-25 22:22:35
全国陷“关停潮"!一年亏损上千万,艰难求生的客运站,会消失吗

全国陷“关停潮"!一年亏损上千万,艰难求生的客运站,会消失吗

李砍柴
2024-11-24 17:07:55
中国对日本免签了,石破茂说了一句意味深长的话!

中国对日本免签了,石破茂说了一句意味深长的话!

西楼知趣杂谈
2024-11-24 19:40:43
民警踢小学生后续:男生殴打同学,副所长被停职,警方评论区沦陷

民警踢小学生后续:男生殴打同学,副所长被停职,警方评论区沦陷

谭谈社会
2024-11-24 19:28:46
诺基亚,依旧奇葩!

诺基亚,依旧奇葩!

最黑科技
2024-11-11 21:32:38
明日开播!新悬疑爱情剧来袭,落魄千金×复仇霸总,试探撩拨

明日开播!新悬疑爱情剧来袭,落魄千金×复仇霸总,试探撩拨

影视快通车
2024-11-25 10:25:34
刀郎真的抄袭王金兰20首歌吗?来看法律如何认定

刀郎真的抄袭王金兰20首歌吗?来看法律如何认定

阿伧说事
2024-11-25 17:10:23
43岁李小璐离婚后越来越嫩,戴蕾丝头巾少女感十足,皮肤白如雪

43岁李小璐离婚后越来越嫩,戴蕾丝头巾少女感十足,皮肤白如雪

南城无双
2024-11-26 00:51:27
事实证明,被传卖掉上亿豪宅移民美国的王刚,已经走上另一条大道

事实证明,被传卖掉上亿豪宅移民美国的王刚,已经走上另一条大道

简读视觉
2024-07-10 01:18:34
王曼昱讲出马琳咋待她!丢奥运女单资格后首次发声,承认今年不顺

王曼昱讲出马琳咋待她!丢奥运女单资格后首次发声,承认今年不顺

三十年莱斯特城球迷
2024-11-25 00:31:18
回顾:18岁校花和41岁教官相爱,死前被割舌头,最终血液干涸而亡

回顾:18岁校花和41岁教官相爱,死前被割舌头,最终血液干涸而亡

江东浪流史
2024-11-23 20:00:03
塔图姆:乔治离开后快船有球员得到更多自由 这让每个人打得更好

塔图姆:乔治离开后快船有球员得到更多自由 这让每个人打得更好

直播吧
2024-11-25 09:40:43
军事 | 莎拉·杜特尔特说小马科斯要杀她:菲律宾会不会再次内战?

军事 | 莎拉·杜特尔特说小马科斯要杀她:菲律宾会不会再次内战?

新民周刊
2024-11-25 09:10:23
重组!阿森纳后腰换代,6000万签快攻爆点,美丽足球回来了

重组!阿森纳后腰换代,6000万签快攻爆点,美丽足球回来了

球文速递
2024-11-25 13:43:02
土地卖不出去了,数量庞大的公务员靠什么吃法?

土地卖不出去了,数量庞大的公务员靠什么吃法?

逍遥论经
2024-11-25 09:11:50
“吃定”一个女人的顶级手段:不是花钱,不是哄她,而是这7个字

“吃定”一个女人的顶级手段:不是花钱,不是哄她,而是这7个字

伊人河畔
2024-11-17 10:47:39
蓄势待发,外媒:BLG续约除Xun外的其余四人,并永久签下Wei

蓄势待发,外媒:BLG续约除Xun外的其余四人,并永久签下Wei

懂球帝
2024-11-25 23:27:10
黄翠如公布怀孕后晒近照!母爱洋溢,老公萧正楠曝烧水都会烫伤手

黄翠如公布怀孕后晒近照!母爱洋溢,老公萧正楠曝烧水都会烫伤手

圈里的甜橙子
2024-11-25 22:43:34
张辽心知肚明:关羽能秒斩颜良文丑,却为何打不过弱一流的庞德?

张辽心知肚明:关羽能秒斩颜良文丑,却为何打不过弱一流的庞德?

Ido历史
2024-11-18 17:52:35
体操世界冠军力挺吴柳芳:活出自我,管晨辰不要管人家的事

体操世界冠军力挺吴柳芳:活出自我,管晨辰不要管人家的事

米修体育
2024-11-24 02:12:11
2024-11-26 02:20:49

科技要闻

特斯拉又降价,知情人士:冲刺今年销售目标

头条要闻

挪威史上最大规模性丑闻 妇科医生20年强奸87名患者

头条要闻

挪威史上最大规模性丑闻 妇科医生20年强奸87名患者

体育要闻

杨瀚森这态度,是打不了NBA的...

娱乐要闻

爆料郑雨盛和女模特,女方非正常怀孕

财经要闻

刘煜辉最新演讲全文:蛇的策略

汽车要闻

特斯拉限时优惠:Model Y仅23.99万起 还能5年0息

态度原创

本地
房产
艺术
数码
军事航空

本地新闻

城市24小时|领跑万亿城市,武汉“开挂”了?

房产要闻

合生把上百个亿万富豪搞破防了

艺术要闻

故宫珍藏的墨迹《十七帖》,比拓本更精良,这才是地道的魏晋写法

数码要闻

雷神银翼 F60 投影仪 1499 元首销,支持 800CVIA 亮度

军事要闻

俄方称在库尔斯克州上空击落多枚导弹及多架无人机

无障碍浏览 进入关怀版