IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux基础课 第四章、SSH -> 正文阅读

[系统运维]Linux基础课 第四章、SSH

1 SSH基本知识

1.1 SSH是什么

SSH为Secure Shell的缩写,是一种网络协议,用于加密两台计算机之间的通信,保证不被窃听或篡改,并且支持各种身份验证机制。在事务中,它主要用户保证远程登录贺远程通信的安全,任何网络服务都可以用这个协议来加密。

1.2 SSH架构

SSH的软件架构是C/S模式,即客户端-服务器模式。 在这个架构中,SSH软件分成了两个部分:向服务器发出请求的部分,称为客户端,OpenSSH的实现为ssh;接受客户端发出的请求的部分,称为服务器,OpenSSH的实现为sshd。
其中大写的SSH表示协议,小写的ssh表示客户端软件。
OpenSSH的客户端是二进制程序ssh。它在Linux/Unix系统的位置是/usr/local/bin/ssh,windows系统的位置是/Program Files/OpenSSH/bin/ssh.exe。Linux系统一般都自带ssh,如果没有则需要自己安装。安装命令如下:

# Ubuntu 和 Debian
sudo apt install openssh-client
# CentOS 和 Fedora
sudo dnf install openssh-clients

2 ssh登录

2.1 基本用法

远程登录服务器有以下几种方式:

ssh hostname # 没有指定用户名,将使用客户端的当前用户名
ssh user@hostname # 指定用户名
ssh user@hostname -p 22 # 登录端口为22,使用-p可以登录到某一特定的端口。

其中user为用户名,hostname为IP地址或域名
第一次登录时会提示:

The authenticity of host '123.57.47.211 (123.57.47.211)' can't be established.
ECDSA key fingerprint is SHA256:iy237yysfCe013/l+kpDGfEG9xxHxm0dnxnAbJTPpG8.
Are you sure you want to continue connecting (yes/no/[fingerprint])?

上述这段文字告诉用户,这台服务器的指纹是陌生的,让用户选择是否要继续连接(输入yes或no)。
所谓“服务器指纹”,指的是 SSH 服务器公钥的哈希值。每台 SSH 服务器都有唯一一对密钥,用于跟客户端通信,其中公钥的哈希值就可以用来识别服务器。

输入yes,然后回车即可。这样会将服务器的信息记录在~/.ssh//known_hosts文件中,然后输入密码即可登录到远程服务器。
~/.ssh/known_hosts文件中保存了本机连接过的所有服务器的公钥指纹信息,每次通过ssh连接一台服务器,系统会通过该文件判断当前需要连接的服务器是否为陌生主机。而如果之前ssh登陆过的服务器的密钥发生了更改,那么登录就会收到提示Host key verification failed,由于发生改变了,所以西我们需要删除之前的主机的指纹信息,添加新的。这个可以使用ssh-keygen -R <hostname>来进行删除。

如果我们需要退出登录,输入logoutexit都可以实现,也可以使用快捷键Ctrl+d退出。

2.2 配置文件

创建文件~/.ssh/config,此为用户的个人配置文件,其保存相关配置信息。我们可以在文件中输入:

Host myServer1
	HostName IP地址或域名
	User 用户名
Host myServer2
	HostName IP地址或域名
	User 用户名

之后再使用服务器时,就可以直接使用别名myServer1myServer2进行登录。
在这里插入图片描述
SSH客户端的全局配置文件为/etc/ssh/ssh_config,其优先级低于用户个人配置文件。除了配置文件,~/.ssh还有一些用户个人的密钥文件和其他文件

2.3 密钥登录

  • 创建密钥
    首先在本台主机上创建密钥,输入ssh-keygen指令,然后一直回车即可。该命令会为本机生成公私钥对,通过密钥来进行远程登录的验证机制使用了密码学中的非对称加密体系。执行命令后,会在~/.ssh/文件夹下生成两个新的文件:

    1. id_rsa:私钥
    2. id_rsa.pub:公钥

    注意,一定要保护好生成的私钥id_rsa,一旦暴露,利用上述指令可以重新生成新的密钥。
    在这里插入图片描述

  • 免密登录
    如果想要免密登录某个服务器,我们只需要将刚才生成的公钥保存在需要登录的远程服务器~/.ssh/authorized_keys文件中。例如我想免密登录到myServer1服务器,则将~/.ssh/id_rsa.pub公钥中的内容,复制到myServer1中的~/.ssh/authorized_keys文件中。也可以使用如下命令一键添加公钥:
    ssh-copy-id myServer1
    第一次应用ssh-copy-id系统会提示输入远程服务器的密码,之后登录时就可以免密登录了。
    在这里插入图片描述

一般来说,应用密钥登录比使用密码登录更加安全,所以启用密钥登录之后,最好关闭服务器的密码登录。如果需要在远程服务器上关闭密码登录。具体方法是先远程登录到服务器中,然后找到sshd的配置文件/etc/ssh/sshd_config,最后将PasswordAuthentication这一项设置为no
PasswordAuthentication no
sshd是服务器运行的后台进程,当我们修改配置文件以后,需要重新启动sshd,然后修改才能生效。可应用下面语句重启远程服务器上的sshsshd服务。

sudo systemctl restart ssh.service
sudo systemctl restart sshd.service
  • 执行远程命令
    免密登录后,我们可以在命令行下直接执行远程命令:ssh user@hostname command。这样的命令会使SSH在登录成功后,立刻在远程主机上执行命令comand。但并不是真正的登录,执行完命令后还在原主机。
    测试:ssh myServer1 ls
    在这里插入图片描述

3 scp传文件

3.1 scp命令简介

scp是secure copy的缩写,相当于cp命令+SSH。它的底层是SSH协议,默认端口是22,相当于先使用ssh命令登录远程主机,然后再进行拷贝操作。
scp主要用于以下三种复制操作:

  • 本地复制到远程。
  • 远程复制到本地。
  • 两个远程系统之间的复制。

使用scp传输数据时,文件和密码都是加密的,不会泄露敏感信息。

基本语法

scp的语法类似cp的语法。

scp source destination

上面命令中,source是文件当前的位置,destination是文件所要复制到的位置。它们都可以包含用户名和主机名。例如:

scp myServer1:main.cpp main.cpp

上面命令即是将远程主机(myServer1)用户主目录下的main.cpp复制为本机当前目录下的main.cpp。注意主机与文件之间要使用:分隔。
scp会先用SSH登录到远程主机,然后在加密连接之中复制文件。客户端发起连接后,会提示用户输入密码。其中用户名和主机名若省略则是代表当前主机下的当前用户名。

scp支持一次复制多个文件。scp source1 source2 destination。如果存在同名文件,scp会在没有警告的情况下覆盖同名文件。

4 参考文献

Linux基础课
菜鸟教程

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-01-24 11:21:19  更:2022-01-24 11:22:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:47:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码