SSH ControlMaster功能

2024-04-21 15:28
文章标签 功能 ssh controlmaster

本文主要是介绍SSH ControlMaster功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ssh 的ControlMaster实现不用每次ssh都输入密码

  • 1、参数说明
  • 2、设置方式
  • 3、Window系统不支持

1、参数说明

要启用 SSH 连接复用功能,您可以按照以下步骤操作:
编辑 SSH 客户端配置文件:
打开或创建 SSH 客户端配置文件 ~/.ssh/config(Linux 和 macOS 系统)或 %USERPROFILE%.ssh\config(Windows 系统)。
在配置文件中添加以下内容:
在配置文件中添加以下内容来启用连接复用:

Host *ControlMaster autoControlPath ~/.ssh/master-%r@%h:%pControlPersist 600

Host *:这表示对所有主机应用这些配置,您也可以针对特定主机或主机模式应用这些配置。
ControlMaster auto:启用连接复用。
ControlPath ~/.ssh/master-%r@%h:%p:定义保存主连接的路径和文件名模式。%r 表示远程用户名,%h 表示远程主机名,%p 表示远程端口号。这将在 ~/.ssh/ 目录下创建一个名为 master-username@hostname:port 的文件,用于保存主连接信息。
ControlPersist 600:定义持续时间(以秒为单位),即在连接关闭后继续保持主连接的时间。在此示例中,连接将在最后一个会话结束后持续 600 秒(10 分钟),以便在此期间可以重用该连接。
链接:https://www.jianshu.com/p/1554e9afb86e

注意ControlPath参数:
ControlPath ~/.ssh/controlmasters/%r@%h:%p (.ssh后面不能有不存在的目录)
改正:ControlPath ~/.ssh/controlmasters-%r@%h:%p 

2、设置方式

#方式一:
Host *ControlPath ~/.ssh/test%r@%h:%pControlMaster autoControlPersist yes
Host kcHostName newrelay.comUser caizhao#方式二:
Host *User caizhaoControlMaster autoHost kcHostName newrelay.comControlPath ~/.ssh/master-%r@%h:%p.socketControlPersist yes ForwardX11 yesServerAliveInterval 300 #方式三:
Host cedarControlPath ~/.ssh/cm-%r@%h:%pControlMaster autoControlPersist 10mHostName newrelay.comUser caizhao

3、Window系统不支持

window系统暂不支持ControlMaster ,要使用安装WLS的Linux系统来支持
getsockname failed: Not a socket

安装
参考:https://learn.microsoft.com/zh-cn/windows/wsl/setup/environment

wsl --install

电脑终端配置wsl
使用 .wslconfig 为 WSL 上运行的所有已安装的发行版配置全局设置。
参考:https://learn.microsoft.com/zh-cn/windows/wsl/enterprise
vim ~/.wslconfig

[experimental]
autoMemoryReclaim=gradual  # gradual  | dropcache | disabled
networkingMode=mirrored
dnsTunneling=true
firewall=true
autoProxy=true

Linux终端中配置网络
配置DNS

sudo rm /etc/resolv.conf
sudo bash -c 'echo "nameserver 8.8.8.8" > /etc/resolv.conf'
sudo bash -c 'echo "[network]" > /etc/wsl.conf'
sudo bash -c 'echo "generateResolvConf = false" >> /etc/wsl.conf'
sudo chattr +i /etc/resolv.conf

设置代理:

#IP为window的IP地址,ipconfig查看
export ALL_PROXY="http://172.19.80.1:7890"

安装ssh

sudo apt update && sudo apt upgrade
sudo apt install openssh-client
sudo apt install openssh-server

shh配置(Ubuntu)

1、ssh服务端配置(服务)
#vim /etc/ssh/sshd_config
Port 2222
ListenAddress 0.0.0.0
PermitRootLogin yes
StrictModes yes
PasswordAuthentication yes
# 配置完需要重启服务:sudo systemctl restart sshd.service2、ssh客户端配置(客户)
#vim ~/.ssh/config
#方式一:
Host *ControlPath ~/.ssh/test%r@%h:%pControlMaster autoControlPersist yes
Host kcHostName newrelay.com(你要连接地址)User caizhao (你的用户名)

修改Wsl为root登录,并修改root密码

 ubuntu config --default-user root

这篇关于SSH ControlMaster功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/923408

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

基于Java和FFmpeg实现视频压缩和剪辑功能

《基于Java和FFmpeg实现视频压缩和剪辑功能》在视频处理开发中,压缩和剪辑是常见的需求,本文将介绍如何使用Java结合FFmpeg实现视频压缩和剪辑功能,同时去除数据库操作,仅专注于视频处理,需... 目录引言1. 环境准备1.1 项目依赖1.2 安装 FFmpeg2. 视频压缩功能实现2.1 主要功

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

基于Spring Boot 的小区人脸识别与出入记录管理系统功能

《基于SpringBoot的小区人脸识别与出入记录管理系统功能》文章介绍基于SpringBoot框架与百度AI人脸识别API的小区出入管理系统,实现自动识别、记录及查询功能,涵盖技术选型、数据模型... 目录系统功能概述技术栈选择核心依赖配置数据模型设计出入记录实体类出入记录查询表单出入记录 VO 类(用于

Qt中实现多线程导出数据功能的四种方式小结

《Qt中实现多线程导出数据功能的四种方式小结》在以往的项目开发中,在很多地方用到了多线程,本文将记录下在Qt开发中用到的多线程技术实现方法,以导出指定范围的数字到txt文件为例,展示多线程不同的实现方... 目录前言导出文件的示例工具类QThreadQObject的moveToThread方法实现多线程QC