【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生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

【Linux进阶】UNIX体系结构分解——操作系统,内核,shell

1.什么是操作系统? 从严格意义上说,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境。我们通常将这种软件称为内核(kerel),因为它相对较小,而且位于环境的核心。  从广义上说,操作系统包括了内核和一些其他软件,这些软件使得计算机能够发挥作用,并使计算机具有自己的特生。这里所说的其他软件包括系统实用程序(system utility)、应用程序、shell以及公用函数库等

UnrealScriptIDE调试环境部署

先安装vs2010   再安装VSIsoShell.exe, 下载地址 https://pan.baidu.com/s/10kPNUuDGTbWXbz7Nos-1WA       fd3t   最后安装unside,下载地址 https://archive.codeplex.com/?p=uside  安装中间有一步选择Binary文件夹要选对路径。   安装好以后,启动 UDKDe

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

【服务器运维】CentOS7 minimal 离线安装 gcc perl vmware-tools

0. 本机在有网的情况下,下载CentOS镜像 https://www.centos.org/download/ 1. 取出rpm 有的情况可能不需要net-tools,但是如果出现跟ifconfig相关的错误,就把它安装上。另外如果不想升级内核版本的话,就找对应内核版本的rpm版本安装 perl-Time-Local-1.2300-2.el7.noarch.rpmperl-Tim

Windows/macOS/Linux 安装 Redis 和 Redis Desktop Manager 可视化工具

本文所有安装都在macOS High Sierra 10.13.4进行,Windows安装相对容易些,Linux安装与macOS类似,文中会做区分讲解 1. Redis安装 1.下载Redis https://redis.io/download 把下载的源码更名为redis-4.0.9-source,我喜欢跟maven、Tomcat放在一起,就放到/Users/zhan/Documents

Linux系统稳定性的奥秘:探究其背后的机制与哲学

在计算机操作系统的世界里,Linux以其卓越的稳定性和可靠性著称,成为服务器、嵌入式系统乃至个人电脑用户的首选。那么,是什么造就了Linux如此之高的稳定性呢?本文将深入解析Linux系统稳定性的几个关键因素,揭示其背后的技术哲学与实践。 1. 开源协作的力量Linux是一个开源项目,意味着任何人都可以查看、修改和贡献其源代码。这种开放性吸引了全球成千上万的开发者参与到内核的维护与优化中,形成了

Linux 下的Vim命令宝贝

vim 命令详解(转自:https://www.cnblogs.com/usergaojie/p/4583796.html) vi: Visual Interface 可视化接口 vim: VI iMproved VI增强版 全屏编辑器,模式化编辑器 vim模式: 编辑模式(命令模式)输入模式末行模式 模式转换: 编辑-->输入: i: 在当前光标所在字符的前面,转为输入模式