Mosh的功能
它是一个支持漫游的远程终端程序。
在所有主流的类 Unix 版本中可用,如 Linux、FreeBSD、Solaris、Mac OS X 和 Android。
支持不稳定连接
支持智能的本地回显
支持用户输入的行编辑
响应式设计及在 wifi、3G、长距离连接下的鲁棒性
在 IP 改变后保持连接。它使用 UDP 代替 TCP(在 SSH 中使用),当连接被重置或者获得新的 IP 后 TCP 会超时,但是 UDP 仍然保持连接。
在很长的时候之后恢复会话时仍然保持连接。
没有网络延迟。立即显示用户输入和删除而没有延迟
像 SSH 那样支持一些旧的方式登录。
包丢失处理机制
Linux 中 mosh 的安装
在 Debian、Ubuntu 和 Mint 类似的系统中,你可以很容易地用 apt-get 包管理器安装。
复制代码代码如下:
# apt-get update
# apt-get install mosh
在基于 RHEL/CentOS/Fedora 的系统中,要使用 yum 包管理器安装 mosh,你需要打开第三方的 EPEL。
复制代码代码如下:
# yum update
# yum install mosh
在 Fedora 22+的版本中,你需要使用 dnf 包管理器来安装 mosh。
复制代码代码如下:
# dnf install mosh
我该如何使用 mosh?
1、 让我们尝试使用 mosh 登录远程 Linux 服务器。
复制代码代码如下:$ mosh root@192.168.0.150
注意:你有没有看到一个连接错误,因为我在 CentOS 7中还有打开这个端口。一个快速但是我并不建议的解决方法是:
复制代码代码如下:
# systemctl stop firewalld [在远程服务器上]
2、 让我们假设把默认的 22 端口改到 70,这时使用 -p 选项来使用自定义端口。
复制代码代码如下:
$ mosh -p 70 root@192.168.0.150
3、 检查 mosh 的版本
复制代码代码如下:
$ mosh --version
4、 你可以输入exit来退出 mosh 会话。
复制代码代码如下:
$ exit
5、 mosh 支持很多选项,你可以用下面的方法看到:
复制代码代码如下:
$ mosh --help
mosh 的优缺点
mosh 有额外的需求,比如需要允许 UDP 直接连接,这在 SSH 不需要。
动态分配的端口范围是 60000-61000。第一个打开的端口是分配好的。每个连接都需要一个端口。
默认的端口分配是一个严重的安全问题,尤其是在生产环境中。
支持 IPv6 连接,但是不支持 IPv6 漫游。
不支持回滚
不支持 X11 转发
不支持 ssh-agent 转发
总结
mosh是一款在大多数linux发行版的仓库中可以下载的一款小工具。虽然它有一些差异尤其是安全问题和额外的需求,它的功能,比如漫游后保持连接是一个加分点。我的建议是任何一个使用ssh的linux用户都应该试试这个程序,mosh值得一试。