Linux进阶笔记-Secure Shell (SSH)远程连接协议
ahcoder 2024-12-13 20:39 12 浏览
Secure Shell用于通过加密连接从客户端远程访问服务器。OpenSSH作为Telnet连接的加密安全连接替代方案,可以实现远程访问shell终端。大多数GNU/Linux发行版默认都安装了OpenSSH客户端,用于连接服务器。
这些例子展示了如何使用SSH套件接受SSH连接并连接到另一台主机。
1: 连接到远程服务器
To connect to a server we must use SSH on the client as follows,
要连接到服务器,我们必须在拥有SSH客户端的机器上使用ssh命令来进行远程连接,ssh的使用格式如下所示:
# ssh [-p port] [user]@<server-address>
- port - SSH服务端监听的端口 (默认为 22)。如果连接的是默认的22端口,-p port通常可以省略
- user - 必须是远程连接过去的服务器上存在的用户。如果你本地机器的用户名和远程的用户名一致,也可以省略@前面的用户名和@符号。
- server-address - 远程服务器的IP、域名,如果本地有做IP和主机名的映射,也可以用主机名。
下面是一个连接到服务器的例子
[sean@MacBook-Pro ~]$ ssh -p 22 demouser@192.168.10.144
demouser@192.168.10.144's password:
Welcome to Ubuntu 24.04.1 LTS (GNU/Linux 6.8.0-48-generic x86_64)
* Documentation: https://help.ubuntu.com
* Management: https://landscape.canonical.com
* Support: https://ubuntu.com/pro
扩展安全维护(ESM)Applications 未启用。
0 更新可以立即应用。
启用 ESM Apps 来获取未来的额外安全更新
请参见 https://ubuntu.com/esm 或者运行: sudo pro status
Last login: Tue Nov 5 10:26:20 2024 from 192.168.10.174
举一个可能存在于生产环境的例子,假设你正在制作一个网站。您选择托管站点的公司告诉您,服务器位于web- server.com,自定义端口60022,并且已选择您的帐户名称usr1来在服务器上创建具有SSH权限的用户。在这种情况下,使用的SSH命令将是这样的
# ssh -p 60022 usr1@web-servers.com
如果远程系统上的帐户名与本地客户端相同,可以省略该用户名。所以如果你在两个系统上都是usr1,那么你只需使用web- server.com而不是usr1@web-servers.com。
当您想要连接的服务器不能直接访问时,您可以尝试使用ProxyJump的选项,通过您可以访问的另一个服务器连接到它,该服务器可以连接到所需的服务器。
# ssh -J usr1@10.0.0.1:60022 usr2@10.0.0.2 -p 2222
这将允许您通过服务器10.0.0.1(在端口60022上运行ssh)连接到服务器10.0.0.2(在端口2222上运行ssh)。当然,你需要在两个服务器上都有账户。OpenSSH 7.3版本中引入了-J 选项。
2: 安装OpenSSH服务组件
远程接受SSH连接的服务器和发起SSH连接的客户端都需要安装openssh
Debian:
# apt install -y openssh-server
Arch Linux:
# pacman -S openssh
Yum:
# yum install openssh
3: 配置 SSH 服务器以接受连接
首先我们必须编辑SSH守护进程的配置文件。尽管在不同的Linux发行版中,它可能位于不同的目录中,但通常存储在/etc/ssh/sshd_config下
使用文本编辑器修改这个文件中设置的值,所有以#开头的行都被注释掉,必须删除这个字符才能生效。下面是一些建议。
Port (chose a number between 0 - 65535, normaly greater than four digits)
PasswordAuthentication yes
AllowUsers user1 user2 ...etc
请注意,最好禁用密码登录,并使用SSH密钥来提高安全性,如本文档所述。
4: 无密码连接(使用密钥对)
首先,你需要一个密钥对。如果你还没有,看看下一节的 生成公钥和私钥
你的密钥对由一个私钥(id_rsa)和一个公钥(id_rsa.pub)组成。你要做的就是将公钥复制到远程主机,并将其内容添加到~/。ssh / authorized_keys文件中。
一个简单的方法是:
ssh <user>@<ssh-server> 'cat >> ~/.ssh/authorized_keys' < id_rsa.pub
一旦公钥被正确地放在用户的主目录中,你只需要使用相应的私钥登录:
ssh <user>@<ssh-server> -i id_rsa
5: 生成公钥和私钥
为SSH客户端生成密钥:
ssh-keygen [-t rsa | rsa1 | dsa ] [-C <comment>] [-b bits]
例如:
ssh-keygen -t rsa -b 4096 - C myemail@email.com
默认情况下私钥是~/.ssh /id_rsa 而公钥是 ~/. ssh /id_rsa.pub
6: 关闭ssh服务
如果你确定有这样的需求,你可以关闭SSH服务器的服务,这样做的话,客户端将无法通过SSH连接从远程连接到服务器。
Ubuntu
sudo service ssh stop
sudo systemctl disable sshd.service
Debian
sudo /etc/init.d/ssh stop
sudo systemctl disable sshd.service
Arch Linux
sudo killall sshd
sudo systemctl disable sshd.service
相关推荐
- KaOS 2025.05版本发布:全面拥抱Qt6,彻底告别Qt5
-
KaOSLinux2025.05版本重磅发布:全面拥抱Qt6,开启KDE生态新篇章继2025.03版本发布两个月后,专注于KDE桌面环境、采用XFS文件系统的滚动发行版Li...
- 基于FIMC接口的CMOS摄像头驱动分析与设计
-
摘要:目前的嵌入式系统中,USB摄像头使用比较普遍,但其应用会受到传输速度的限制。本文采用一款高速CMOS摄像头,其驱动利用S3C6410内置的FIMC接口技术,采用DMA和ping-pong缓冲...
- 没错是微软 推出基于Linux的交换机系统
-
2015-09-2205:59:59作者:郑伟你没看错,为了提升自身Azure云数据中心内网络设备的兼容性及开放性,微软也开始推出基于Linux的网络交换机系统了。这个被称为AzureCloud...
- Linus Torvalds 宣布首个 Linux 内核 6.16 候选版本
-
Linux内核负责人兼创始人LinusTorvalds宣布关闭合并窗口,该窗口用于将主要新功能添加到内核中,并开始发布Linux6.16候选版本,从候选版本1(Linux6.16-r...
- Linux内核漏洞将影响Haswell架构服务器
-
在infoq网站上,GilTene最近报告一个十分重要,但并不为人知Linux内核补丁,特别对采用Haswell架构的Linux系统用户和管理员应该特别关注。报告提醒RedHat发行版的用户(包括...
- 关于Linux性能调优中网络I/O的一些笔记
-
写在前面和小伙伴分享一些Linux网络优化的笔记,内容很浅,可以用作入门博文内容结合《Linux性能优化》读书笔记整理涉及内容包括常用的优化工具(mii-tool,ethtool,ifconfig,i...
- 国产操作系统- Veket Linux(国产操作系统之光银河麒麟阅读理解)
-
VeketLinux是一个随身的可装在U盘的Linux操作系统。主要面向桌面用户。它的设计重点是提供简单易用且稳定的操作系统,同时保持更新和开发。它具有强大的功能集和广泛的用户基础,可满足...
- AlmaLinux 9.6发布:升级工具、初步支持IBM Power虚拟化技术
-
IT之家5月21日消息,科技媒体linuxiac昨日(5月20日)发布博文,报道称代号为SageMargay的AlmaLinux9.6发行版已上线,距上一版本9.5发...
- 跟老韩学Linux运维架构师系列,vim与view的基本使用
-
下面是vim和view的10个实例:用vim打开一个新文件:vimnewfile.txt这个命令将会在vim编辑器中打开一个新文件。在vim中移动光标:使用方向键或h、j、k、l键来移动光标。在v...
- malloc底层原理剖析——ptmalloc内存池
-
malloc底层为什么是内存池malloc大家都用过,其是库函数。我们都知道库函数在不同的操作系统中其实执行的是系统调用,那么malloc在Linux上执行的是哪个系统调用呢?brk()和mmap()...
- Zen 6架构首秀Linux,AMD加速下一代处理器布局
-
IT之家5月15日消息,科技媒体Phoronix昨日(5月14日)发布博文,报道称AMD已经开始为下一代“Zen6”处理器做准备,已为该构架向Linux内核提交了首个补丁,...
- 为何越来越多企业转向安卓/Linux工业平板电脑?答案在这里
-
在工业领域,设备的稳定性至关重要,尤其是工业平板电脑,常年运行在高温、粉尘、潮湿等复杂环境下,一旦系统崩溃或者卡顿,可能会影响整个生产流程。那么,为什么越来越多的企业选择安卓/Linux工业平板电脑,...
- 从3ms到0.8ms:ARM+Linux如何重塑工业控制实时性标杆
-
在智能制造领域,产线控制系统对实时性的要求越来越高。根据行业调研数据,超过65%的工业现场出现过因系统响应延迟导致的故障停机,平均每次停机造成的直接损失高达2-8万元。传统x86架构搭配Windows...
- 看Linux如何"挖坑种树"
-
写在前面,有人看我的Linux文章说技术难度不深,笔者不是不想写深,笔者是觉得Linux难就难在入门,入门之后你就知道如何上网查询你所要要解决的Linux需求。如果你已入门,此文已对你无用,请略过此...
- AlmaLinux 9.6 发布,新增功能亮点纷呈!
-
距离上一版本AlmaLinux9.5发布六个月后,基于5.14内核的AlmaLinux正式宣布其企业级Linux发行版的9.x系列第六个更新——AlmaLinux9.6(Sag...
- 一周热门
- 最近发表
-
- KaOS 2025.05版本发布:全面拥抱Qt6,彻底告别Qt5
- 基于FIMC接口的CMOS摄像头驱动分析与设计
- 没错是微软 推出基于Linux的交换机系统
- Linus Torvalds 宣布首个 Linux 内核 6.16 候选版本
- Linux内核漏洞将影响Haswell架构服务器
- 关于Linux性能调优中网络I/O的一些笔记
- 国产操作系统- Veket Linux(国产操作系统之光银河麒麟阅读理解)
- AlmaLinux 9.6发布:升级工具、初步支持IBM Power虚拟化技术
- 跟老韩学Linux运维架构师系列,vim与view的基本使用
- malloc底层原理剖析——ptmalloc内存池
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux ip地址 (34)
- linux 用户查看 (33)