部署OpenVPN并使用多用户管理

引言

OpenVPN能方便我们打通内网以及保障服务的安全,但是官方部署openvpn的方式较为繁琐。

在github找到了一个star最多的openvpn部署脚本,十分便捷,特此记录。

安装

使用 github.com/angristan/o... 的openvpn安装脚本来快速部署openvpn服务器,同时他还集成了证书签发、撤销以及卸载功能。

bash 复制代码
curl -O https://raw.githubusercontent.com/angristan/openvpn-install/master/openvpn-install.sh
chmod +x openvpn-install.sh
./openvpn-install.sh

执行后会打开交互终端,询问你一些相关信息,用于生成配置:

  • 首先是IP配置,如果你是配置在云服务器上,并且有公网IP,此处改成公网IP。
  • 一般不需要IPv6支持,此处选否
  • 此处按需选择OpenVPN服务端口,一般保持默认即可
  • 选择传输层协议,一般使用UDP,除非你的网络不支持
  • 选择DNS,如果没有特殊需要,保持默认即可
  • 可选是否进行数据包压缩,官方貌似不推荐,选否
  • 选择是否定制加密选项,默认的即可,除非有特殊需求 之后就会开始安装OpenVPN,并进行相关配置

安装完成后生成客户端证书,会询问你客户端名,我们填写client;由于我们采用用户管理的方式,所以不需要客户端密码

到此OpenVPN服务端架设完毕,同时证书也生成在Home目录,拷贝给客户端使用即可。

多用户管理

用户较多时我们通常使用多用户单证书的方式管理客户端,此时客户端与服务端都需要修改配置。

服务端

  • 创建密码文件 /etc/openvpn/psw-file,用户名密码空格隔开,如 user 123456
bash 复制代码
echo user 123456 > /etc/openvpn/psw-file
bash 复制代码
PASSFILE="/etc/openvpn/psw-file"
LOG_FILE="/var/log/openvpn-password.log"
TIME_STAMP=`date "+%Y-%m-%d %T"`

if [ ! -r "${PASSFILE}" ]; then
  echo "${TIME_STAMP}: Could not open password file "${PASSFILE}" for reading." >> ${LOG_FILE}
  exit 1
fi

CORRECT_PASSWORD=`awk '!/^;/&&!/^#/&&$1=="'${username}'"{print $2;exit}' ${PASSFILE}`

if [ "${CORRECT_PASSWORD}" = "" ]; then 
  echo "${TIME_STAMP}: User does not exist: username="${username}", password="${password}"." >> ${LOG_FILE}
  exit 1
fi

if [ "${password}" = "${CORRECT_PASSWORD}" ]; then 
  echo "${TIME_STAMP}: Successful authentication: username="${username}"." >> ${LOG_FILE}
  exit 0
fi

echo "${TIME_STAMP}: Incorrect password: username="${username}", password="${password}"." >> ${LOG_FILE}
exit 1
  • 编辑 /etc/openvpn/server.conf 加入以下内容
conf 复制代码
auth-user-pass-verify /etc/openvpn/checkpsw.sh via-env
client-cert-not-required  
username-as-common-name 

最后重启OpenVPN systemctl restsart openvpn

客户端

打开 client.ovpn ,加入一行 auth-user-pass 即可。

连接时会询问你用户名和密码,证书输入后便可登录。

相关推荐
a努力。18 小时前
得物Java面试被问:B+树的分裂合并和范围查询优化
java·开发语言·后端·b树·算法·面试·职场和发展
霖雨18 小时前
备份 SQL Server 到 Azure Storage
后端·python·microsoft·flask·azure
IT_陈寒18 小时前
5 个现代 JavaScript 特性让你彻底告别老旧写法,编码效率提升 50%
前端·人工智能·后端
楼田莉子18 小时前
C++高级数据结构——LRU Cache
数据结构·c++·后端·学习
一叶飘零_sweeeet18 小时前
零基础入门 Go 语言
开发语言·后端·golang
0和1的舞者18 小时前
SpringBoot 接口规范:统一返回、异常处理与拦截器详解
java·spring boot·后端·spring·知识·统一
一 乐18 小时前
动漫交流与推荐平台|基于springboot + vue动漫交流与推荐平台系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
BingoGo18 小时前
别再手写 URL 解析器了:PHP 8.5 URI 扩展让 URL 处理更安全、更干净
后端·php
大鸡腿同学18 小时前
丛林中的狐狸把戏
后端
再学一点就睡18 小时前
IP从入门到起飞:妈妈再也不用担心我不会网络基础啦
前端·后端·tcp/ip