【linux】centos7下部署openvpn专用隧道

2024-04-08 22:04

本文主要是介绍【linux】centos7下部署openvpn专用隧道,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 本站以分享各种运维经验和运维所需要的技能为主

《python零基础入门》:python零基础入门学习

《python运维脚本》: python运维脚本实践

《shell》:shell学习

《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战

《k8》暂未更新

《docker学习》暂未更新

《ceph学习》ceph日常问题解决分享

《日志收集》ELK+各种中间件

《运维日常》运维日常

《linux》运维面试100问

【linux】centos7下部署openvpn专用隧道

部署过程一下:

yum -y install easy-rsa
mkdir -p /opt/easy-rsa
cp -a /usr/share/easy-rsa/3.0.8/* /opt/easy-rsa/
cp -a /usr/share/doc/easy-rsa-3.0.8/vars.example /opt/easy-rsa/vars
vi /opt/easy-rsa/vars 
#打开注释
set_var EASYRSA_DN	"cn_only"
set_var EASYRSA_REQ_COUNTRY	"CN"
set_var EASYRSA_REQ_PROVINCE	"Shanghai"
set_var EASYRSA_REQ_CITY	"Shanghai"
set_var EASYRSA_REQ_ORG	        "lucifer"
set_var EASYRSA_REQ_EMAIL	"xxx@xxx.com"
set_var EASYRSA_NS_SUPPORT	"yes"#生成证书---需要加密的输入密码,不需要的直接回车和yes跳过,我一般都是nopass过去,因为有证书就可以了
/opt/easy-rsa/easyrsa init-pki
/opt/easy-rsa/easyrsa build-ca
/opt/easy-rsa/easyrsa build-ca nopass
echo -e 'node' | ./easyrsa gen-req server nopass
echo -e 'yes' | ./easyrsa sign server server
./easyrsa gen-dhyum -y install openvpncd /etc/openvpn/
vi server.conf
port 1777 #端口
proto udp #协议
dev tun #采用路由隧道模式tun
ca ca.crt #ca证书文件位置
cert server.crt #服务端公钥名称
key server.key #服务端私钥名称
dh dh.pem #交换证书
server 10.188.0.0 255.255.255.0 #给客户端分配地址池,注意:不能和VPN服务器内网网段有相同
push "route 172.26.2.0 255.255.0.0" #允许客户端访问内网网段
push "route 172.26.3.0 255.255.0.0"
push "route 10.80.0.0 255.255.255.0"
route 172.26.2.0 255.255.0.0
route 172.26.3.0 255.255.0.0
route 10.80.0.0 255.255.255.0
ifconfig-pool-persist ipp.txt #地址池记录文件位置
keepalive 10 120 #存活时间,10秒ping一次,120 如未收到响应则视为断线
max-clients 100 #最多允许100个客户端连接
status openvpn-status.log #日志记录位置
verb 3 #openvpn版本
client-to-client #客户端与客户端之间支持通信
log /var/log/openvpn.log #openvpn日志记录位置
persist-key #通过keepalive检测超时后,重新启动VPN,不重新读取keys,保留第一次使用的keys。
persist-tun #检测超时后,重新启动VPN,一直保持tun是linkup的。否则网络会先linkdown然后再linkup
duplicate-cncp -a /opt/easy-rsa/pki/ca.crt /etc/openvpn/
cp -a /opt/easy-rsa/pki/issued/server.crt /etc/openvpn/
cp -a /opt/easy-rsa/pki/private/server.key /etc/openvpn/
cp -a /opt/easy-rsa/pki/dh.pem /etc/openvpn/#手动起好看日志
nohup openvpn --config /etc/openvpn/server.conf >/dev/null &

生成客户端证书脚本:

客户端:生成脚本---mac或者win直接下载openvpn的gui客户端,win把配置文件放到config下即可。mac直接导入file即可cat create-openvpn-client.sh 
#!/bin/bash
cd /opt/easy-rsa
echo $1 | /opt/easy-rsa/easyrsa gen-req $1 nopass
echo yes | /opt/easy-rsa/easyrsa sign client $1
mkdir /tmp/$1
cd /tmp/$1
cp /opt/easy-rsa/pki/ca.crt .
cp /opt/easy-rsa/pki/issued/$1.crt .
cp /opt/easy-rsa/pki/private/$1.key .
echo "client #指定当前VPN是客户端
dev tun #使用tun隧道传输协议
proto udp #使用udp协议传输数据
remote <your-ip> 1777 #openvpn服务器IP地址端口号
resolv-retry infinite #断线自动重新连接,在网络不稳定的情况下非常有用
nobind #不绑定本地特定的端口号
ca /Users/apple/Downloads/$1/ca.crt #指定CA证书的文件路径
cert /Users/apple/Downloads/$1/$1.crt #指定当前客户端的证书文件路径
key /Users/apple/Downloads/$1/$1.key #指定当前客户端的私钥文件路径
verb 3 #指定日志文件的记录详细级别,可选0-9,等级越高日志内容越详细
persist-key #通过keepalive检测超时后,重新启动VPN,不重新读取keys,保留第一次使用的keys
persist-tun #检测超时后,重新启动VPN,一直保持tun是linkup的。否则网络会先linkdown然后再linkup" > client.ovpn
cd .. && tar -czf $1.tar.gz $1 cat create-openvpn-client-win.sh 
#!/bin/bash
cd /opt/easy-rsa
echo $1 | /opt/easy-rsa/easyrsa gen-req $1 nopass
echo yes | /opt/easy-rsa/easyrsa sign client $1
mkdir /tmp/$1
cd /tmp/$1
cp /opt/easy-rsa/pki/ca.crt .
cp /opt/easy-rsa/pki/issued/$1.crt .
cp /opt/easy-rsa/pki/private/$1.key .
echo "client
dev tun
proto udp 
remote <your-ip> 1777 
resolv-retry infinite
nobind
ca ca.crt
cert $1.crt
key $1.key
verb 3
persist-key
persist-tun" > client.ovpn
tar -czf $1.tar.gz . 
mv $1.tar.gz /tmp
chown xxx:xxx /tmp/$1.tar.gz ----注意,win的路径只需要当下就可以。

固定ip

#在server.conf上需要加上

ifconfig-pool-persist ipp.txt #地址池记录文件位置

[root@tt openvpn]# ll ccd/
总用量 4
-rw-r--r-- 1 root root 36 1月   5 2023 xxx <your client name>
[root@tt openvpn]# cat ccd/<xxx> # <your client name> 
ifconfig-push 10.188.0.100 255.255.255.0 
[root@tt openvpn]# pwd
/etc/openvpn

这篇关于【linux】centos7下部署openvpn专用隧道的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/886520

相关文章

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Linux samba共享慢的原因及解决方案

《Linuxsamba共享慢的原因及解决方案》:本文主要介绍Linuxsamba共享慢的原因及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux samba共享慢原因及解决问题表现原因解决办法总结Linandroidux samba共享慢原因及解决