免费注册 查看新帖 |

Chinaunix

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

[系统管理] 如何修改一个文件的inode? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-11-29 14:58 |只看该作者 |倒序浏览
大家好

我现在正在跑一个 java 程序,是这样启动的:
java -cp classes App > output.out

现在output.out很大了,我用 cat /dev/null > output.out 来清空这个文件

用 du 命令看到文件大小确实为0了,但是 ls -l 看还是以前的大小(很长的字节数)

然后我 rm output.out 然后 touch output.out,发现新的 output.out 没有 java 程序的输出了

现在想问下,有什么方法,在不重启 java 程序的情况下,让 java 程序的输出信息,输出到 output.out 文件里?

论坛徽章:
13
技术图书徽章
日期:2014-04-29 14:15:42IT运维版块每日发帖之星
日期:2015-12-12 06:20:00IT运维版块每日发帖之星
日期:2015-08-30 06:20:00IT运维版块每日发帖之星
日期:2015-08-24 06:20:00IT运维版块每日发帖之星
日期:2015-08-02 06:20:002015年亚洲杯之澳大利亚
日期:2015-04-03 15:03:12申猴
日期:2015-03-20 09:00:292015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15季节之章:冬
日期:2015-01-20 17:08:47双子座
日期:2014-11-21 16:30:31技术图书徽章
日期:2014-07-11 16:29:08
2 [报告]
发表于 2012-11-29 15:29 |只看该作者
我可否这样理解你的需求

在不重启 java 程序的情况下,让 java 程序的输出信息,output.out 文件里,然后如果文件过大,把文件内容清空,对吗?

论坛徽章:
0
3 [报告]
发表于 2012-11-29 15:36 |只看该作者
回复 2# dengbao2001


    是的哈,就是这个需求

论坛徽章:
0
4 [报告]
发表于 2012-11-29 16:25 |只看该作者
回复 1# songday


mkfifo output.fifo
cat output.fifo > output.out
java -cp classes App > output.fifo
output.out过大时
rm output.out;cat output.fifo > output.out

论坛徽章:
0
5 [报告]
发表于 2012-11-29 17:05 |只看该作者
回复 1# songday

不重启的方法:

javapid=自己找
ls -l /proc/$javapid/fd
fd=找到output.out对应的号
gdb -p $javapid /path/bin/java
p close($fd)
p creat("/path/output.out",0600)
q
y

论坛徽章:
0
6 [报告]
发表于 2012-11-29 17:39 |只看该作者
本帖最后由 songday 于 2012-11-29 17:47 编辑
darrenlee3 发表于 2012-11-29 17:05
回复 1# songday

不重启的方法:


谢谢你的回复哈
我在测试服务器上试了下,发现这个方法是可以让 output.out 重新接受 java 输出的信息

不过会让这个 java 程序似乎进入了一个不对的状态,就是它自己是工作的,然后其它的程序访问不了它提供的服务了

我看到指向 output.out 的有两个:
1 -> /mnt/storage/output.out
2 -> /mnt/storage/output.out

第一次我是在 gdb 里面 close 了1和2,但是 output.out没有内容
第二次我运行了两次 gdb,分别 close 了1 和 2,output.out 开始接受内容了,但是 java 程序有些不正常了

论坛徽章:
0
7 [报告]
发表于 2012-11-29 17:56 |只看该作者
这里也想请教一下,为什么 cat /dev/null > output.out 以后

使用 du 命令,可以看到这个文件的大小以后从 0 重新开始了

但是用 ls -l 看,还是之前的大小

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
8 [报告]
发表于 2012-11-29 20:27 |只看该作者
kill -HUP 不就行了?

论坛徽章:
0
9 [报告]
发表于 2012-11-29 21:40 |只看该作者
回复 8# q1208c


    我试了的,java程序关闭了,不是重启

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
10 [报告]
发表于 2012-11-29 22:14 |只看该作者
回复 9# songday


噢, 我倒忘了. java好象是有点问题. 它不会处理 HUP信号.

那你就得重启java进程了. 这是最好的办法. 或者配置你的java进程按时间来写 log. 这样就不用重启了.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP