linux系统更新正在运行进程的可执行文件需要注意的text file busy的原因及解决方法

snooda   发布时间:2014-04-12 22:29:20   作者:佚名   我要评论
这篇文章主要介绍了linux系统更新正在运行进程的可执行文件需要注意的text file busy的原因及解决方案,需要的朋友可以参考下
最近发现很多同学不知道线上操作替换文件的要点。所以又整理了一下。

线上替换一个正在运行进程的文件时(包括二进制、动态库、需要读取的资源文件等)。应避免使用cp/scp操作。而需要使用mv/rsync作为替代。

原因:cp是将源文件截断然后写入新内容。也就是说正在打开这个文件的进程可以立刻感知到修改。修改文件内容很可能导致程序逻辑错误甚至崩溃。而mv则是标记”删除“老文件,然后放一个新的同名文件过去。也就是说老文件和新文件其实是两个不同文件(inode不同),只是名字一样而已。正在打开老文件的进程不会受到影响。如果进程使用了mmap打开某文件(比如载入so),如果目标文件被使用cp覆盖并且长度变小。那么读取差额部分的地址时(在新文件中其实已经不存在了),会导致SIGBUS信号。使进程崩溃。

至于可执行文件本身。倒是不怕cp导致崩溃。。因为cp时会报”text file busy"。压根cp不了。这时候也应该使用mv类操作。替换完成后重启进程。执行的就是新的可执行文件了。

相关文章

  • linux使用cp报错 Text file busy

    有同事问到我:使用cp命令时,如果发现要被覆盖的文件(二进制可执行文件)正在运行,cp会报错,cp命令是怎么知道该文件正在执行的?
    2014-04-12
  • Linux下执行程序出现 Text file busy 提示时的解决方法

    最近在用linux执行命令的时候提示Text file busy,百度了一下发现原来通过fuser xxx 命令查看制定的文件被哪个进程占用,然后关闭该进程,则解决问题
    2014-04-12

最新评论