我试图在 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) 配置来限制对此脚本的访问,因此只有少数人可以执行该脚本。
关于linux - 远程 SUDO ssh 脚本中的 SED,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30138800/