百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

利用阿里云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:...

取消回复欢迎 发表评论: