当前位置: 首页 > article >正文

Windows Server 2019开启SSH服务踩坑全记录:从PowerShell命令到防火墙规则,一篇搞定

Windows Server 2019 SSH服务部署终极指南从零构建到企业级安全配置当我们需要在Windows Server环境中实现安全高效的远程管理时SSH服务已经成为现代运维体系中不可或缺的一环。不同于传统的RDP远程桌面SSH提供了更轻量级、更安全的命令行访问方式特别适合自动化脚本执行、批量服务器管理以及与DevOps工具链的集成。本文将带您深入Windows Server 2019的SSH服务部署全流程涵盖从基础安装到企业级安全加固的完整知识体系。1. 环境准备与核心组件安装在开始部署之前我们需要确保服务器满足基本要求。Windows Server 2019 Standard/Datacenter版本均支持OpenSSH服务但需要注意系统版本需为1809或更新。建议先通过以下命令检查系统信息Get-ComputerInfo | Select-Object WindowsProductName, WindowsVersion, OsHardwareAbstractionLayer1.1 OpenSSH服务器安装微软官方提供了两种安装方式通过GUI界面和PowerShell命令行。对于服务器环境我们强烈推荐使用PowerShell实现自动化部署# 检查可用功能 Get-WindowsCapability -Online | Where-Object Name -like OpenSSH* # 安装服务器组件 Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0安装过程中可能遇到的典型问题及解决方案错误代码可能原因解决方案0x800f0954Windows更新服务未运行启动wuauserv服务Start-Service wuauserv0x800f0906网络连接问题检查代理设置或尝试离线安装包0x800f081f系统组件损坏运行DISM /Online /Cleanup-Image /RestoreHealth1.2 服务初始化配置安装完成后需要进行基础服务配置# 启动SSH服务 Start-Service sshd # 设置开机自启 Set-Service -Name sshd -StartupType Automatic # 验证服务状态 Get-Service sshd | Select-Object Status, StartType注意默认情况下OpenSSH服务器会监听22端口如果该端口已被占用需要修改配置文件C:\ProgramData\ssh\sshd_config中的Port参数。2. 网络与防火墙深度配置2.1 防火墙规则精细化控制Windows Defender防火墙需要专门配置以允许SSH连接。以下是推荐的进阶配置方式# 创建自定义防火墙规则限制源IP New-NetFirewallRule -Name OpenSSH-Server-TCP-In -DisplayName OpenSSH Server (TCP-In) -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22 -RemoteAddress 192.168.1.0/24 -Program %ProgramFiles%\OpenSSH\sshd.exe对于需要变更默认端口的情况建议采用以下最佳实践修改sshd_config中的Port参数为高端口号如5022同步更新防火墙规则在客户端连接时显式指定端口ssh -p 5022 userserver2.2 网络层安全加固为提高安全性建议实施以下措施禁用密码认证强制使用密钥对# sshd_config配置 PasswordAuthentication no PubkeyAuthentication yes限制可登录的用户组AllowGroups ssh-users启用日志审计# 修改日志级别为VERBOSE Set-ItemProperty -Path HKLM:\SOFTWARE\OpenSSH -Name LogLevel -Value VERBOSE3. 用户认证体系与权限管理3.1 密钥认证配置最佳实践Windows OpenSSH支持标准的RSA/ECDSA/Ed25519密钥格式。以下是完整的密钥部署流程# 客户端生成密钥Linux/Mac/WSL ssh-keygen -t ed25519 -C workexample.com # Windows客户端生成密钥 ssh-keygen -t rsa -b 4096 -f $env:USERPROFILE\.ssh\id_rsa将公钥部署到服务器的方式# 创建.ssh目录如不存在 $userHome (Get-LocalUser -Name $env:USERNAME).HomeDirectory if (!(Test-Path $userHome\.ssh)) { New-Item -ItemType Directory -Path $userHome\.ssh -Force } # 设置严格权限 icacls $userHome\.ssh /inheritance:r /grant:r $env:USERNAME:(OI)(CI)F3.2 管理员权限精细控制对于需要执行特权操作的用户推荐使用gsudo等工具而非直接授予管理员权限# 安装gsudo winget install gsudo # 配置SSH命令有限提权 $profileContent function Invoke-Elevated { param([string]$Command) gsudo $Command } Add-Content -Path $PROFILE -Value $profileContent4. 高级运维与排错指南4.1 服务监控与性能优化建议创建自定义的PowerShell监控脚本# 监控SSH连接状态 function Get-SSHConnections { $connections Get-NetTCPConnection -LocalPort 22 -State Established $connections | ForEach-Object { [PSCustomObject]{ RemoteAddress $_.RemoteAddress RemotePort $_.RemotePort OwningProcess (Get-Process -Id $_.OwningProcess).ProcessName StartTime $_.CreationTime } } } # 添加计划任务每5分钟运行一次 $action New-ScheduledTaskAction -Execute PowerShell.exe -Argument -Command Get-SSHConnections | Export-Csv -Path C:\monitor\ssh_connections.csv -Append -NoTypeInformation $trigger New-ScheduledTaskTrigger -Once -At (Get-Date) -RepetitionInterval (New-TimeSpan -Minutes 5) Register-ScheduledTask -TaskName SSH Connection Monitor -Action $action -Trigger $trigger -User SYSTEM4.2 常见故障排查清单当遇到连接问题时按照以下流程排查基础服务检查Test-NetConnection -ComputerName localhost -Port 22日志分析Get-WinEvent -LogName OpenSSH/Operational -MaxEvents 50 | Where-Object { $_.LevelDisplayName -match Error|Warning } | Format-List TimeCreated, Message配置文件验证# 测试配置文件语法 $env:ProgramFiles\OpenSSH\sshd.exe -t网络层诊断# 检查防火墙规则 Get-NetFirewallRule -DisplayName *SSH* | Select-Object DisplayName, Enabled, Direction, Action | Format-Table -AutoSize5. 与开发工具链的集成实践5.1 VSCode深度集成配置在VSCode中实现高效SSH开发需要以下配置// settings.json { remote.SSH.showLoginTerminal: true, remote.SSH.remotePlatform: { my-server: windows }, remote.SSH.defaultExtensions: [ ms-vscode.powershell, ms-azuretools.vscode-docker ] }高级技巧通过SSH Config管理多环境Host prod-server HostName 192.168.1.100 User admin Port 5022 IdentityFile ~/.ssh/prod_key ForwardAgent yes Host dev-server HostName dev.example.com User developer IdentityFile ~/.ssh/dev_key LocalForward 3306 localhost:33065.2 CI/CD管道集成示例在Azure DevOps中配置SSH部署任务steps: - task: SSH0 inputs: sshEndpoint: my-ssh-connection runOptions: commands commands: | cd /d D:\deploy git pull origin main pwsh -File .\deploy.ps1 readyTimeout: 20000对于需要交互式会话的场景可以考虑使用Invoke-Command$session New-PSSession -HostName server01 -UserName admin Invoke-Command -Session $session -ScriptBlock { # 远程执行代码 Get-Service | Where-Object Status -eq Stopped } Remove-PSSession $session6. 企业级安全加固方案6.1 证书认证与双因素集成对于高安全要求环境建议实施智能卡/PIV认证# sshd_config AuthenticationMethods publickey,keyboard-interactive:pivTOTP双因素认证# 安装Google Authenticator模块 Install-Module -Name GoogleAuthenticator -Force6.2 网络层防护策略端口敲门Port Knocking# 示例敲门序列脚本 $knockSequence 1001,2002,3003 $knockSequence | ForEach-Object { Test-NetConnection -ComputerName $target -Port $_ -InformationLevel Quiet Start-Sleep -Milliseconds 200 }基于时间的访问控制# 创建时间限制防火墙规则 $workHours { Monday 08:00-17:00 Tuesday 08:00-17:00 Wednesday 08:00-17:00 Thursday 08:00-17:00 Friday 08:00-16:00 }在实际生产环境中部署Windows SSH服务时我们发现最大的挑战往往不是技术实现而是如何在便利性与安全性之间找到平衡点。通过逐步实施本文介绍的各项措施您可以构建出一个既高效又安全的远程管理环境。

相关文章:

Windows Server 2019开启SSH服务踩坑全记录:从PowerShell命令到防火墙规则,一篇搞定

Windows Server 2019 SSH服务部署终极指南:从零构建到企业级安全配置 当我们需要在Windows Server环境中实现安全高效的远程管理时,SSH服务已经成为现代运维体系中不可或缺的一环。不同于传统的RDP远程桌面,SSH提供了更轻量级、更安全的命令行…...

手把手教你用Python玩转CALCE锂电池数据集:从数据清洗到LSTM/Transformer模型实战

手把手教你用Python玩转CALCE锂电池数据集:从数据清洗到LSTM/Transformer模型实战 锂电池作为新能源领域的核心组件,其剩余寿命预测一直是工业界和学术界的研究热点。CALCE数据集作为马里兰大学发布的权威锂电池老化数据,包含了多组电池在不同…...

LVGUI图片资源管理新思路:用NXP GUI Guider一键生成合并bin文件,告别手动算地址

LVGUI图片资源管理新思路:用NXP GUI Guider一键生成&合并bin文件,告别手动算地址 在嵌入式GUI开发中,图片资源管理一直是个让人头疼的问题。特别是当项目需要大量高分辨率图片时,如何高效地将这些资源存储到外部Nor Flash并正…...

PotPlayer字幕翻译神器:打破语言壁垒,畅享全球影音盛宴

PotPlayer字幕翻译神器:打破语言壁垒,畅享全球影音盛宴 【免费下载链接】PotPlayer_Subtitle_Translate_Baidu PotPlayer 字幕在线翻译插件 - 百度平台 项目地址: https://gitcode.com/gh_mirrors/po/PotPlayer_Subtitle_Translate_Baidu 还在为外…...

告别模糊坐标!自定义你的MATLAB Figure数据提示(DataTip)显示格式

告别模糊坐标!自定义你的MATLAB Figure数据提示(DataTip)显示格式 在科研数据可视化过程中,精确呈现坐标信息往往比我们想象的更重要。想象这样一个场景:你正在分析一组高频采样数据,当鼠标悬停在某个峰值点…...

ArcGIS插件开发实战:用Python打造你的第一个自定义工具(附完整代码)

ArcGIS插件开发实战:用Python打造你的第一个自定义工具(附完整代码) 在GIS领域,ArcGIS作为行业标杆软件,其强大的可扩展性一直备受开发者青睐。想象一下,当你面对重复性操作时,不再需要一遍遍点…...

告别死记硬背:用TensorFlow和tf_geometric实战GraphSAGE,搞定蛋白质网络节点分类

蛋白质网络节点分类实战:用TensorFlow和tf_geometric实现GraphSAGE 在生物信息学领域,蛋白质相互作用网络(PPI)的分析一直是研究热点。传统方法往往需要依赖复杂的特征工程,而图神经网络(GNN)的出现为我们提供了一种端到端的解决方案。本文将…...

Python脚本清理VS重装残留:手把手教你用win32api批量删除注册表垃圾项

Python脚本清理VS重装残留:手把手教你用win32api批量删除注册表垃圾项 开发者在Windows平台上重装Visual Studio时,经常会遇到各种莫名其妙的错误。这些问题的根源往往在于注册表中残留的旧配置项。手动清理不仅效率低下,还容易遗漏关键项。本…...

Exploring Hallucination in Large Language Models: Causes, Detection, and Mitigation Strategies

1. 大语言模型幻觉现象的本质与分类 当你向ChatGPT询问"第一个登月的人是谁",它却回答"1951年的查尔斯林德伯格"——这个明显违背常识的答案就是典型的大语言模型幻觉。这种现象就像AI的"创造性谎言",模型会生成看似合理但…...

FreeRTOS下网卡驱动‘零拷贝’改造初探:解决GD32F470 Ping 17包就超时的性能瓶颈

FreeRTOS下GD32F470网卡驱动零拷贝优化实战:突破Ping 17包超时瓶颈 当GD32F470平台运行FreeRTOSlwIP协议栈时,开发者常会遇到一个诡异现象:连续Ping测试中,每17个数据包就会出现一次超时。这种周期性性能瓶颈往往暴露了传统网卡驱…...

5种方法快速判断你的Linux系统是ARM还是x86(附命令详解)

5种方法快速判断你的Linux系统是ARM还是x86(附命令详解) 在Linux系统管理和开发过程中,了解当前系统的CPU架构至关重要。无论是安装软件、部署服务还是调试程序,不同架构(ARM/x86)的系统可能需要完全不同的…...

fpga 以太网w5500 SPI传输80MHz FPGA verilog TCP客户端驱动源码

fpga 以太网w5500 SPI传输80MHz FPGA verilog TCP客户端驱动源码,8个SOCKET都可用,SPI频率80MHZ,硬件验证以通过 。 w5500 ip 核 w5500 软核,还有TCP服务端和UDP模式,联系联系我要那个,默认发TCP客户端。 这个代码是用…...

DX-BT24蓝牙模块实战:从AT指令到手机透传的完整指南

1. 认识DX-BT24蓝牙模块 第一次拿到DX-BT24蓝牙模块时,我完全被它的小巧震惊了——只有拇指大小的板子,居然能实现完整的蓝牙5.1通信功能。这个由大夏龙雀科技推出的模块,最大的特点就是内置了标准串口协议,让开发者可以像操作普通…...

网络工程-VLAN变种

MUX VLAN 概述 应用典型场景:在企业网络中,1.企业员工和企业客户可以访问企业的服务器。对于企业来说,2.希望企业内部员工之间可以互相交流,而3.企业客户之间是隔离的,不能够互相访问。 普通VLAN技术应用局限&#…...

华为OD机试 - FLASH坏块监测系统 - 并查集(Java 新系统 200分)

华为OD机试 新系统 题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题》。 刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适…...

告别固定邻居!用DeGCN的可变形卷积思想,让GCN在骨架行为识别里‘活’起来

可变形图卷积:让骨架行为识别模型学会"动态思考" 在咖啡厅里,两位工程师正盯着笔记本电脑屏幕上的骨架动作数据争论不休。"你看这个挥手动作,传统GCN对所有关节一视同仁地处理,但明明只有手臂在动啊!&q…...

高通平台Sensor驱动移植避坑指南:从BMI160实战到SEE架构解析

高通平台Sensor驱动移植实战:从BMI160配置到SEE架构深度解析 在移动设备开发领域,传感器驱动移植是BSP工程师的必修课。当拿到一款新传感器,如何快速完成从硬件对接到系统集成的全流程?本文将以BMI160六轴惯性传感器为例&#xff…...

SFUD串行Flash通用驱动库原理与嵌入式移植实战

1. SFUD 串行 Flash 通用驱动库深度解析1.1 库定位与工程价值SFUD(Serial Flash Universal Driver)并非一个简单的 SPI Flash 封装层,而是一个面向嵌入式产品全生命周期的底层固件基础设施。其核心价值在于解耦硬件选型与软件实现——当 Winb…...

从零到一:基于Qwen2.5-VL-7B-Instruct构建专属多目标检测模型

1. 环境准备与模型下载 第一次接触Qwen2.5-VL-7B-Instruct这类大模型时,最让人头疼的就是环境配置。我刚开始搭建环境时,光是版本兼容问题就折腾了大半天。后来发现用清华源安装确实能省不少时间,这里分享下我的完整配置流程。 先确保你的机器…...

用Matlab Robotics Toolbox搞定UR5机械臂建模与仿真:从DH参数到可视化(附完整代码)

用Matlab Robotics Toolbox实现UR5机械臂建模与运动控制全流程实战 在工业自动化和机器人研究领域,UR5协作机械臂因其卓越的灵活性和安全性成为学术界和工业界的宠儿。本文将带您深入探索如何利用Matlab Robotics Toolbox这一强大工具,从零开始构建UR5机…...

FastAPI子应用挂载:别再让root_path坑你一夜闭

Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT&#xff0…...

用Grad-CAM破解YOLOv8黑箱:为什么你的模型总认错物体?(案例演示)

用Grad-CAM破解YOLOv8黑箱:为什么你的模型总认错物体?(案例演示) 当你的YOLOv8模型将哈士奇误判为狼,或是把路灯识别成行人时,问题的根源往往藏在卷积神经网络那些不可见的注意力分布中。本文将通过三个典型…...

higress 这个中登才是AI时代的心头好捍

核心摘要:这篇文章能帮你 ?? 1. 彻底搞懂条件分支与循环的适用场景,告别选择困难。 ?? 2. 掌握遍历DOM集合修改属性的标准姿势与性能窍门。 ?? 3. 识别流程控制中的常见“坑”,并学会如何优雅地绕过去。 ?? 主要内容脉络 ?? 一…...

为什么你的微调效果总差2个点?——大模型清洗中被低估的语义重复剔除术

第一章:大模型工程化中的数据去重与清洗 2026奇点智能技术大会(https://ml-summit.org) 数据质量是大模型性能的底层基石。未经治理的原始语料库往往包含大量重复样本、低信息熵文本、噪声片段及跨文档镜像内容,直接训练将导致模型收敛缓慢、记忆偏差放…...

HagiCode Soul 平台技术解析:从需求萌发到独立平台的演进之路涣

1 安装与初始化 # 全局安装 OpenSpec npm install -g fission-ai/openspeclatest # 在项目目录下初始化 cd /path/to/your-project openspec init 初始化时,OpenSpec 会提示你选择使用的 AI 工具(Claude Code、Cursor、Trae、Qoder 等)。 3 O…...

大模型水印不是加个logo!揭秘Transformer层粒度嵌入、梯度掩码与语义一致性校验三重防御体系

第一章:大模型工程化中的模型水印技术 2026奇点智能技术大会(https://ml-summit.org) 在大模型规模化部署与商业化落地过程中,模型水印技术已成为保障知识产权、追踪非法复用、防范模型窃取的关键工程能力。不同于传统数字水印嵌入媒体内容&#xff0c…...

LeetCode 删除无效的括号:python 题解恳

这个代码的核心功能是:基于输入词的长度动态选择反义词示例,并调用大模型生成反义词,体现了 “动态少样本提示(Dynamic Few-Shot Prompting)” 与 “上下文长度感知的示例选择” 的能力。 from langchain.prompts impo…...

扁率和椭率详解

扁率和椭率详解 引言 在几何学、地球科学、天文学等领域,扁率和椭率是两个非常重要的概念。它们描述了几何体(尤其是旋转椭球体)的形状特征,对于理解地球形状、天体运动以及各种工程应用都具有重要意义。本文将深入探讨扁率和椭率的概念、定义、数学推导、应用场景以及使…...

告别海量标注!用SG-One的Masked Average Pooling,一个样本就能搞定图像分割

小样本图像分割实战:SG-One的Masked Average Pooling核心解析与PyTorch实现 当标注数据稀缺成为计算机视觉项目的常态时,传统分割方法往往陷入"巧妇难为无米之炊"的困境。SG-One提出的Masked Average Pooling技术,正在改变这一局面…...

告别手动复制粘贴:用Web Scraper Chrome扩展轻松抓取网页数据

告别手动复制粘贴:用Web Scraper Chrome扩展轻松抓取网页数据 【免费下载链接】web-scraper-chrome-extension Web data extraction tool implemented as chrome extension 项目地址: https://gitcode.com/gh_mirrors/we/web-scraper-chrome-extension 你是否…...