利用阿里云99元服务器自建VPN网络实现RDP远控家里电脑
nanshan 2024-11-25 15:26 29 浏览 0 评论
远程控制家里的电脑大家都在用哪些方案呢?向日葵、todesk、rustdesk、电脑管家、其他?大家都在评论区留言讨论吧。
之前给大家分享过使用阿里云99元一年的服务器自建RustDesk中继服务器实现远程控制家里的电脑,今天再给大家分享使用openvpn加微软原生的远程桌面去实现。比如向日葵、todesk、ruskdesk这些远控软件,远程桌面拥有更优异的性能,主要表现在对带宽要求更低,CPU占用更低,操作更流畅,笔者现在就正在车上使用openvpn+rdp连接家里面的主力机进行创作。
下面就跟着笔者一起来搭建吧。
购买服务器
如果你已经有服务器,或者已经购买过服务器,请忽略此步骤。
首先我们打开阿里云官网,找到99权益区,下单购买服务器,建议选择阿里Linux,或者ubuntu、debian做操作系统,不再建议cenos,毕竟官方已经不再支持,笔者的是阿里linux。
配置Openvpn server
配置安全组
在阿里云控制台,找到安全组设置,添加TCP端口1194,允许所有IP连接。国内UDP协议在有些电信运营商环境不太稳定,虽然UDP性能更好,但是不推荐使用。
登录服务器
如果是你windows10/11、MacOS、Linux系统,那么你可以直接使用系统自带的CMD/终端/Powershell等,配合ssh命令登录服务器。如果系统没有ssh命令,可以使用xshell等类似的工具远程连接服务器。
ssh root@ip
将IP换成自己服务器的公网IP,回车后,输入密码,即可登录服务器。
安装VPN
如果你的系统是ubuntu/debian类,则使用:
apt install openvpn easy-rsa
如果是centos/阿里linux等使用Yum包管理器的,则使用
yum install -y openvpn easy-rsa
安装完成后,建立一个临时目录用于生成证书,笔者是在用户目录下创建的easy-rsa目录,并在/usr/share/easy-rsa/目录下找到easyrsa脚本等文件,拷贝到刚创建的目录,不同的系统可能不太一样,笔者的alinux,是/usr/share/easy-rsa/3.0.8目录下
mkdir ~/easy-rsa
cd ~/easy-rsa
cp -rf /usr/share/easy-rsa/3.0.8/* ./
初始化
./easyrsa init-pki
生成CA证书,会提示你输入证书密码和证书的组织名称,名称可以随意
./easy-rsa build-ca
生成DH密钥,这个需要点时间,慢慢等完成即可
./easy-rsa gen-dh
生成服务器证书和密钥,此处会让输入前面创建CA证书时设置的密码
./easyrsa build-server-full server nopass
生成HMAC密钥,注意目录:
openvpn --genkey --secret ~/easy-rsa/pki/ta.key
生成撤消证书,此处也会让输入CA证书密钥
./easyrsa gen-crl
拷贝证书密钥等到openvpn的目录
mkdir -p /etc/openvpn/server/
cp -rp ~/easy-rsa/pki/{ca.crt,dh.pem,ta.key,crl.pem,issued,private} /etc/openvpn/server/
配置openvpn server,包括配置使用用户名密码登录,忽略客户端证书,网段等
/etc/openvpn/server/server.conf
# Secure OpenVPN Server Config
# Basic Connection Config
#
local 0.0.0.0
dev tun
proto tcp
port 1194
keepalive 10 120
max-clients 100
# Certs
ca /etc/openvpn/server/ca.crt
cert /etc/openvpn/server/issued/server.crt
key /etc/openvpn/server/private/server.key
dh /etc/openvpn/server/dh.pem
tls-auth /etc/openvpn/server/ta.key 0
# Ciphers and Hardening
reneg-sec 0
crl-verify /etc/openvpn/server/crl.pem
tls-version-min 1.2
cipher AES-256-CBC
client-to-client
#auth SHA512
# Drop Privs
user openvpn
group openvpn
# IP pool,VPN的网段,IP池,根据情况修改
server 10.198.0.0 255.255.0.0
topology subnet
# ip 持久化,一个客户端连接后,后续再连接都分配相同IP
ifconfig-pool-persist /etc/openvpn/server/ipp.txt
# 客户端配置,可以配置固定IP,下发特定路由表等
client-config-dir /etc/openvpn/ccd
# Misc
persist-key
persist-tun
#comp-lzo
# DHCP Push options force all traffic through VPN and sets DNS servers
# push "redirect-gateway def1 bypass-dhcp"
# push "route 172.17.0.0 255.255.0.0"
# 使用密码认证,指定认证用的脚本
auth-user-pass-verify /etc/openvpn/server/checkpwd.sh via-env
# Logging
log-append /var/log/openvpn.log
verb 6
verify-client-cert none
username-as-common-name
script-security 3
# vpn 服务器启动后的初始化脚本,可以在里面添加特定的NAT规则之类,
# 实现比如家里拔上VPN后,可以通过内网IP访问所有的服务器。
up /etc/openvpn/server/up.sh
/etc/openvpn/server/checkpwd.sh 密码检验脚本
#!/bin/sh
###########################################################
# This script will authenticate OpenVPN users against
# a plain text file. The passfile should simply contain
# one row per user with the username first followed by
# one or more space(s) or tab(s) and then the password.
###########################################################
PASSFILE="/etc/openvpn/server/user_passwd.txt"
LOG_FILE="/var/log/openvpn/openvpn-login.log"
TIME_STAMP=`date "+%Y-%m-%d %T"`
#username=$1
#password=$2
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
a=`env`
b=`set`
echo "${TIME_STAMP}: Incorrect password: username=\"${username}\", password=\"${password}\", env=${a}, set=${b}." >> ${LOG_FILE}
exit 1
/etc/openvpn/server/user_passwd.txt 密码文件,一行一个,用户名和密码间使用空格分开,请将123456789换成你的密码
cateyea 123456789
cateyeb 123456789
/etc/openvpn/server/up.sh文件
#!/bin/bash
# /usr/sbin/route add -net 172.17.0.0/16 gw 10.198.0.1
/etc/openvpn/ccd/cateyea 固定IP配置,如此处我们固定为10.198.255.252
ifconfig-push 10.198.255.252 255.255.0.0
启动服务器:
systemctl start openvpn-server@server
安装客户端
准备客户端文件cateye.ovpn
client
# 标识这是个客户端
dev tun
# 使用三层路由IP隧道(tun)还是二层以太网隧道(tap)。服务端是什么客户端就是什么
proto tcp
# 使用的协议,有udp和tcp。服务端是什么客户端就是什么
remote 你的IP 1194
# 服务端的地址和端口
resolv-retry infinite
# 一直尝试解析OpenVPN服务器的主机名。
# 在机器上非常有用,不是永久连接到互联网,如笔记本电脑。
nobind
# 大多数客户机不需要绑定到特定的本地端口号。
;user nobody
;group nobody
# 初始化后的降级特权(仅非windows)
persist-key
persist-tun
# 尝试在重新启动时保留某些状态。
#ca [inline]
<ca>
你的CA证书内容
</ca>
# cert vpn-client-01.crt
# key vpn-client-01.key
# ca证书、客户端证书、客户端密钥
# 如果它们和client.conf或client.ovpn在同一个目录下则可以不写绝对路径,否则需要写绝对路径调用
ns-cert-type server
auth-user-pass
#remote-cert-tls server
# 通过检查certicate是否具有正确的密钥使用设置来验证服务器证书。
#tls-auth [inline] 1
key-direction 1
<tls-auth>
你的ta.key文件内容
</tls-auth>
# 加强认证方式,防攻击。服务端有配置,则客户端必须有
cipher AES-256-CBC
# 选择一个密码。如果在服务器上使用了cipher选项,那么您也必须在这里指定它。注意,v2.4客户端/服务器将在TLS模式下自动协商AES-256-GCM。
# compress lz4-v2
# 服务端用的什么,客户端就用的什么
# 表示客户端启用lz4的压缩功能,传输数据给客户端时会压缩数据包。
verb 3
# 日志级别
;mute 20
# 沉默的重复信息。最多20条相同消息类别的连续消息将输出到日志。
ping 5
ping-restart 120
reneg-sec 2
hand-window 15
tran-window 5
将里面的IP换成你服务器的公网IP,将CA证书换成你的ca证书的内容,ta.key换你的ta.key的内容,可以在服务器上通过cat ta.key类似命令输出内容,然后复制粘贴即可。
在你的电脑上安装Openvpn客户端,安装后并导入配置文件,输入用户名、密码,即可连接成功,重复上述步骤,在你的家里面的电脑 ,公司的笔记本等上分别安装。
开启RDP
windows11 在设置->系统->远程桌面中打开,并且设置远程桌面的用户,默认管理员组的用户都有远程权限,无需二次添加,另外需要给用户设置密码。
windows10用户参考下图,也是设置->系统->远程桌面
在你的各电脑上都拔上openvpn后,在控制端打开远程桌面,输入受控端的vpn IP,即可连接,如果你配了ccd固定IP,直接输入即可,如果没配,可以通过ipconfig命令查看ip,或者在服务器上的ipp.txt文件中查看。
如果有不能下载客户端的朋友,可以关注并私信我,笔者提供安装包
相关推荐
- 如何为MySQL服务器和客户机启用SSL?
-
用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...
- Mysql5.7 出现大量 unauthenticated user
-
线上环境mysql5.7突然出现大量unauthenticateduser,进mysql,showprocesslist;解决办法有:在/etc/hosts中添加客户端ip,如192.16...
- MySQL 在 Windows 系统下的安装(mysql安装教程windows)
-
更多技术文章MySQL在Windows系统下的安装1.下载mysql和Framework链接链接:百度网盘请输入提取码提取码:6w3p双击mysql-installer-communit...
- MySql5.7.21.zip绿色版安装(mysql数据库绿色版安装)
-
1、去网上下载满足系统要求的版本(mysql-5.7.21-winx64.zip)2、直接解压3、mysql的初始化(1)以管理员身份运行cmd,在mysql中的bin目录下shift+右键-在...
- MySQL(8.0)中文全文检索 (亲测有效)
-
在一堆文字中找到含有关键字的应用。当然也可以用以下语句实现:SELECT*FROM<表名>WHERE<字段名>like‘%ABC%’但是它的效率太低,是全盘扫描。...
- 新手教程,Linux系统下MySQL的安装
-
看了两三个教程。终于在哔哩哔哩找到一个简单高效的教程,成功安装,up主名叫bili逍遥bili,感兴趣可以去看看。下面这个是我总结的安装方法环境:CentOS764位1.下载安装包,个人觉得在...
- 麒麟服务器操作系统安装 MySQL 8 实战指南
-
原文连接:「链接」Hello,大家好啊,今天给大家带来一篇麒麟服务器操作系统上安装MySQL8的文章,欢迎大家分享点赞,点个在看和关注吧!MySQL作为主流开源数据库之一,被广泛应用于各种业务...
- 用Python玩转MySQL的全攻略,从环境搭建到项目实战全解析
-
这是一篇关于“MySQL数据库入门实战-Python版”的教程,结合了案例实战分析,帮助初学者快速掌握如何使用Python操作MySQL数据库。一、环境准备1.安装Python访问Pytho...
- 安装MySQL(中标麒麟 安装mysql)
-
安装MySQL注意:一定要用root用户操作如下步骤;先卸载MySQL再安装1.安装包准备(1)查看MySQL是否安装rpm-qa|grepmysql(2)如果安装了MySQL,就先卸载rpm-...
- Mysql最全笔记,快速入门,干货满满,爆肝
-
目录一、MySQL的重要性二、MySQL介绍三、软件的服务架构四、MySQL的安装五、SQL语句六、数据库相关(DDL)七、表相关八、DML相关(表中数据)九、DQL(重点)十、数据完...
- MAC电脑安装MySQL操作步骤(mac安装mysqldb)
-
1、在官网下载MySQL:https://dev.mysql.com/downloads/mysql/根据自己的macOS版本,选择适配的MySQL版本根据自己需求选择相应的安装包,我这里选择macO...
- mysql主从(mysql主从切换)
-
1、本章面试题什么是mysql主从,主从有什么好处什么是读写分离,有什么好处,使用mycat如何实现2、知识点2.1、课程回顾dubboORM->MVC->RPC->SOApro...
- 【linux学习】以MySQL为例,带你了解数据库
-
做运维的小伙伴在日常工作中难免需要接触到数据库,不管是MySQL,mariadb,达梦还是瀚高等其实命令都差不多,下面我就以MySQL为例带大家一起来了解下数据库。有兴趣的小伙伴不妨评论区一起交流下...
- 玩玩WordPress - 环境简介(0)(玩玩网络科技有限公司)
-
简介提到开源博客系统,一般都会直接想到WordPress!WordPress是使用PHP开发的,数据库使用的是MySQL,一般会在Linux上运行,Nginx作为前端。这时候就需要有一套LNMP(Li...
- 服务器常用端口都有哪些?(服务器端使用的端口号范围)
-
下面为大家介绍一下,服务器常用的一些默认端口,以及他们的作用: 21:FTP服务所开放的端口,用于上传、下载文件。 22:SSH端口,用于通过命令行模式远程连接Linux服务器或vps。 23:...
你 发表评论:
欢迎- 一周热门
-
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
手机如何设置与显示准确时间的详细指南
-
【系统配置】信创终端挂载NAS共享全攻略:一步到位!
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)