13.4 SSH 配置和相关工具

SSH 即 Secure Shell,安全 shell,顾名思义是一种安全地使用 shell 的方式。一般用作远程使用。

SSH 工具

FreeBSD 自带 ssh,可以接入其他安装了 ssh 的设备,用法:

$ ssh 用户名@IP:端口

如:

$ ssh [email protected]:1022

技巧

ssh FreeBSD 的话,接入的是哪个 tty?

$ tty
/dev/pts/1 # 即 pseudo-terminal,伪终端

WinSCP

scp 即 Secure Copy,安全复制,顾名思义是一种安全地使用 cp 命令的方式。一般用作远程使用,在不同设备间传输文件。

WinSCP 是对 scp 命令的图形化封装的软件,并同时支持 FTP 等多种协议。可以快捷的传输文件与 Windows 系统和 Linux 或 BSD 之间。

下载地址:

https://winscp.net/eng/download.php

自 OpenSSH 9.0 起,scp 命令默认使用 SFTP 协议进行文件传输。WinSCP 默认即是 SFTP

但是,这个版本号和远程被控的操作系统相关。FreeBSD 查看内置的 OpenSSH 版本:

上面的输出,OpenSSH 的主要版本号为 9.7,用户无需任何修改即可使用 WinSCP。

Xshell

Xshell 是 Windows 平台上的强大的 shell 工具。支持 串口、SSH、Telnet!

Xshell 下载地址(输入用户名和邮件即可):

https://www.netsarang.com/zh/free-for-home-school

如果提示需要重新验证,请打开上面的网站重装一遍,即可。

MobaXterm

MobaXterm 是一款集成了 SCP 功能的软件。

MobaXterm 目前不支持中文,下载地址 https://mobaxterm.mobatek.net/download-home-edition.html,左右任选。

MobaXterm
MobaXterm

在选择鼠标后,操作行为和 Xshell 一致。

PuTTY

下载地址:https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html

PuTTY 界面以反人类著称,不支持 i18n(中文版注入木马等),自身安全性也没有保障(CVE-2024-31497)一般被集成到其他软件间接使用。

Termius

Termius

Termius 下载地址:https://termius.com/download/

目前不支持中文,使用需要登录和注册。

Termius 鼠标行为和 PuTTY 接近,一样的反人类(无论选择快捷键还是鼠标)。右键出不来 Xshell 那种行为。

配置 SSH

允许 root 使用 ssh

技巧

视频教程见 004-FreBSD14.2 允许 root 登录 ssh

编辑“/etc/ssh/sshd_config”(删去前边的 #,并将 yes 或 no 修改为如下):

技巧

如果你实在是找不到 #PasswordAuthentication no 这行,请你看看你改的究竟是 /etc/ssh/sshd_config 还是 /etc/ssh/ssh_config。sshd 才是我们真正要改的文件。

开启 SSH 服务

如果提示找不到 sshd,请执行下一命令:

然后再

SSH 密钥登录

生成密钥

OpenSSH 7.0 及以上版本默认禁用了 ssh-dss(DSA) 公钥算法。FreeBSD 13.0 采用 OpenSSH_7.9。因此使用默认值即可。

配置密钥

检查权限(默认创建的权限如下):

生成验证公钥:

使用 winscp 把私钥和公钥保存到本地后,删除服务器上的多余文件:

修改 /etc/ssh/sshd_config

逐个找到(分散于 sshd_config,并按需修改配置如下(删去前边的 #,并将 yesno 的状态修改为如下):

重启服务

使用 xshell 登录即可,输入密钥密码,导入私钥 id_rsa,即可登录。

如果使用其他 ssh 软件无法登录请自行转换密钥格式。

保持 SSH 不断线

传统的 screen

screen 即英文“屏幕”的意思,即提供一块虚拟屏幕给你用。

安装:

或者:

使用方法:

使用 -S 可以指定 xxx 为名字,方便找到。

然后就可以进行 ssh 连接了,后续可以关闭这个窗口或软件,不影响 ssh。

查看有哪些正在运行的 screen?

Detached 的可以直接 -r 恢复。

Attached 的必须先离线再恢复:

mosh:移动的 shell

moshmobile shell,移动的 shell。

个人认为,mosh 真的只适合在户外用手机、平板通过流量远程控制服务器使用。

Mosh 不支持多窗口、分屏模式、多个客户端连接到同一服务器。Mosh 也不支持在客户端重启(或用户切换到不同机器)时重新连接。要实现上述功能,用户通常须在 Mosh 会话中使用 GNU screen、OpenBSD tmux 等终端多路复用器。——Mosh: A State-of-the-Art Good Old-Fashioned Mobile Shell

要使用 mosh:① 服务端和客户端都需要配置相同的 UTF-8 编码,② 双方都需要安装 mosh。

或者:

编辑 ~/.login_conf,加入:

  • 默认的系统:

  • 已中文化的系统:

你的客户端也需要同样的设置,因为是移动的 shell,所以我们使用安卓上的 JuiceSSH 进行测试。

下载地址:https://play.google.com/store/apps/details?id=com.sonelli.juicessh

juicessh

点击“服务端命令”,设置如下:

其他不用变:用户名、密码和 ssh 的相同。亦需要端口 22 进行验证。

FreeBSD 开放端口:

根据上述输出,可以看到,我主机的端口是 60001。而你需要放通 60000-61000

测试连接:

juicessh 的 mosh
juicessh 的 mosh
juicessh 的 mosh

断开测试:

juicessh 的 mosh 断开 WiFi
juicessh 的 mosh 再次恢复连接 WiFi

可以看到,在断开后有提示,重连网络后自动恢复,像是没有断开一样(已结合 screen 使用)。

参考文献

最后更新于

这有帮助吗?