我正在尝试使用 Capistrano 在 iptables 防火墙中远程打开一个端口。这是我的任务:
desc "Open up a port in the firewall"
task :open_port, :roles => :all do
port = variables[:port] || nil
if (!port)
puts "You must specify the port number"
next
end
run "#{sudo} /sbin/iptables -I RH-Firewall-1-INPUT 1 -p tcp --dport #{port.to_s} -j ACCEPT"
run "#{sudo} /sbin/service iptables save"
run "#{sudo} /etc/init.d/iptables restart"
end
问题是任务中的第一个命令被锁定。我尝试使用各种端口号和目标机器运行此规则,结果始终相同。
我确实有很多其他规则,看起来很像这样,但效果很好。事实上,我有一个类似的任务,其中第一个命令是调用 iptables 以创建端口映射,并且该任务工作得很好。
更重要的是,我可以在 Capistrano 主机上成功运行这个命令:
ssh -l deployer core sudo /sbin/iptables -I RH-Firewall-1-INPUT 1 -p tcp --dport 2424 -j ACCEPT
这工作正常。这应该正是 Capistrano 试图做的事情。
为什么这个命令会锁定 Capistrano?
TIA 寻求解决方案或任何线索。
玩得开心!!!