使用SSH进行Linux远程管理

SSH是一个用于安全远程登录和执行命令的协议,它的加密技术能够保护数据传输的安全,让用户在进行远程管理时更加放心。本文将从多个方面对使用SSH进行Linux远程管理进行详细阐述。

一、SSH的基本操作

1、连接远程服务器

ssh [用户名]@[IP地址或域名]

输入以上命令后,需要输入账户密码才可登录。如果已经在本地生成了公私钥对并将公钥上传至服务器,也可以通过以下方式登录:

ssh -i [私钥路径] [用户名]@[IP地址或域名]

2、执行命令

ssh [用户名]@[IP地址或域名] [命令]

输入以上命令后,会远程执行相应的命令。如果需要以非交互方式执行,可以加上”-n”参数。

ssh -n [用户名]@[IP地址或域名] [命令]

3、SCP文件传输

SCP是一种基于SSH协议的文件传输工具,可以将本地文件复制到远程服务器,也可以将远程服务器上的文件复制到本地。

将本地文件传输到远程服务器:

scp [本地文件路径] [用户名]@[IP地址或域名]:[远程目录路径]

将远程服务器上的文件传输到本地:

scp [用户名]@[IP地址或域名]:[远程文件路径] [本地目录路径]

二、SSH的配置和使用技巧

1、配置公钥免密登录

为了避免每次登录都需要输入密码,可以将本地公钥上传至服务器,实现免密登录。

先在本地生成公私钥对:

ssh-keygen -t rsa

将生成的公钥~/.ssh/id_rsa.pub上传至服务器的~/.ssh/authorized_keys文件中:

ssh-copy-id [用户名]@[IP地址或域名]

2、配置SSH别名

在本地的~/.ssh/config文件中添加别名:

Host [别名]
    Hostname [IP地址或域名]
    User [用户名]
    Port [端口号]

这样在登录时就可以使用别名,而不需要输入完整的服务器信息。

ssh [别名]

3、使用SSH-Agent

SSH-Agent可以避免每次SSH操作都需要输入密码,提高SSH的使用效率。

首先在本地启动SSH-Agent:

eval $(ssh-agent)

然后将私钥添加至SSH-Agent的密钥列表中:

ssh-add [私钥路径]

三、SSH的安全设置

1、更改SSH默认端口

SSH默认端口为22,容易成为恶意攻击的目标。可以将SSH端口更改为非默认端口,提高安全性。

在服务器的/etc/ssh/sshd_config文件中更改Port字段,并重启SSH服务:

Port [新端口号]
systemctl restart sshd.service

2、禁用SSH root用户登录

为了避免黑客攻击,应该禁止SSH root用户登录,通过管理普通用户权限来执行相应任务。

在服务器的/etc/ssh/sshd_config文件中更改PermitRootLogin字段为no,并重启SSH服务:

PermitRootLogin no
systemctl restart sshd.service

3、限制SSH远程登录IP地址范围

为了限制SSH远程登录的IP地址范围,可以通过/etc/hosts.allow和/etc/hosts.deny文件进行设置。

在/etc/hosts.allow文件中添加允许登录的IP地址:

sshd: [允许登录的IP地址范围]

在/etc/hosts.deny文件中添加拒绝登录的IP地址:

sshd: ALL

四、SSH的高级应用

1、在SSH中使用端口转发

通过SSH在本地主机和远程主机之间建立的隧道,可以在传输数据的同时进行端口转发。

将远程服务器的80端口转发至本地的8080端口:

ssh -L 8080:localhost:80 [用户名]@[IP地址或域名]

2、通过SSH连接Grafana

Grafana是一个开源的数据可视化平台,可以将监控指标以图表的形式进行展示。可以通过SSH连接服务器,并启动Grafana服务,然后在本地浏览器中直接访问Grafana的Web界面。

在服务器中启动Grafana:

systemctl start grafana-server

然后在本地终端中启动SSH并进行端口转发:

ssh -L 3000:localhost:3000 [用户名]@[IP地址或域名]

接着在本地浏览器中访问http://localhost:3000即可。

总结

SSH作为一种安全远程登录和执行命令的协议,具有非常广泛的应用场景。本文介绍了SSH的基本操作、配置和使用技巧、安全设置以及高级应用,希望对大家了解和使用SSH有所帮助。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/297427.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-28 12:15
下一篇 2024-12-28 12:15

相关推荐

  • Python SSH 远程执行命令

    Python SSH 远程执行命令是指在一个服务器上执行远程另一个服务器上命令。如果你需要在本地机器上执行命令,或者在远程机器上执行本地命令,你都可以使用 SSH。在 Python…

    编程 2025-04-29
  • 如何在Linux中添加用户并修改配置文件

    本文将从多个方面详细介绍在Linux系统下如何添加新用户并修改配置文件 一、添加新用户 在Linux系统下创建新用户非常简单,只需使用adduser命令即可。使用以下命令添加新用户…

    编程 2025-04-27
  • 如何解决linux jar包 invalid or corrupt jarfile问题

    对于许多开发人员和系统管理员在Linux环境下使用Java开发过程中遇到的一个常见的问题是 invalid or corrupt jarfile(无效或损坏的jar文件)错误。当您…

    编程 2025-04-27
  • 在Linux上安装JRE并配置环境变量

    本文将从以下几个方面为您详细阐述如何在Linux系统上,通过自己账户安装JRE,并且配置环境变量。 一、安装JRE 在进行安装前,我们需要下载JRE的安装包并解压,可以从官方网站下…

    编程 2025-04-27
  • GTKAM:Linux下的照片管理器

    GTKAM是用于Linux操作系统的一款照片管理器,它支持多种相机及存储设备,并提供了一系列强大的工具,让用户可以方便地浏览、管理、编辑和导出照片。本文将从多个方面对GTKAM进行…

    编程 2025-04-27
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • CentOS 开启 SSH

    一、安装 SSH SSH 是 Secure Shell 的缩写,是一种安全协议。在 CentOS 系统中,可以通过以下命令安装 SSH: sudo yum install open…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • 如何在Windows/Linux/MacOS下安装Python

    如果你对Python安装一无所知,本文将从多个方面对Python在Windows/Linux/MacOS下的安装做出详细阐述,为初学者提供帮助。 一、Windows下Python的…

    编程 2025-04-25
  • Linux网络连接激活失败原因及解决方法

    一、网卡驱动问题 1、缺少网卡驱动 若使用新的网卡,需要安装对应网卡驱动,否则会导致网络连接激活失败。可通过以下命令查看当前系统中是否存在网卡驱动: lsmod | grep et…

    编程 2025-04-25

发表回复

登录后才能评论