我有3个服务器的进程,需要所有的CPU,他们可以得到。我让这些进程将它们的标准输出写入文件。
./run.sh > run.log这样写会不会减缓这个过程呢?( ./run.sh脚本开始例如。Java程序,有时也是Ruby程序)
现在,我想创建一个web界面,在脚本运行时显示输出。我可以想象编写一个php脚本,它每5秒刷新一次,创建到服务器的SSH连接,完成并获取run.log文件。
但是,这不是会干扰或减缓进程吗?,服务器能够尽可能多地使用它的能力是非常关键的。还是有更好的方法来处理这个问题呢?而不是每5秒创建一个SSH连接,而是使用Ajax进行持久连接和更新?(安全不是一项要求)
发布于 2011-06-24 14:46:20
,这篇文章会不会减缓这个过程?( ./run.sh脚本开始例如。Java程序,有时也是Ruby程序)
也许;如果进程写入了大量数据,它可以很容易地减缓进程的速度,因为该进程很可能会同步写入磁盘。否则,你不用担心。
另一种选择是设置脚本通过某种消息服务将输出与web应用程序一起发送到机器。这将避免轮询服务器;它是否更有效取决于细节。
一个简单有效的机制是将stdout转发到UDP套接字,让web应用程序监听这些消息,并将这些消息暂时存储在循环缓冲区中。
https://stackoverflow.com/questions/6469370
复制相似问题