免费注册 查看新帖 |

Chinaunix

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

如何在.sh_history里打上timestamp? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-04-18 12:07 |只看该作者 |倒序浏览
各位好!

AIX/KSH环境,因为系统管理的需求,想能对.sh_history的每一个命令动作都打上时间戳,由一个办法比较笨的是在crontab里写以分钟为周期的date>>.sh_history,但是我想是否能有通过shell脚本实现的精确到秒的时间戳追加呢?

谢谢了!

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2006-04-18 14:37 |只看该作者
1.用BASH或TCSH

2.如果坚持用kornshell,是否考虑在$PROMPT_COMMAND或$PS1上作一下手脚?

[ 本帖最后由 waker 于 2006-4-18 14:38 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2006-04-18 14:39 |只看该作者
原帖由 waker 于 2006-4-18 14:37 发表
1.用BASH或TCSH

2.如果坚持用kornshell,是否考虑在$PROMPT_COMMAND或$PS1上作一下手脚?



请问版主,使用bash如何实现,谢谢。

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
4 [报告]
发表于 2006-04-18 14:44 |只看该作者
bash 3.0+
直接打 history

论坛徽章:
0
5 [报告]
发表于 2006-04-18 15:22 |只看该作者
在以前别区的贴子看到通过脚本也行:
把他们加到.bashrc文件中, source .bashrc 即可。
# === Begin ====
datestamp_history(){
export infodate=`date "+: %c"`
export infohis=`history 1`
echo $infodate' =>; '$infohis >;>; $HOME/.history-timestamp
}
export PROMPT_COMMAND=datestamp_history
# === end =====

但我运行的时候出错。
-bash: /root/.bashrc: line 12: syntax error near unexpected token `;'
-bash: /root/.bashrc: line 12: `echo $infodate' =>; '$infohis >;>; $HOME/.history-timestamp'

什么原因呢?

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
6 [报告]
发表于 2006-04-18 15:27 |只看该作者
>;变>

论坛徽章:
0
7 [报告]
发表于 2006-04-18 15:39 |只看该作者
哈,多谢,现在可以了。刚一下子没看懂。
echo $infodate' => '$infohis >> $HOME/.history-timestamp

论坛徽章:
0
8 [报告]
发表于 2006-04-18 20:58 |只看该作者
谢谢大家!
还是有启发的,我考虑一下能不能移植到KSH里。

论坛徽章:
0
9 [报告]
发表于 2006-04-19 10:06 |只看该作者

回复 1楼 unixboy1106 的帖子

USERIP=`who -m|awk '{print $6}'|awk -F"(" '{print $2}'|awk -F")" '{print $1}'`
export PROMPT_COMMAND='{ date "+: %c;  ${USER} ${USERIP}    `history 1 | { read x cmd; echo "$cmd"; }`"; } >> /var/log/.cmdlog'

把上述加入到/etc/bashrc中即可

论坛徽章:
0
10 [报告]
发表于 2007-03-11 22:17 |只看该作者
还是觉得挺有意义的,但是没有完美的答案,顶起来。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP