免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4603 | 回复: 11
打印 上一主题 下一主题

当我覆盖正在运行的程序的文件时,经常会导致程序崩溃 [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-29 11:44 |只看该作者 |倒序浏览
怪了,以前写的程序在运行时覆盖的话,都会提示文件在忙,不允许

我写了一个测试程序,经常在我用SCP 覆盖上传的时候,就崩溃了,崩溃的时间点就是我上传的时候,而且几个相同的程序同时死掉。

有没有人遇到过这种情况 ,

论坛徽章:
0
2 [报告]
发表于 2010-04-29 11:45 |只看该作者
大哥,Linux不是NT。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2010-04-29 11:51 |只看该作者
回复 2# prolj


  好姐姐,麻烦告诉我问题出在哪,我也知道linux 跟NT 不一样

论坛徽章:
1
申猴
日期:2014-02-11 14:50:31
4 [报告]
发表于 2010-04-29 12:25 |只看该作者
本帖最后由 chenzhanyiczy 于 2010-04-29 12:29 编辑

回复 3# cookis


他是不知道的,
最讨厌讲一半不讲的

论坛徽章:
0
5 [报告]
发表于 2010-04-29 12:30 |只看该作者
看起来不大可能。
这样说吧,最早的系统程序执行的时候会把文件的内容一次加载到内存中,所以,就算覆盖了文件内容,也不会影响到正在执行这个程序的进程。
后来有个copy on write的概念,相当于开始只加载程序的部分内容,等程序执行到需要的内容时,再从硬盘上读取进来,这种case如果修改了文件,那么可能会影响到当前的进程。
不过你正好在覆盖的时候产生问题,可以用命令ulimit -c size打开core dump,程序死掉的话,也许会产生一个core文件,你用gdb分析一下死在哪里了。

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
6 [报告]
发表于 2010-04-29 12:31 |只看该作者
Linux文件基于计数的,load execute的时候不锁程序,直接mmap。如果你写了程序,载入器是不知道滴,然后mmap就会搞错数据,然后就悲剧咯。

论坛徽章:
0
7 [报告]
发表于 2010-04-29 12:54 |只看该作者
LZ你确定是覆盖可执行文件?
exec系列的系统调用在do_mmap映射可执行文件时会加MAP_DENYWRITE选项,在映射解除之前,试图写这个文件会得到ETXTBUSY错误。

动态链接库则没有这么好的待遇,mmap之后是可以修改的。如果你拷贝覆盖的是动态链接库的话,崩溃就是正常的……

参考:http://lwn.net/2001/1011/kernel.php3

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
8 [报告]
发表于 2010-04-29 13:14 |只看该作者
LS:我经常覆盖可执行文件,一般是玩ACM的时候,直接运行,然后N小时候慢桌面都是xterm……

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
9 [报告]
发表于 2010-04-29 13:18 |只看该作者
回复 7# kouu


    哦,对,我还覆盖了动态链接库,那可能是这个问题

论坛徽章:
0
10 [报告]
发表于 2010-04-29 13:23 |只看该作者
LS:覆盖分两种,一种是cp、一种是mv。两种是不同的。
cp是打开目标文件,然后把内容写进去。如果目标文件已经被deny write,那么就会text busy
mv是把源文件的inode移动到目标路径去,目标路径下原来的那个inode就不能从目录树上找到了。但是原来的inode还存在,因为有进程正映射了它。直到这个inode再也不被引用的时候,它会被释放。

所以,mv覆盖没有问题,cp覆盖就会text busy。

如果LS发现cp覆盖一个正在执行的可执行文件,不会报text busy的话,希望提供一些环境及操作细节,非常感谢~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP