[笔记]mosh使用笔记
听说mosh好使,那么怎么在Mac本下使用mosh来登录Ubuntu及AWS服务器呢?
mosh介绍
mosh官网在:https://mosh.org/
代码开源在:https://github.com/mobile-shell/mosh
卖点就是通过UDP传输,网络切换可以自动重连,不会导致执行中的命令断掉。
mosh安装
Ubuntu下安装mosh服务器:
$ sudo apt-get install mosh
Mac下安装mosh客户端:
$ brew install mosh
运行
Ubuntu下运行mosh-server
:
$ mosh-server
MOSH CONNECT 60001 y8btZAE3fjpmzQu7s/4XWg
mosh-server (mosh 1.3.2) [build mosh 1.3.2]
Copyright 2012 Keith Winstein <mosh-devel@mit.edu>
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
[mosh-server detached, pid = 7195]
看到mosh-server detached
不要慌,毕竟它也不监听端口。
假设服务器地址为123.123.123.123
,用户名是etworker
,则Mac下运行:
$ mosh etworker@123.123.123.123
如果一切顺利,连接起来就像ssh一样。
如果服务器ssh的端口是2222,则用下面的方式连接:
$ mosh --ssh="ssh -p 2222" etworker@123.123.123.123
注意
Mosh使用的UDP协议连接的,使用的端口是从60000到61000,如果开启了防火墙服务器上就需要打开相应的UDP端口。
一个Mosh连接就会打开一个UDP端口,比如建立两个连接就是60001、60002,以此类推。
假设Mosh使用60001 UDP端口,则在服务器上运行
$ iptables -I INPUT -p udp –dport 60001 -j ACCEPT
这样就在服务器上打开60001这个UDP端口。
当然,最好是把上一条命令写入服务器iptables的规则中,这样不必要每次都手动打开这个端口。
Amazon AWS
我在Amazon上的服务器是通过key文件做的鉴权,所以先说一下Mac怎么ssh上去。
先将密钥文件拷贝到Mac上,比方说文件名叫xxx.pem
,然后修改权限:
$ chmod 400 xxx.pem
假设服务器地址是111.111.111.111,进到xxx.pem
同目录下,ssh如下:
$ ssh -i xxx.pem ubuntu@111.111.111.111
此时在服务器上安装mosh,方式同上。
注意需要在安全组里面配置端口,开放6000-61000的UDP端口。
安全组的端口过滤方法,应该不需要再细说了吧。
接着就可以使用Mac来连接了:
$ mosh --ssh="/usr/bin/ssh -i xxx.pem" ubuntu@111.111.111.111
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!