在win中,给powershell客户端,搭建sshd服务器。
https://github.com/PowerShell/Win32-OpenSSH/releases
答:
这是微软用,openssh官方的源码,
源码网址:
https://github.com/PowerShell/openssh-portable
被微软编译后的2进制程序。2进制程序上,有微软的签名。
不建议使用其他公司的闭源sshd,里面可能有后门。
而且收费的sshd,虽然软件比较新,但一般都是闭源的。
不建议使用,n年前的低版本sshd,软件太老有漏洞。
建议解压到:
d:\OpenSSH_Win64_7.9p1
不建议安装在c盘。
powershell.exe -ExecutionPolicy Bypass -File install-sshd.ps1
sshd
OpenSSH SSH Server
powershell 传教士 原创文章 ,2019-04-23
$env:ProgramData\ssh\
或
C:\ProgramData\ssh\
生成sshd_config等文件
动作:
启动并停止服务:
Set-Service -Name sshd -StartupType 'Automatic'
start-service sshd
stop-service sshd
Remove-Item -path C:\ProgramData\ssh\ssh_host_*
cd d:\你的安装目录
ssh-keygen -A
答:
这个文件存储在c盘,修改后保存不了。所以你应该
复制C:\ProgramData\ssh\sshd_config到d盘。
用记事本打开并更改,保存。
再复制回来。
这时文件权限坏了,但并不影响sshd服务启动。
答:
此版本的ssh客户端公钥,应该添加到这个文件中:
C:\ProgramData\ssh\administrators_authorized_keys
New-NetFirewallRule -Name sshd -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
New-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name DefaultShell -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe" -PropertyType String -Force
New-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name DefaultShellCommandOption -Value "/c" -PropertyType String -Force
管理员权限运行powershell后,运行命令:
https://github.com/PowerShell/PowerShell/releases
如PowerShell-6.2.0-win-x64.msi
New-Item c:\pwsh -ItemType SymbolicLink -Target 'C:\Program Files\PowerShell\6'
$f = "$env:ProgramData\ssh\sshd_config"
$f2 = Get-Content -LiteralPath $f
Set-Content -LiteralPath $f -Value $f2[0..7]
Add-Content -LiteralPath $f -Value 'Subsystem powershell c:\pwsh\pwsh.exe -sshs -NoLogo -NoProfile'
Add-Content -LiteralPath $f -Value $f2[8..$f2.length]
pwsh -c 'Add-Content -Value "`nSubsystem powershell /usr/bin/pwsh -sshs -NoLogo -NoProfile" -LiteralPath /etc/ssh/sshd_config '
restart-service sshd
问:powershell经过ssh,远程运行命令,比bash强在哪?
=============linux远程命令 & ps远程命令 对比例子============
任意sh ---> ssh ---> linux上的bash:
ssh aaa@1.1.1.1 "以用户aaa权限执行的,命令xxx"
win,linux中的powershell ---> ssh ---> linux上的powershell:
$a = 1
[scriptblock]$备份命令 =
{
Get-Date
$b = $using:a + 2 #引用客户机变量,需要用$using:
}
$连接1 = New-PSSession -HostName 1.1.1.1 -UserName root #手动输入密码或用-KeyFilePath 选项。还需要修改/etc/ssh/sshd_config
invoke-command -ScriptBlock { $备份命令 } -Session $连接1
bash的远程命令,简单直接。就好像我左手这盘蛋炒饭,简单解饿,但是不够强。更适用于 简单远程命令场合。
你再看看我右手这盘盖饭好在哪?答:生菜垫底,萝卜雕花围边。
bash远程传递的是【字符串】,powershell传递的是【代码块】。特色是【对象垫底,大花括号围边】。
代码块,支持多行,格式化,使代码美观。
变量名,函数名支持中文。
代码块中,支持引用服务器端变量,即服务器上的【$a】,在服务器还上叫【$a】
即使变量重名,两个$a也绝不会弄混。
强类型变量,在远程使用,无需序列化/反序列化。这点py不行。java不行。
而代码嵌套容易,使的ps的ssh远程,从server1(跳板机,堡垒机)经ssh进入server2,再ssh进入server3,进入33层ssh server执行命令很容易。而shell难。
先在win中的d盘,建立几个中文文件名。
win用户名
win密码
终端软件的编码,选unicode(utf-8),这点和连接linux相同。
$PSVersionTable
get-childitem d:\
dir 查看中文会不会乱码。
$服务器ip = '192.168.1.201'
$账户名 = 'xxxx'
[scriptblock]$测试命令 =
{
get-childitem d:\
}
$连接2 = New-PSSession -HostName $服务器ip -UserName $账户名
#这里将提示你输入密码
$要返回的内容 = Invoke-Command -ScriptBlock $测试命令 -Session $连接2
$要返回的内容
$要返回的内容.name # dir 返回的文件名
答:
不能。
答:
使用用户私钥文件。
$连接3 = New-PSSession -HostName $远程ip -UserName $账户名 -keyfile c:\Users\userabcd\.ssh\id_rsa
答:
https://www.cnblogs.com/piapia/p/10412550.html
在客户机上:
Invoke-Command -FilePath d:\abc.ps1 -Session $连接4
在客户机上:
Invoke-Command -ScriptBlock $测试命令 -Session $连接5
在客户机上:
Invoke-Command -ScriptBlock { get-date; d:\xxx.ps1 ;#或 /tmp/a.ps1 } -Session $连接6
答:
scp /tmp/abc.tar.gz your_name@ip:d:\dir123
openssh官方现在不建议使用scp了。建议使用sftp。
答:
用powershell的winscp第三方模块。
开源免费软件,支持图形,也支持命令行。win,linux通用。
install-module winscp
在win中,给powershell客户端,搭建sshd服务器。的更多相关文章
- win中Oracle简易客户端和plsql的配置
连接数据库有2种方式:在本机安装Oracle数据库或者是安装一个oracle简易客户端 当然,简易客户端跟oracle数据库比较少了一些功能 连接方式: 1)简易连接 sqlplus scott/ti ...
- Mac上一条命令搭建web服务器
实际测试工作中偶尔会需要搭建Web服务器环境,由于Mac OS X自带了Apache和PHP环境,只需要简单的启动就可以. 开启Apache 开启Web服务器的方法有两种(默认启动端口号是80): 打 ...
- (转)初学Git及简单搭建git服务器和客户端
终于搞定,mac自己作为git服务器,mac也是客户端,如何免登 从另外一个linux服务器的上传公钥得到提示 ssh-copy-id -i ~/.ssh/id_rsa.pub git@192.168 ...
- [转]win server 2003 + IIS 6 搭建MVC 运行环境
本文来自:http://c.jinhusns.com/bar/t-993 win server 2003 + IIS 6 搭建MVC 运行环境 上一篇 下一篇近乎_问阳 发表于:2014-01-07 ...
- sshd服务器搭建管理和防止暴力破解
1.1 Linux服务前期环境准备,搭建一个RHEL7环境 1.2 sshd服务安装-ssh命令使用方法 1.3 sshd服务配置和管理 1.4 防止SSHD服务暴力破解的几种方式 1.1 Linux ...
- CentOS8.1中搭建Gitlab服务器
依旧是写在前面的话♠:很多IT人从业N年也许都还没有亲自搭过一次Gitlab服务器,是不是?有木有?!通常都是背着自己的笔记电脑到一家公司入职,或入职后领到公司分配的电脑,然后分配了Git账号,拿了将 ...
- 【C#】MVC项目中搭建WebSocket服务器
前言 因为项目需要,前端页面中需要不断向后台请求获取一个及一个以上的状态值.最初的方案是为每个状态值请求都建立一个定时器循环定时发起Ajax请求,结果显而 易见.在HTTP1.1协议中,同一客户端浏览 ...
- Linux-Rsync服务器/客户端搭建实战
一.需求 每晚汇总各机器的操作日志,同步到主服务器进行日志分析. 二.基础知识 rsync 分为服务器端.客户端,服务器端搭建比客户端辛苦一些(也是很简单). rsync 服务器是指以 deamon ...
- 如何在win上搭建SVN服务器
本博文转自:http://www.cnblogs.com/armyfai/p/3985660.html SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本, ...
随机推荐
- centos7忘记密码解决办法
centos7重置密码: centos7一改以往风格,很多方面都做了改进,尤其是修改root密码,一般centos6以前直接进入grub然后从单用户模式进去就可以修改,可centos7不同,笔者今天修 ...
- swift 有道 翻译文档(2 条件语句 循环语句)
控制流使用if和switch来创建条件语句,使用for-in.while和repeat-while来创建循环.条件或循环变量的括号是可选的.身体周围需要支撑. let individualScores ...
- 【VS2019】F12跳转到源码
1.工具->选项 2.文本编辑器->C#->高级->勾选支持导航到反编译源码 3.关闭浏览器不停止项目
- c#泛型约束 (where T:class)
.NET支持的类型参数约束有以下五种:where T : struct | T必须是一个结构类型where T : class ...
- 【改】利用ALSA库进行音频重采样
转自:http://www.voidcn.com/article/p-snamarwr-p.html 一.ALSA介绍: 1.简介: 高级Linux声音体系(英语:Advanced LinuxSoun ...
- L - Non-Prime Factors (质数筛选+因子分解)
In many programming competitions, we are asked to find (or count the number of) Prime Factors of an ...
- 使用XStream解析复杂XML并插入数据库(二)
标注黄色地方:我需要加深学习!!! 我写的是webservice,目前具体写webservice的步骤我还不清楚, 整理完小知识开始整理webservice! 针对以下格式的XML进行解析 <? ...
- Octopus501工作站环境配置
操作系统 Ubuntu18.04LTS(Ubuntu16.04) 远程桌面 Xtce4桌面系统(mate桌面系统)+vncserver远程桌面服务器 远程ssh连接登录 ssh服务器 文件系统 vsF ...
- leetcode71
这道题很简单,大约是词法分析器差不多的原理.但是我觉得看了别人简洁的代码后还是很有收获的.本人的冗余代码就不好意思放上来了,以下是别人的参考代码和值得借鉴的地方: class Solution { p ...
- Spring IOC、AOP、Transaction、MVC小结
1.IOC.AOP:把对象交给Spring进行管理,通过面向切面编程来实现一些“模板式”的操作,使得程序员解放出来,可以更多的关注业务实现. - ...