2、ubuntu系统配置OpenSSH | 使用vscode或pycharm远程连接

news2025/7/19 17:10:07

 1、OpenSSH介绍

OpenSSH(Open Secure Shell)是一套基于SSH协议的开源工具,用于在计算机网络中提供安全的加密通信。它被广泛用于远程系统管理、文件传输和网络服务的安全隧道搭建,是保护网络通信免受窃听和攻击的重要工具。

1.1、核心功能

安全远程登录

  • ssh 命令:通过加密通道登录远程主机(如 ssh user@hostname)。

  • 替代不安全的Telnet和rlogin,防止密码和会话内容被截获。

文件传输

  • scp:加密的跨系统文件拷贝(如 scp file.txt user@host:/path)。

  • sftp:交互式加密文件传输(类似FTP的安全版本)。

端口转发(隧道)

  • 本地转发:将本地端口流量通过SSH隧道转发到远程服务器。

  • 远程转发:将远程服务器端口流量转发回本地。

  • 动态转发:创建SOCKS代理,灵活转发多种流量。

密钥管理

  • 支持公钥认证(无需每次输入密码),通过 ssh-keygen 生成密钥对。

  • 密钥可存储在 ~/.ssh/authorized_keys 中实现免密登录。

服务端支持

  • sshd:OpenSSH的服务端守护进程,监听默认端口22。

  • 通过 /etc/ssh/sshd_config 配置文件调整安全策略(如禁用密码登录)。

1.2、安全特性

  • 强加密算法:使用AES、ChaCha20等加密数据,Diffie-Hellman密钥交换确保会话安全。

  • 协议版本:推荐SSH-2(修复SSH-1的漏洞),默认禁用旧版协议。

  • 防中间人攻击:首次连接时记录主机指纹,后续验证防止伪装。

  • 审计与日志:详细日志记录(/var/log/auth.log 等)便于追踪访问行为。

1.3、典型应用场景

远程服务器管理:运维人员通过SSH安全管理Linux/Unix服务器。

自动化脚本与工具:结合SSH密钥实现无人值守备份、CI/CD流水线等。

跨防火墙访问:通过隧道访问内网服务(如数据库、Web管理界面)。

安全文件传输:取代FTP,用于敏感数据的加密传输。

1.4、配置优化与安全实践

禁用密码登录:仅允许公钥认证,防止暴力破解。

# 修改sshd_config
PasswordAuthentication no

限制用户与IP:仅允许特定用户或IP段访问。

AllowUsers admin@192.168.1.0/24

更改默认端口:减少自动化攻击风险(如 Port 2222)。

禁用Root登录:降低权限滥用风险。

PermitRootLogin no

更新与漏洞防护:保持OpenSSH版本最新,及时修复安全漏洞。

1.5、优势总结

  • 开源免费:可自由使用、审计和修改代码。

  • 跨平台支持:适用于Linux、Windows(通过WSL或OpenSSH for Windows)、macOS等。

  • 社区强大:持续更新维护,及时响应安全威胁。

2、配置OpenSSH

2.1、安装OpenSSH服务器

更新系统:

sudo apt update && sudo apt upgrade -y

安装 OpenSSH Server

sudo apt install openssh-server -y

启动并启用 SSH 服务

sudo systemctl start ssh
sudo systemctl enable ssh # 设置开机启动

检查 SSH 服务状态

sudo systemctl status ssh

2.2、配置 SSH 安全性

修改默认端口(可选,但推荐)

编辑 SSH 配置文件:

sudo nano /etc/ssh/sshd_config

找到 #Port 22,取消注释并修改为一个非标准端口(例如 2222):

Port 2222

禁用 root 登录(推荐)

/etc/ssh/sshd_config 中找到以下行,取消注释:#PermitRootLogin prohibit-password

PermitRootLogin no

2.3、配置防火墙

安装 UFW(可选):

sudo apt install ufw -y

允许 SSH 端口:

sudo ufw allow 602/tcp  # 替换为你的 SSH 端口

启用防火墙:

sudo ufw enable

3、使用vscode远程资源管理器远程连接

3.1、安装 Remote-SSH 插件

3.2、打开配置文件

/Users/wq/.ssh/config

  • 特点:这是用户目录下的SSH配置文件,通常用于存储特定用户的SSH配置。
  • 适用场景:当您只需要修改自己的SSH配置,且不需要系统管理员权限时,选择此选项是合适的。
  • 影响范围:仅影响当前用户,不会影响其他用户或系统范围的SSH配置。

/etc/ssh/ssh_config

  • 特点:这是系统范围的SSH配置文件,它影响所有用户和SSH连接。
  • 适用场景:当您需要修改整个系统的SSH配置,且您拥有管理员权限时,可以选择此选项。但请谨慎操作,因为这会影响所有用户。
  • 影响范围:更改此文件会影响整个系统的SSH配置。

设置指定自定义配置文件

  • 特点:此选项允许您指定一个不同于上述两个位置的自定义配置文件。
  • 适用场景:当您需要更大的灵活性,或者需要与其他用户或系统共享配置文件时,可以选择此选项。
  • 影响范围:取决于您指定的配置文件路径和权限设置。

3.3、配置信息

打开SSH配置,可以进行配置的增删改查,保存文件即可。

3.4、远程连接

 连接方式1


  • -v 参数:表示启用详细模式(verbose mode)。在这种模式下,SSH 客户端会输出详细的调试信息,包括连接过程中的每一步操作、加密协商、认证过程等。

连接方式2

 在客户端(如本地电脑)打开终端,使用以下命令连接到服务器:

ssh -v -p 602 wangqiang@192.168.2.22  # 替换端口、用户名和服务器 IP
# 通过终端进行连接 

(dify) wq@wqdeMacBook-Pro dify % ssh -v -p 602 wangqiang@192.168.2.22
OpenSSH_9.9p1, LibreSSL 3.3.6
debug1: Reading configuration data /Users/wq/.ssh/config
...
...

Welcome to Ubuntu 22.04.5 LTS (GNU/Linux 6.8.0-58-generic x86_64)

 * Documentation:  https://help.ubuntu.com
 * Management:     https://landscape.canonical.com
 * Support:        https://ubuntu.com/pro

扩展安全维护(ESM)Applications 未启用。

0 更新可以立即应用。

2 个额外的安全更新可以通过 ESM Apps 来获取安装。
可通过以下途径了解如何启用 ESM Apps:at https://ubuntu.com/esm

New release '24.04.2 LTS' available.
Run 'do-release-upgrade' to upgrade to it.

*** System restart required ***
wangqiang@wangqiang:~$ 


# 退出远程

wangqiang@wangqiang:~$ exit
注销
debug1: client_input_channel_req: channel 0 rtype exit-status reply 0
debug1: client_input_channel_req: channel 0 rtype eow@openssh.com reply 0
debug1: channel 0: free: client-session, nchannels 1
Connection to 192.168.2.22 closed.
Transferred: sent 3644, received 4388 bytes, in 158.5 seconds
Bytes per second: sent 23.0, received 27.7
debug1: Exit status 0
(dify) wq@wqdeMacBook-Pro dify % 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2379705.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RPC与SOAP的区别

一.RPC(远程过程调用)和SOAP(简单对象访问协议)均用于实现分布式系统中的远程通信,但两者在设计理念、协议实现及应用场景上存在显著差异。 二.对比 1.设计理念 2.协议规范 3.技术特性 4.典型应用场景 5.总结 三.总结…

Day11-苍穹外卖(数据统计篇)

前言: 今天写day11的内容,主要讲了四个统计接口的制作。看起来内容较多,其实代码逻辑都是相似的,这里我们过一遍。 今日所学: Apache ECharts营业额统计用户统计订单统计销量排行统计 1. Apache ECharts 1.1 介绍 A…

Tomcat简述介绍

文章目录 Web服务器Tomcat的作用Tomcat分析目录结构 Web服务器 Web服务器的作用是接收客户端的请求,给客户端作出响应。 知名Java Web服务器 Tomcat(Apache):用来开发学习使用;免费,开源JBoss&#xff0…

《从零开始:Spring Cloud Eureka 配置与服务注册全流程》​

关于Eureka的学习,主要学习如何搭建Eureka,将order-service和product-service都注册到Eureka。 1.为什么使用Eureka? 我在实现一个查询订单功能时,希望可以根据订单中productId去获取对应商品的详细信息,但是产品服务和订单服…

FPGA学习知识(汇总)

1. wire与reg理解,阻塞与非阻塞 2. 时序取值,时钟触发沿向左看 3. ip核/setup debug 添加 ila 一、ila使用小技巧 二、同步复位、异步复位和异步复位同步释放 设计复位设计,尽量使用 异步复位同步释放;尽管该方法仍然对毛刺敏感…

Redisson分布式锁-锁的可重入、可重试、WatchDog超时续约、multLock联锁(一文全讲透,超详细!!!)

本文涉及到使用Redis实现基础分布式锁以及Lua脚本的内容,如有需要可以先参考博主的上一篇文章:Redis实现-优惠卷秒杀(基础版本) 一、功能介绍 (1)前面分布式锁存在的问题 在JDK当中就存在一种可重入锁ReentrantLock,可重入指的是在同一线…

语言模型:AM-Thinking-v1 能和大参数语言模型媲美的 32B 单卡推理模型

介绍 a-m-team 是北科 (Ke.com) 的一个内部团队,致力于探索 AGI 技术。这是一个专注于增强推理能力的 32B 密集语言模型。 a-m-team / AM-Thinking-v1 是其旗下的一个语言模型,采用低成本的方式能实现和大参数模型媲美。 DeepSe…

ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式

ChatGPT:OpenAI Codex—一款基于云的软件工程 AI 代理,赋能 ChatGPT,革新软件开发模式 导读:2025年5月16日,OpenAI 发布了 Codex,一个基于云的软件工程 AI 代理,它集成在 ChatGPT 中&#xff0c…

智能视觉检测技术:制造业质量管控的“隐形守护者”

在工业4.0浪潮的推动下,制造业正经历一场以智能化为核心的变革。传统人工质检模式因效率低、误差率高、成本高昂等问题,逐渐难以满足现代生产对高精度、高速度的需求。智能视觉检测技术作为人工智能与机器视觉融合的产物,正成为制造业质量管控…

利用html制作简历网页和求职信息网页

前言 大家好,我是maybe。今天下午初步学习了html的基础知识。做了两个小网页,一个网页是简历网页,一个网页是求职信息填写网页。跟大家分享一波~ 说明:我不打算上传图片。所以如果有朋友按照我的代码运行网页,会出现一个没有图片…

卷积神经网络进阶:转置卷积与棋盘效应详解

【内容摘要】 本文深入解析卷积神经网络中的转置卷积(反卷积)技术,重点阐述标准卷积与转置卷积的计算过程、转置卷积的上采样作用,以及其常见问题——棋盘效应的产生原因与解决方法,为图像分割、超分辨率等任务提供理论…

2025年5月13日第一轮

1.百词斩 2.安全状态和死锁 3.银行家算法和状态图 4.Vue运行 5.英语听力 6.词汇 7.英语 长篇:数学竞赛 8.数学 间断点类型和数量 The rapid development of artificial intelligence has led to widerspareasd concreasns about job displacemant.As AI technology conti…

小结:Android系统架构

https://developer.android.com/topic/architecture?hlzh-cn Android系统的架构,分为四个主要层次:应用程序层、应用框架层、库和运行时层以及Linux内核层。: 1. 应用程序层(Applications) 功能:这一层包…

基于C#的MQTT通信实战:从EMQX搭建到发布订阅全解析

MQTT(Message Queueing Telemetry Transport) 消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点。 它被设计用于低带宽,不稳定或高延迟的…

ISP中拖影问题的处理

有时候会出现如下的阴影问题该如何处理呢?本文将提供几个思路。 1、降低曝光时间 如果曝光时间过大,会统计整个曝光时间内的图像信息,就会导致拖影的产生,这个时候可以考虑降低一下曝光时间。 2、时域降噪过大 只要明白时域降噪…

SQLMesh 模型管理指南:从创建到验证的全流程解析

本文全面介绍SQLMesh这一现代化数据转换工具的核心功能,重点讲解模型创建、编辑、验证和删除的全生命周期管理方法。通过具体示例和最佳实践,帮助数据工程师掌握SQLMesh的高效工作流程,包括增量模型配置、变更影响评估、安全回滚机制等关键操…

HarmonyOS AVPlayer 音频播放器

鸿蒙文档中心:使用AVPlayer播放视频(ArkTS)文档中心https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/video-playback 这张图描述的是 HarmonyOS AVPlayer 音频播放器的状态流转过程,展示了 AVPlayer 在不同状态之间的切换条件和关键操作…

⭐️白嫖的阿里云认证⭐️ 第二弹【课时1:提示词(Prompt)技巧】for 「大模型Clouder认证:利用大模型提升内容生产能力」

「大模型Clouder认证:利用大模型提升内容生产能力」这个认证目前在阿里云认证中心还是免费的,简单几步就可以申请考试,有两次的免费考试机会。而且,这个课程中的内容对于所有普通用户来说都非常实用,课程整体长度也就3节课,非常快速就能学完。心动不如行动,赶紧开始吧!…

Filament引擎(一) ——渲染框架设计

filament是谷歌开源的一个基于物理渲染(PBR)的轻量级、高性能的实时渲染框架,其框架架构设计并不复杂,后端RHI的设计也比较简单。重点其实在于项目中材质、光照模型背后的方程式和理论,以及对它们的实现。相关的信息,可以参考官方…

c++从入门到精通(六)--特殊工具与技术-完结篇

文章目录 特殊工具与技术-完结篇控制内存分配运行时类型识别成员指针嵌套类局部类固有的不可抑制特性位域volatile限定符链接指示 extern "C" 特殊工具与技术-完结篇 控制内存分配 重载new和delete: ​ 如果应用程序希望控制内存分配的过程,…