AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 528070
Accepted
armandfp
armandfp
Asked: 2019-07-03 07:51:38 +0800 CST2019-07-03 07:51:38 +0800 CST 2019-07-03 07:51:38 +0800 CST

为 openVPN 动态推送路由

  • 772

我知道从 server.conf 我可以做到这一点:

push "route 192.168.20.0 255.255.255.0"

但是,有没有办法动态推送路由?我有一个 API 调用,它返回 vpn 客户端需要的所有路由,所以如果发生某些路由更改,客户端将重新启动 vpn 连接,它将拥有新的路由。这可能吗?如何?我想从服务器端管理这个。

route openvpn
  • 2 2 个回答
  • 2205 Views

2 个回答

  • Voted
  1. Best Answer
    EchoMike444
    2019-07-03T20:29:51+08:002019-07-03T20:29:51+08:00

    自定义配置的关键是使用客户端连接选项

    vpn-endpoint.conf 的提取

    script-security 2
    client-connect /etc/openvpn/up-client
    

    一个非常基本的脚本

     #!/bin/sh
     CONFIG_FILE=$1
     ( env ; echo CONFIG_FILE  ${CONFIG_FILE} ) >> /var/log/openvpn-up-client.log
     case "$username" in
        (me)
             echo 'push "route 192.168.168.168 255.255.255.255"' >>${CONFIG_FILE}
             ;;
        (*)
             echo 'push "route 192.168.169.169 255.255.255.255"' >>${CONFIG_FILE}
             ;;
     esac
    

    man openvpn提取

    --客户端连接cmd

    在客户端连接上运行命令 cmd。

    cmd 包含脚本(或可执行程序)的路径,可选地后跟参数。

    路径和参数可以是单引号或双引号和/或使用反斜杠转义,并且应该用一个或多个空格分隔。

    该命令将刚刚经过身份验证的客户端的公用名和 IP 地址作为环境变量传递(请参阅下面的环境变量部分)。该命令还将新创建的临时文件的路径名作为最后一个参数(在 cmd 中指定的任何参数之后)传递,该命令用于将动态生成的配置文件指令传递回 OpenVPN。

    如果脚本要在客户端连接时生成要在服务器上应用的动态配置文件,则应将其写入最后一个参数命名的文件中。

    有关可以在动态生成的配置文件中合法使用的选项,请参阅下面的 --client-config-dir 选项。

    请注意,脚本的返回值很重要。如果脚本返回非零错误状态,将导致客户端断开连接。

    • 4
  2. binakh
    2019-10-02T03:12:56+08:002019-10-02T03:12:56+08:00

    我遇到过同样的问题。我编写了一个脚本,该脚本从数据库中调用一个存储过程,该过程返回路由。在你的情况下API。并将这些路由写入 file_list (sys.argv[1:])。

    此脚本将其作为选项传递给您的 serverConfig /etc/openvpn/server.conf。你写这行:

    脚本安全 2

    客户端连接 /path/to/your/script

    您可以使用 python 脚本并在脚本中使用append函数:

    file_list.append("push \"route %s %s\"\n" % (your_vpn_route, "255.255.255.x"))
    
    • 0

相关问题

  • 通过 VPN 路由更多流量

  • OpenVPN TLS 握手在 P_CONTROL_HARD_RESET_SERVER_V2 挂起(未收到)

  • 如何将 tc qdisc 命令与特定接口永久关联?

  • 哪些vpn服务不需要Win/Android/iOS客户端软件就可以实现?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve