시스템 관리자는 동시에 여러 서버를 관리할 수 있으며 이러한 서버는 서로 다른 위치에 배치될 수 있습니다. 물론 직접 일일이 관리하는 것이 최선의 방법은 아닙니다. 원격 제어 방법이 가장 효과적이어야 합니다.
Linux 시스템에는 telnet, ssh, vnc 등 여러 가지 원격 관리 도구가 있습니다. 그중 ssh는 가장 일반적으로 사용되는 관리 방법으로 암호문 전송을 사용하므로 간단하고 안전합니다.
Secure Shell
의 약자는 IETF의 Network Working Group(Network Working Group
)에서 제정한 SSH
입니다. 컴퓨터의 셸
에 안전한 전송 및 사용 환경을 제공하기 위해 애플리케이션 계층과 전송 계층을 기반으로 만들어진 보안 프로토콜입니다. Secure Shell
缩写是SSH
, 由IETF的网络工作小组(Network Working Group
)所制定,SSH
是一项创建在应用层和传输层基础上的安全协议,为计算机的shell
提供安全的传输和使用环境。
下面我们来介绍 SSH 的 7 大用法。
最简单的用法就是不带参数,仅输入 ssh 再加上主机地址,比如:
ssh 192.168.0.116
这种形式登陆主机,会默认使用当前用户进行登录。第一次连接的时候,SSH 会确认目标主机的真实性,如果没有问题的话,输入 yes 即可。
如果我们想要以指定用户名来登录主机,有两种方法:
a. 使用 -l 选项
ssh -l alvin 192.168.0.116
b. 使用 user@hostname 格式
ssh alvin@192.168.0.116
这两种方法,其中第二种尤为常用。
SSH 默认使用的端口号是 22。大多现代的 Linux 系统 22 端口都是开放的。如果你运行 ssh 程序而没有指定端口号,它直接就是通过 22 端口发送请求的。
如果我们不想通过 22 端口登录,那么我们可以使用 -p
选项来指定端口。
ssh 192.168.0.116 -p 1234
引申话题:如何修改端口号?
只需修改 /etc/ssh/ssh_config
,修改如下一行:
Port 22
使用 -C
选项,所有通过 SSH 发送或接收的数据将会被压缩,并且任然是加密的。
ssh -C 192.168.0.116
但是,这个选项在网速不是很快的时候比较有用,而当网速较快的时候,使用压缩反而会降低效率,所以要视情况使用。
因为某些原因,我们想要追踪调试我们建立的 SSH 连接情况。SSH 提供的 -v
选项参数正是为此而设的。其可以看到在哪个环节出了问题。
[Alvin.Alvin-computer] ➤ ssh -v pi@192.168.0.116 OpenSSH_7.1p2, OpenSSL 1.0.1g 7 Apr 2014 debug1: Reading configuration data /etc/ssh_config debug1: Connecting to 192.168.0.116 [192.168.0.116] port 22. debug1: Connection established. debug1: key_load_public: No such file or directory debug1: Enabling compatibility mode for protocol 2.0 debug1: Local version string SSH-2.0-OpenSSH_7.1 debug1: Remote protocol version 2.0, remote software version OpenSSH_7.4p1 Raspbian-10+deb9u4 debug1: match: OpenSSH_7.4p1 Raspbian-10+deb9u4 pat OpenSSH* compat 0x04000000 debug1: Authenticating to 192.168.0.116:22 as 'pi' debug1: SSH2_MSG_KEXINIT sent debug1: SSH2_MSG_KEXINIT received
如果你的客户端有多于两个以上的 IP 地址,你就不可能分得清楚在使用哪一个 IP 连接到 SSH 服务器。为了解决这种情况,我们可以使用 -b
选项来指定一个IP 地址。这个 IP 将会被使用做建立连接的源地址。
[Alvin.Alvin-computer] ➤ ssh -b 192.168.0.105 pi@192.168.0.116 Linux raspberrypi 4.14.71-v7+ #1145 SMP Fri Sep 21 15:38:35 BST 2018 armv7l The programs included with the Debian GNU/Linux system are free software; the exact distribution terms for each program are described in the individual files in /usr/share/doc/*/copyright. Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent permitted by applicable law. Last login: Sun Feb 24 08:52:29 2019 from 192.168.0.105
如果我们想在目标主机执行一条命令,我们通常的做法是,先登录到目标主机,执行命令,再退出来。这样做当然是可以,但是比较麻烦。
如果我们仅仅是想远程执行一条命令,可以直接在后面跟上命令就好,如下:
[Alvin.Alvin-computer] ➤ ssh pi@192.168.0.116 ls -l Desktop Documents Downloads MagPi Music
另外一个很赞的基于 SSH 的工具叫 sshfs
sshfs -o idmap=user user@hostname:/home/user ~/Remote
sshfs -o idmap=user pi@192.168.0.116:/home/pi ~/Pi
-p
옵션을 사용하여 포트를 지정할 수 있습니다. 🎜rrreee🎜확장된 주제: 포트 번호를 변경하는 방법은 무엇입니까? 🎜🎜/etc/ssh/ssh_config
를 수정하고 다음 줄을 수정하세요: 🎜rrreee-C
사용 옵션을 선택하면 SSH를 통해 보내거나 받는 모든 데이터가 압축되고 암호화됩니다. 🎜rrreee🎜 하지만 이 옵션은 인터넷 속도가 그다지 빠르지 않을 때 더 유용합니다. 인터넷 속도가 빠르지 않을 때 압축을 사용하면 효율성이 떨어지므로 상황에 맞게 사용하세요. 🎜-v
옵션 매개변수가 설계되었습니다. 문제가 발생한 위치를 확인할 수 있습니다. 🎜rrreee-b
옵션을 사용하여 IP 주소를 지정할 수 있습니다. 이 IP는 연결을 설정하기 위한 소스 주소로 사용됩니다. 🎜rrreee라는 또 다른 훌륭한 SSH 기반 도구 SSHFS
. sshfs를 사용하면 원격 호스트의 파일 시스템을 로컬로 직접 마운트할 수 있습니다. 사용 형식은 다음과 같습니다. 🎜rrreee🎜예: 🎜rrreee🎜🎜🎜🎜더 많은 Linux 기사를 보려면 🎜🎜Linux Tutorial🎜🎜🎜🎜 칼럼을 방문하여 알아보세요! 🎜🎜위 내용은 당신이 모르는 리눅스에서의 SSH 명령 사용법 7가지의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!