[英]SED in remote SUDO ssh script
我试图在 1000 台服务器上运行 yum 时禁用 RHN 检查。 它是通过以下方式完成的:
编辑这个文件/etc/yum/pluginconf.d/rhnplugin.conf
[main]
enabled = 0
我写了一个脚本来远程执行此操作。 我们正在使用个人帐户,我需要使用 SUDO 执行此命令:
for HOST in $(cat serverlist ) ; do echo $HOST; ssh -o ConnectTimeout=5 -oStrictHostKeyChecking=no $HOST -t 'sudo cp /etc/yum/pluginconf.d/rhnplugin.conf /etc/yum/pluginconf.d/rhnplugin.$(date +%F) ; sudo sed -i -e "s/1/0/g" /etc/yum/pluginconf.d/rhnplugin.conf ' ; done
我知道这是一条很长的线路,但为什么它不起作用?
所有单独的命令都独立工作
sudo cp /etc/yum/pluginconf.d/rhnplugin.conf /etc/yum/pluginconf.d/rhnplugin.$(date +%F)
sudo sed -i -e "s/1/0/g" /etc/yum/pluginconf.d/rhnplugin.conf
已尝试转义特殊字符:
sudo sed -i -e "s\/1\/0\/g" /etc/yum/pluginconf.d/rhnplugin.conf
但我一直收到错误:
sed: -e expression #1, char 1: unknown command: `?'
谢谢你的帮助。
sudo(1) 命令需要一个伪电传打字机 (pty),如果没有看到,则失败。 重写您的命令行以使用 su(1) 代替。 使用您的本地 sudo(1) 配置来限制对该脚本的访问,以便只有少数人可以执行该脚本。
我实际上找到了这个问题的答案,或者更确切地说是解决方法。 看到为了下面的代码片段,在那里我得到了-as根- ssh作为我(szymonri)到其他主机,然后调用sed命令,作为根用户编辑/etc/hosts
的文件。 这一切都归功于base64
魔法。
ME=`echo -e "$(hostname -I | awk '{print $1}')\toverlord"`
B64ENC=`echo "sed -i 's/.*overlord/$ME/g' /etc/hosts" | base64`
su - szymonri sh -c "ssh jetson bash -c \\\"echo $B64ENC \| base64 --decode \| sudo bash \\\""
/etc/hosts
行
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.