免费注册 查看新帖 |

Chinaunix

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

上午玩linux, 反过来被linux玩了 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-04 14:38 |只看该作者 |倒序浏览
在命令行输入:
SHELL> ls -l
[xyz@localhost test]$ ls -l
总计 64
-rw-rw-r-- 1 xyz xyz 1577 06-13 22:51 allow_ip
-rw-rw-r-- 1 xyz xyz 1752 06-13 22:58 allow_ip_new.txt
-rw-rw-r-- 1 xyz xyz 2432 06-16 17:34 a.txt
-rw-rw-r-- 1 xyz xyz 1577 06-16 17:29 httpd.conf
-rw-rw-r-- 1 xyz xyz 1576 06-16 17:33 httpd.conf.new
-rw-rw-r-- 1 xyz xyz  314 06-18 16:40 live.txt
drwxrwxr-x 2 xyz xyz 4096 06-17 00:55 new
-rw-rw-r-- 1 xyz xyz 2588 06-13 22:53 new_ip

这样我在命令行里执行 ls -l | awk '{print $8}' 就可以打印出文件名了
然而把 ls -l 放在脚本里,然后用crontab 定时执行:
####cron.sh###
#!/bin/bash

ls -l
打印出来的却是:
total 64
-rw-rw-r-- 1 xyz xyz 2432 Jun 16 17:34 a.txt
-rw-rw-r-- 1 xyz xyz 1577 Jun 13 22:51 allow_ip
-rw-rw-r-- 1 xyz xyz 1752 Jun 13 22:58 allow_ip_new.txt
-rw-rw-r-- 1 xyz xyz 1577 Jun 16 17:29 httpd.conf
-rw-rw-r-- 1 xyz xyz 1576 Jun 16 17:33 httpd.conf.new
-rw-rw-r-- 1 xyz xyz  314 Jun 18 16:40 live.txt
drwxrwxr-x 2 xyz xyz 4096 Jun 17 00:55 new
-rw-rw-r-- 1 xyz xyz 2588 Jun 13 22:53 new_ip
日期的格式变了, 变成类似这样子的了Jun 16 17:34
用 ls -l | awk '{print $8}'打印出时间来了

被linux搞晕了, 同样一个脚本,在命令行里的输出, 和把这个脚本放在crontab里执行的输出,竟然不一样...........

PS:我在suse 10 enterprise 和 fedora 8上都做了试验, 得到的现象是一样的。
想了很久,也没想明白到底是为什么, 大侠们出来解解惑哦.........多谢了先

论坛徽章:
0
2 [报告]
发表于 2008-07-04 14:41 |只看该作者
脚本加上export LANG="xx"这样的语言环境行不行呢?

论坛徽章:
0
3 [报告]
发表于 2008-07-04 14:43 |只看该作者
直接ls不是文件名了么

论坛徽章:
0
4 [报告]
发表于 2008-07-04 14:44 |只看该作者
会不会默认的shell不是bash

论坛徽章:
0
5 [报告]
发表于 2008-07-04 14:50 |只看该作者
原帖由 uinion 于 2008-7-4 14:41 发表
脚本加上export LANG="xx"这样的语言环境行不行呢?


嗯,确实是LANG环境变量的问题导致的,我刚刚在cron.sh里加了
echo $LANG  在日志里输出为空, 而我在命令行里输出的我 en_US.UTF-8

刚刚在cron.sh 里加上 export LANG="en_US.UTF-8"之后
看看cron.log 输出的前后对比,结果已经出来了:),hoho

    #此为echo $LANG打印出空的东东
total 64
-rw-rw-r-- 1 xyz xyz 2432 Jun 16 17:34 a.txt
-rw-rw-r-- 1 xyz xyz 1577 Jun 13 22:51 allow_ip
-rw-rw-r-- 1 xyz xyz 1752 Jun 13 22:58 allow_ip_new.txt
-rw-rw-r-- 1 xyz xyz 1577 Jun 16 17:29 httpd.conf
-rw-rw-r-- 1 xyz xyz 1576 Jun 16 17:33 httpd.conf.new
-rw-rw-r-- 1 xyz xyz  314 Jun 18 16:40 live.txt
drwxrwxr-x 2 xyz xyz 4096 Jun 17 00:55 new
-rw-rw-r-- 1 xyz xyz 2588 Jun 13 22:53 new_ip
en_US.UTF-8  #此为echo $LANG在export LANG之后打印出的东东
total 64
-rw-rw-r-- 1 xyz xyz 1577 2008-06-13 22:51 allow_ip
-rw-rw-r-- 1 xyz xyz 1752 2008-06-13 22:58 allow_ip_new.txt
-rw-rw-r-- 1 xyz xyz 2432 2008-06-16 17:34 a.txt
-rw-rw-r-- 1 xyz xyz 1577 2008-06-16 17:29 httpd.conf
-rw-rw-r-- 1 xyz xyz 1576 2008-06-16 17:33 httpd.conf.new
-rw-rw-r-- 1 xyz xyz  314 2008-06-18 16:40 live.txt

可以前后对比看到输出的时间格式改变了:)

不过uinion大侠能不能解释下其中的原因呢, ls -l 还根据LANG这个环境变量的不同,来做不同的输出么???

论坛徽章:
0
6 [报告]
发表于 2008-07-04 14:51 |只看该作者
原帖由 napfy 于 2008-7-4 14:43 发表
直接ls不是文件名了么


如果是我,我也直接ls了, 但是刚刚是在看人家的脚本..............把ls -l | awk '{print $9}'拷贝到命令行来执行,打印出一片空白行................

论坛徽章:
0
7 [报告]
发表于 2008-07-04 16:55 |只看该作者
原帖由 king_boss 于 2008-7-4 14:51 发表


如果是我,我也直接ls了, 但是刚刚是在看人家的脚本..............把ls -l | awk '{print $9}'拷贝到命令行来执行,打印出一片空白行................


呵呵,其实我也不知道的。我只是之前试过写一些脚本,直接用./xxxxxx.sh的方式执行是正常的,但加到crontab里定时运行就不行了。后来还是要在脚本前加export XXXX这样加载bash的环境才正常的。

论坛徽章:
0
8 [报告]
发表于 2008-07-04 16:57 |只看该作者
QJ不成反被C      
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP