gossh使用示例

gossh使用示例

1.单机模式

1.远程运行命令。

命令原型

gossh [-t cmd] -h hostname -P port(default 22) -u username(default root) -p passswrod  [-f]  "command"

-t 参数可以省略,gossh默认执行模式就是远程执行命令。

command远程执行命令如果有空格,建议使用双引号将括起来。

-P -u 都可以不指定,使用默认值。

示例

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2 -t cmd -u root -p xxxx -P 22 "uname"
ip=192.168.56.2
command=uname
return=0
Linux

使用默认值
只指定了-h 主机,-t -u -P都使用默认值。

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2  "uname"
ip= 192.168.56.2
command= uname
Linux

使用-f强制执行命令,一些危险命令拒绝执行,使用-f强制执行。

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2  "cd /tmp && rm ip.txt"
Dangerous command in cd /tmp && rm ip.txt
You can use the `-f` option to force to excute
[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2 -f  "cd /tmp && rm ip.txt"
ip=192.168.56.2
command=cd /tmp && rm ip.txt
return=0

2.推送文件到远程主机。

支持推送文件或者文件夹到远程主机,如果远程主机已经存在文件,默认是拒绝执行,可以使用-f参数强制覆盖。

命令原型

gossh -t push -h hostname -P port(default 22) -u username(default root) -p passswrod  [-f]  
localfile/localpath  remotepath

如果远程文件已存在,可以使用-f参数强制覆盖。

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2 -t push ip.txt  /tmp
ip=192.168.56.2
command=push ip.txt to 192.168.56.2:/tmp
return=1
<ERROR>
Remote Server's /tmp has the same file ip.txt
You can use `-f` option force to cover the remote file.
</ERROR>

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2 -t push -f ip.txt  /tmp
ip=192.168.56.2
command=push ip.txt to 192.168.56.2:/tmp
return=0
push ip.txt to 192.168.56.2:/tmp ok

3.从远程主机拉取文件。

命令原型

gossh -t pull -h hostname -P port(default 22) -u username(default root) -p passswrod remote_file  
local_path

注意:如果local_path不存在,会自动创建。

完整示例

[root@andesli.com /project/go/src/gossh]#gossh -h 192.168.56.2 -u root -p xxxxx -P 22 -t pull  
/tmp/ip.txt .
ip= 192.168.56.2
command= scp  root@192.168.56.2:/tmp/ip.txt .
Files is transferred successfully.

2.批量模式

批量模式和单机模式的区别:

使用-i参数代替-h指定批量运行的ip文件。 可以是用-c参数指定并发度。 如果密码加密了,需要带上-e参数告诉gossh密码已经加密。
批量拉取文件到本地时,由于是文件都一样,文件会放到local_path/ip下,单机模式时直接放在local_path指定本地目录,但是批量模式,放到local_path下每个主机ip子目录下。
ipfile文件内容(密码加密):

[root@andesli.com /project/go/src/gossh]#cat ip.txt 
192.168.56.2|22|root|T9GrQBSkD6zkRZOEd+ggfg==
192.168.56.2|22|root|
192.168.56.2|22
192.168.56.2|

1.批量远程运行命令。

[root@andesli.com /project/go/src/gossh]#gossh -t cmd -i ip.txt "uname"
[servers]=[192.168.56.2 192.168.56.2]
ip=192.168.56.2
command=uname
return=0
Linux

ip=192.168.56.2
command=uname
return=0
Linux

2.推送文件到批量远程主机。

[root@andesli.com /project/go/src/gossh]#gossh -t push -f -i ip.txt  passtool /tmp   
[servers]=[192.168.56.2 192.168.56.2]
ip=192.168.56.2
command=push passtool to 192.168.56.2:/tmp
return=0
push passtool to 192.168.56.2:/tmp ok

ip=192.168.56.2
command=push passtool to 192.168.56.2:/tmp
return=0
push passtool to 192.168.56.2:/tmp ok

3.批量从远程主机拉取文件到本地。

[root@andesli.com /project/go/src/gossh]#gossh -t pull -f -i ip.txt  /project/go/src/gossh/passtool 
/tmp 
[servers]=[192.168.56.2 192.168.56.2]
ip= 192.168.56.2
command= scp  root@192.168.56.2:/project/go/src/gossh/passtool /tmp/192.168.56.2
return=0
Pull from /project/go/src/gossh/passtool to /tmp/192.168.56.2 ok.

ip= 192.168.56.2
command= scp  root@192.168.56.2:/project/go/src/gossh/passtool /tmp/192.168.56.2
return=0
Pull from /project/go/src/gossh/passtool to /tmp/192.168.56.2 ok.

注意:

-h hostname 指定主机,用于单机模式。
-i ipfile 指定ip文件,用于批量模式。
如果既不指定-h 也不指定-i参数,gossh默认会从当前目录中寻找ip.txt文件作为ip文件进行批量模式执行。

文件推送或者拉取过程中,设计到文件是否存在的判断,以及是否覆盖的判断,详细规则见gossh安全管理第3节文件传递安全性。

阅读全文
除特别注明外,本站所有文章均基于CC-BY-NC-SA 4.0原创,转载请注明出处。
文章名称:《gossh使用示例》
文章链接:https://www.mrgod.cn/65.html
分享到: 生成海报

评论 抢沙发

评论前必须登录!

立即登录   注册

简简单单,做好记录

切换注册

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活