服务器在线安装openssh
管理员权限启动powershell,输入指令
查看默认安装状态
Get-WindowsCapability -Online | Where-Object Name -like 'OpenSSH*'
data:image/s3,"s3://crabby-images/4d378/4d3780d3a8201cde8e62f81106e4185cd2599217" alt=""
可以看到系统默认安装了客户端,未安装服务器端
安装服务器端
Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0
data:image/s3,"s3://crabby-images/929bd/929bd0ca7d08b49d408ae7d691e33a7a7f9ab546" alt=""
启动服务、设置自启动、配置防火墙
# Start the sshd service
Start-Service sshd
# OPTIONAL but recommended:
Set-Service -Name sshd -StartupType 'Automatic'
# Confirm the Firewall rule is configured. It should be created automatically by setup. Run the following to verify
if (!(Get-NetFirewallRule -Name "OpenSSH-Server-In-TCP" -ErrorAction SilentlyContinue | Select-Object Name, Enabled)) {
Write-Output "Firewall Rule 'OpenSSH-Server-In-TCP' does not exist, creating it..."
New-NetFirewallRule -Name 'OpenSSH-Server-In-TCP' -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
} else {
Write-Output "Firewall rule 'OpenSSH-Server-In-TCP' has been created and exists."
}
data:image/s3,"s3://crabby-images/accc8/accc899168122e373460c856787fa13aaecd13c8" alt=""
客户端连接测试:(默认进入的是cmd)
windows powershell自带的ssh
ssh 用户名@服务器ip地址
data:image/s3,"s3://crabby-images/d0e3b/d0e3b5e84e6bc7d8278d9b874ca32aa89c5fe6d7" alt=""
xshell
data:image/s3,"s3://crabby-images/37b6c/37b6cc27d80237d9036bbbccaf9d1d3022d913e6" alt=""
关于启动powershell
ssh连接默认启动的是服务器的cmd,如果要使用powershell,输入powershell指令进入即可:
data:image/s3,"s3://crabby-images/b9552/b95522e0228cce15d774a3bba3fd6b80381f800c" alt=""
客户端测试:scp
powershell自带的scp
scp 1.txt yeqiang@ip:./1.txt
文件被拷贝到了用户主目录下,等价于Linux系统的~/1.txt
data:image/s3,"s3://crabby-images/e198a/e198a69e107f9b89fa96d4f85e8d56274bf31975" alt=""
xftp
data:image/s3,"s3://crabby-images/15af3/15af393a71d99a6e18703f0a384c87ca1400d752" alt=""
内网服务器离线安装openssh(高版本!)
github地址
下载msi文件
拷贝到内网服务器上,执行安装
手动安装
双击安装
配置服务器
# Start the sshd service
Start-Service sshd
# OPTIONAL but recommended:
Set-Service -Name sshd -StartupType 'Automatic'
# Confirm the Firewall rule is configured. It should be created automatically by setup. Run the following to verify
if (!(Get-NetFirewallRule -Name "OpenSSH-Server-In-TCP" -ErrorAction SilentlyContinue | Select-Object Name, Enabled)) {
Write-Output "Firewall Rule 'OpenSSH-Server-In-TCP' does not exist, creating it..."
New-NetFirewallRule -Name 'OpenSSH-Server-In-TCP' -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
} else {
Write-Output "Firewall rule 'OpenSSH-Server-In-TCP' has been created and exists."
}
查看服务器状态
PS C:\Users\Administrator> netstat -ano | findstr 22
TCP 0.0.0.0:22 0.0.0.0:0 LISTENING 5600
TCP [::]:22 [::]:0 LISTENING 5600
PS C:\Users\Administrator> get-service sshd
Status Name DisplayName
------ ---- -----------
Running sshd OpenSSH SSH Server
参考资料