1.如何通过命令行远程重启或远程关闭Windows系统

怎么才能远程重启电脑系统_怎么远程重启电脑cmd

安装步骤:

1、进入链接下载最新 OpenSSH-Win64.zip(64位系统),解压至C:\Program Files\OpenSSH

2、打开cmd,cd进入C:\Program Files\OpenSSH(安装目录),执行命令:

powershell.exe -ExecutionPolicy Bypass -File install-sshd.ps1

3、设置服务自动启动并启动服务:

sc config sshd start= auto

net start sshd

到此服务已经安装完毕,默认端口一样是22,默认用户名密码为Window账户名和密码,当然防火墙还是要设置对应端口允许通讯

修改设置:

通常linux下会修改ssh_config文件来修改ssh配置,但在安装目录并没有发现这个文件,查阅官方wiki后发现,原来是在C:\ProgramData\ssh目录下(此目录为隐藏目录)

端口号:Port 22

密钥访问:PubkeyAuthentication yes

密码访问:PasswordAuthentication no

空密码:PermitEmptyPasswords no

然后进入C:\Users\账户名\.ssh目录,创建authorized_keys公钥文件(也可在ssh_config修改路径)(仅限7.7之前版本,7.9版本请看最后更新)

设置完成后重启sshd服务,接下来就可以使用Xshell等工具使用密钥连接了~

踩过的坑:

命令行不识别空格时:C:\Program Files\用C:\Progra~1\替代

Windows Service2012R2即使配置了.ssh/authorized_keys公钥,连接时依然显示没有注册公钥。。。

查阅了官方wiki判断可能是权限问题:Fix SSH file permissions

进入C:\Program Files\OpenSSH(安装目录),右键 FixHostFilePermissions.ps1使用PowerShell运行,命令行提示全选是,重启sshd服务后密钥连接正常

2019.5.17更新:

新部署服务器的时候,发现公钥无法注册,发现新版本有变动:

参考官方wiki:administrators_authorized_keys

Administrators用户组的用户连接公钥,默认位置为

C:\ProgramData\ssh\administrators_authorized_keys

并且需要设置权限,在CMD中执行命令:

icacls administrators_authorized_keys /inheritance:r

icacls administrators_authorized_keys /grant SYSTEM:(F)

icacls administrators_authorized_keys /grant BUILTIN\Administrators:(F)

修改ssh_config文件:

AuthorizedKeysFile %programdata%/ssh/administrators_authorized_keys

重启sshd服务,即可使用密钥登陆SSH

3. 安装expect 方法

转自

6个Expect脚本示例

2014年09月01日 20:48:32?HaveFunInLinux?阅读数 7982

本文译至: 脚本语言用于自动提交输入到交互程序。它相比其它脚本语言简单易学。使用expect脚本的系统管理员和开发人员可以轻松地自动化冗余任务。它的工作原理是等待特定字符串,并发送或响应相应的字符串。

以下三个expect命令用于任何自动化互动的过程。

send –?发送字符串到进程

expect –?等待来自进程的特定的字符串

spawn –?启动命令?

请确保在您的系统上安装expect软件包,因为它不会被默认安装。 一旦安装后,你会看到expect解释器“/usr/bin/expect”。 一般来说,expect脚本文件具有.exp的扩展。

1. Expect “Hello World”范例

下面的expect脚本等待具体字符串“hello”。?当它找到它时(在用户输入后),“world”字符串将作为应答发送。

#!/usr/bin/expect

expect "hello"

send "world"

2.?等待的字符串超时

默认情况下,等待的超时时间为10秒。?如果你不为expect命令输入任何东西,将在20秒内超时。?您也可以更改超时时间,如下所示。

#!/usr/bin/expect

set timeout 10

expect "hello"

send "world"

3. 使用Expect自动化用户进程

在Expect的帮助下,你可以自动化用户进程,并得到期望的输出。?例如,您可以使用Expect编写测试脚本来简化项目的测试用例。

下面的例子执行了额外的程序自动化。

#!/usr/bin/expect

set timeout 20

spawn "./addition.pl"

expect "Enter the number1 :" { send "12\r" }

expect "Enter the number2 :" { send "23\r" }

interact

执行上面的脚本,输出结果如下所示。

$ ./user_proc.exp

spawn ./addition.pl

Enter the number1 : 12

Enter the number2 : 23

Result : 35

如果你写的代码没有interact命令,在这种情况下,脚本会在发送字符串“23\r”后立即退出。?interact命令执行控制,处理addtion进程的作业,并生成预期的结果。

4.?在$expect_out变量中的匹配和不匹配的内容

在字符串匹配成功时expect返回,但在此之前它将匹配的字符串存储在$expect_out(0,string)。之前所收到的字符串加上匹配的字符串存储在$expect_out(buffer)。下面的例子展示了这两个变量匹配的值。

#!/usr/bin/expect

set timeout 20

spawn "./hello.pl"

expect "hello"

send "no match : <$expect_out(buffer)> \n"

send "match : ?<$expect_out(0,string)>\n"

interact

hello.pl程序只是打印两行,如下图所示。

#!/usr/bin/perl

print "Perl program\n";

print "hello world\n";

如下所示执行。

$ ./match.exp

spawn ./hello.pl

Perl program

hello world

no match : ?<Perl program

hello>

match : ?<hello>

5. 自动化SU登录到其他用户帐户?

Expect可以让你从程序中传递密码给Linux登录账号,而不是在终端输入密码。在下面的程序中,su自动登录到需要的账户上。?

#!/usr/bin/expect

set timeout 20

set user [lindex $argv 0]

set password [lindex $argv 1]

spawn su $user

expect "Password:"

send "$password\r";

interact

如下所示执行上面的expect程序。?

bala@localhost $ ./su.exp guest guest

spawn su guest

Password:

guest@localhost $

运行上面的脚本后,从bala用户帐户登录到guest用户帐户。?

6. SSH登录到另一台计算机

下面给出的expect程序项目可自动从一台计算机ssh登录到另一台机器。?

#!/usr/bin/expect

set timeout 20

set ip [lindex $argv 0]

set user [lindex $argv 1]

set password [lindex $argv 2]

spawn ssh "$user\@$ip"

expect "Password:"

send "$password\r";

interact

执行上面的expect程序如下所示。?

guest@host1 $ ./ssh.exp 192.168.1.2 root password

spawn ssh root@192.168.1.2

Password:

Last login: Sat Oct ?9 04:11:35 2010 from host1.geetkstuff.com

root@host2 #

4. 我这边的简单命令为

脚本为:

请点击输入描述

#!/usr/bin/expectset timeout 20set ip [lindex $argv 0]set user [lindex $argv 1]set password [lindex $argv 2]

spawn ssh "$user\@$ip" "net start gscloud"expect "password:"send "$password\r";

interact

请点击输入描述

执行的命令为:

./deploy/startwin 10.24.196.213 administrator Test1127?!

如何通过命令行远程重启或远程关闭Windows系统

用CMD环境命令shutdown实现:

例:shutdown /s /p /f /m \\172.19.1.100 /user:administrator "password"

即可。(注意命令语法中的空格)

首先打开运行窗口,出现DOS界面,然后敲入如下命令:shutdown /r /m\\hostname-t 0其中,/r 表示重新启动,/m表示机器主机名,-t表示延后时间(0表示立即重启)如果需要关机,则敲入如下命令:shutdown /s /m\\hostname-t 0其中,/s 表示关闭计算机如果你对命令行不太熟悉,可以直接敲入如下命令:shutdown /i打开对话框,然后输入相关参数即可远程关机或重启,需要有本地的管理员权限,要远程关闭计算机,请把相应的用户加入本地管理员,或者修改组策略添加用户权限。添加远程关机用户账户权限1. 在组策略编辑器中,打开逐级展开“计算机配置”→“Windows 设置”→“安全设置”→“本地策略”→“用户权利指派”2. 在“组策略”窗口的右侧窗格中选择“从远端系统强制关机”,通过双击将其打开。3. 单击对话框下方的“添加用户或组”按钮,添加一个可以远程关机的用户。