国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > 幫助中心 > 正文

ssh遠程執行命令方法和Shell腳本實例

2024-07-09 22:42:53
字體:
來源:轉載
供稿:網友

寫這篇博客之前,我google了一堆相關文章,大都是說修改/etc/sudoers,然后NOPASSWD:指定的cmd,但是真心不管用,沒有遠程虛擬終端這個方法就是浮云,ubuntu10.04 server 親測!!

ssh執行遠程操作
命令格式
復制代碼 代碼如下:
ssh -p $port $user@$p 'cmd' 
 
$port : ssh連接端口號 
$user: ssh連接用戶名 
$ip:ssh連接的ip地址 
cmd:遠程服務器需要執行的操作 

準備工作

基于公私鑰認證或者用戶名密碼認證能確保登錄到遠程local2服務器(有點基本運維知識的人做這個事情都不是問題)
cmd如果是腳本,注意絕對路徑問題(相對路徑在遠程執行時就是坑)

不足

這個命令可以滿足我們大多數的需求,但是通常運維部署很多東西的時候需要root權限,但是有幾處限制:
遠程服務器local2禁止root用戶登錄
在遠程服務器腳本里轉換身份用expect需要send密碼,這樣不夠安全

ssh的-t參數

復制代碼 代碼如下:
-t      Force pseudo-tty allocation.  This can be used to execute arbitrary screen-based programs on a remote machine, which can be very useful, e.g. when implementing menu services.  Multiple -t options force tty allocation, even if ssh has no local tty. 

中文翻譯一下:就是可以提供一個遠程服務器的虛擬tty終端,加上這個參數我們就可以在遠程服務器的虛擬終端上輸入自己的提權密碼了,非常安全
命令格式
復制代碼 代碼如下:
ssh -t -p $port $user@$ip  'cmd' 

示例腳本

復制代碼 代碼如下:
#!/bin/bash 
 
#變量定義 
ip_array=("192.168.1.1" "192.168.1.2" "192.168.1.3") 
user="test1" 
remote_cmd="/home/test/1.sh" 
 
#本地通過ssh執行遠程服務器的腳本 
for ip in ${ip_array[*]} 
do 
    if [ $ip = "192.168.1.1" ]; then 
        port="7777" 
    else 
        port="22" 
    fi 
    ssh -t -p $port $user@$ip "remote_cmd" 
done 

這個方法還是很方便的,-t虛擬出一個遠程服務器的終端,在多臺服務器同時部署時確實節約了不少時間啊!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄯善县| 榆林市| 女性| 乌兰浩特市| 新化县| 晋城| 南通市| 栖霞市| 云霄县| 东城区| 闸北区| 庄浪县| 绵竹市| 安图县| 安龙县| 本溪| 舞钢市| 浦江县| 民县| 吴旗县| 海南省| 和林格尔县| 剑河县| 外汇| 新野县| 大足县| 靖宇县| 桃源县| 额敏县| 翼城县| 嫩江县| 浦江县| 呼图壁县| 阳曲县| 桂阳县| 凉城县| 怀远县| 湛江市| 罗定市| 鞍山市| 石台县|