这几天想用ipad连接电脑试一下,这样上课的时候就不用搬抬这么重的臭屁电脑了,于是开始尝试了几种方法,一开始先开通了windows专业版,想用学校机房电脑测试一下,结果不行,后面还是打算研究在ipad上如何使用,这样就可以方便携带了,2023.2.22刚入手了益博斯键盘和向日葵的鼠标,准备尝试一下,用几天,不行就退掉准备入二手轻薄本了。
玩了一周,最后还是用了cygwin下的autossh才能实现足够稳定的连接,吐血了要
提前说明这里后面的教程需要有些许基础的linux知识。
这里给出内容大纲
这里推荐使用向日葵,直接用就可以了,当然还有类似teamviwer之类的软件。
不过这类软件的原理是直接投屏。
那免费版肯定就是会画面卡一点,服务器资源肯定给氪金用户的了,不过目前对比起来感觉和rd-client也差不了多少。
并且投屏的另一个缺点就是你的电脑会跟着一起点亮屏幕,然后你在ipad做什么别人都能看到你的电脑上也在干这个,所以就稍微隐私性差一点,当然如果你电脑放家里也没啥,只不过我电脑一般放在实验室,emm就有不太好吧。
使用这个呢网上也有很多相关教程了,这里着重推荐这个,他写的好到以至于我都不好意思写了,感觉像是再写一遍。
从任何地方远程桌面连接到家里的电脑 - 知乎 (zhihu.com)
首先是需要被连接的那个电脑是专业版,不过专业版得800多,所以没有预算的可以去破解,这里的话推荐搜heu kms,一个软件,很方便升级到专业版。
有了专业版之后就可以开启远程桌面了,这里可以在控制面板找到开启,win10也可以直接在设置里面找
这里直接搜远程就可以选择了,
在选择用户那里可以看到自己电脑的用户名(这个有时候很多人会弄错)
电脑端连接不需要本电脑是专业版,window电脑本身自带远程桌面连接,输入好正确的ip地址就可以了。
获取ip地址的方法可以在控制台输入ipconfig
找到下面这里的ip地址
这里我就不提供其他操作系统的了,有兴趣的人可以去搜下。
这里连接方法本质上是和电脑端类似的,因为我们用的是RD-client,是微软官方退出的连接客户端,
也许在APP-Store上面搜到的不叫这个名字,也不是很多人用,但是就是相关度最高那个,下载完之后,名字就是rd-client。
这里的连接也是比较简单的,输入id即可
连接失败原因:
原因有很多种
比如可能用户名弄错了,密码一般是我们登录微软账号的那个,不要输pin的。
可以把那个”仅限网络身份级别连接的勾选“给去掉尝试一下。
ip地址也要注意不要写错,比如我们的校园网的ip地址每天都会变的。
注意了,以上的方法都是只能在同一个局域网下使用的,例如校园网,那这个时候就有人不满了,那我都同一个局域网了,那算什么远程啊,浪费我时间吗这不。
ok为了解决这个问题,我们可以通过内网穿透的方式来实现在其他网络远程控制(但是两部设备也一样需要联网)。相信大家应该都听过这个词吧,这里就不做详细阐述了,只需要知道我们要一个有公网ip的服务器来帮忙转接端口就可以了。
这里用的是腾讯云服务器来做一个内网穿透。
在云服务器控制台和宝塔(如果有的话)那里都要打开
当然如果为了更加安全,可以不要用3389端口
这里比较简单
首先可以在本机电脑创建ssh密钥(如果已经创建了会有提示)
ssh-keygen
成功执行后该命令会在~/.ssh
文件夹下生成id_rsa
文件和id_rsa.pub
文件,前者是私钥,需要妥善保管防止泄露,后者是公钥,需要保存到服务器上。可以通过执行以下命令来自动将公钥上传至服务器:
ssh-copy-id <服务器用户名>@<服务器IP>
当然如果你的电脑上没有ssh-copy-id
命令,可以手动将本地的~/.ssh/id_rsa.pub
文件中的内容全部追加到到服务器中的~/.ssh/authorized_keys
文件后面(记得要换行哦,一行是一个不佟的ssh密钥)。
可以使用vim命令去编辑该文件,如果vim不会的话(建议去学一学,很实用,记住常用的命令即可)
可以在本地执行一下命令
scp ~/.ssh/id_rsa.pub <服务器用户名>@<服务器IP>:~/
然后在服务器上执行以下命令:
cat ~/id_rsa.pub >> ~/.ssh/authorized_keys
rm ~/id_rsa.pub
ssh尝试连接服务器时,会自动匹配~/.ssh/authorized_keys
中的公钥和你的私钥,如果成功配对,则不需要输入密码就可以连接到服务器了。
如果不行的话可以往下翻阅,下面有写连接失败的原因
在服务器上编辑/etc/ssh/sshd_config
文件,,找到#GatewayPorts no
改为yes
并去掉注释。
重启sshd服务
sudo systemctl restart sshd
ssh -NfR <服务器IP>:<服务器Port>:<本地IP>:<本地Port> <服务器用户名>@<服务器IP>
其中:
localhost
-R
**表示远程端口转发-N
**表示不执行命令,只进行端口转发-f
**表示将ssh放到后台执行事实上当我们准备好所有东西后,本地电脑开机的时候我们只需要执行上述这一条命令就可以实现端口转发了,你就可以在任何有互联网的地方远程连接电脑啦!
但是ssh的连接是非常不稳定的,那么如何来解决这个问题呢。
这里我尝试了好几种方法,但是很多都不太成功,就在这里写下来,供大家参考,顺便看看能不能找出问题,一劳永逸的解决吧
该方法比较简单,但是不算很有效
大概方法如下
接下来我们启动该任务就可以啦
但是,即使是这样也还是会断联,但是目前没找出是什么原因,而且wifi有时候也会断连,校园网也可能会有时把我的账号给登出去,所以emm我继续寻找其他办法。
一些参考文章:
在这一篇可以下载到autossh的windows版本很方便,不用安装任何程序
Windows下使用AutoSSH,并作为服务自启动(不用安装Cygwin) - h46incon - 博客园 (cnblogs.com)
这一篇是命令的解释参考
利用AutoSSH建立SSH隧道,实现内网穿透 - 知乎 (zhihu.com)
(补充):
后面发现上面的那篇免cygwin安装的方法无法正常执行autossh
就是虽然命令不会报错,但是并不能连通,最后只能无奈下载cygwin
这里放上下载cygwin的文章,cygwin下载还是很方便的,主要就是下载各种插件,如果漏装了就重新运行安装程序,补充包就可以了
How to create SSH tunnel on Windows by using AutoSSH | Free Online Tutorials (tutorialspots.com)
或者中文版的文章(内容基本一致,ssh相关的插件的话其实用autossh就够了)
(153条消息) 如何在 Windows 上安装 Autossh服务_autossh windows_快乐小胡!的博客-CSDN博客
注意事项:这里呢他们两个的文章都有些地方写的不是很详细
这里补充一些
cygrunsrv: Error installing a service
的错误,可能是没有以管理员权限运行。如果你的电脑是Linux操作系统,那么使用autossh就很简单了
首先是在自己的本地电脑上执行命令安装Autossh
yum install autossh
然后建立SSH隧道,只需要一条代码,非常的简单
autossh -M 4010 -NR 1000:localhost:2000 [email protected] (-p xxxx)
cygrunsrv -I AutoSSH -p /bin/autossh -a "-M 20000 -fNR 1000:localhost:2000 root@服务器ip" -e AUTOSSH_NTSERVICE=yes
参数解释:
代码解释:
这种情况有很多,网上也有很多教程
这里列举一些比较好的
(150条消息) 【Linux】ssh设置了密钥,但ssh登陆的时候还需要输入密码_zclinux_的博客-CSDN博客_sftp密钥登陆后还需要密码
我当时总是输入密码错误,后面不记得调了什么就又可以了,应该是开了那个PermitRootLogin yes
在我的文件里面默认这个是被注释掉了
还有这个RSAAuthentication yes
我找不到,其他基本都是正确的。
或者ssh密钥已经设置好了的时候还是要密码,要去确认一下authorized_key文件到底有没有写错,记得要分行,一个ssh公钥是一行(画面显示的时候可能会因为屏幕不够长换成多行)
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password
如果是提示这个的时候呢,其实可能就真的是公钥出问题啦,记得要去看一下,当然也可以上网搜其他方法
比如可能用户名弄错了,密码一般是我们登录微软账号的那个,不要输pin的。
可以把那个”仅限网络身份级别连接的勾选“给去掉尝试一下。
ip地址也要注意不要写错,比如我们的校园网的ip地址每天都会变的。(如果做了内网穿透就不会变)
如果有用宝塔页面,则记得也要去宝塔那里开启3389的端口,否则也是无法远程连接的