免费注册 查看新帖 |

Chinaunix

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

日志分析:根据用户ID统计在线时长 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-03 16:48 |只看该作者 |倒序浏览
根据[login]判断登陆   [logout]判断登出
[playerid][2095]   playerid后边方括号内的数字为用户ID
统计判断该ID在线时长

请教一下高手,该怎样处理。


[2009-12-03 10:01:09103](LoginManagerImpl.java:229) [ messageReceiveStart [961531:0] [1] +[LoginSystem]] - [login][failed][accountid:961531]
[2009-12-03 10:01:13185](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][25]
[2009-12-03 13:50:55211](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 13:50:55213](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 13:50:55214](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 13:50:57309](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 14:20:20104](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 14:20:20105](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 14:20:20105](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 14:21:26465](LoginManagerImpl.java:229) [ messageReceiveStart [961531:0] [1] +[LoginSystem]] - [login][failed][accountid:961531]
[2009-12-03 14:21:28464](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 14:52:15782](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 14:52:15783](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 14:52:15784](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [10] +[BagMessageProcessManager]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 14:52:47172](LoginManagerImpl.java:229) [ messageReceiveStart [961531:0] [1] +[LoginSystem]] - [login][failed][accountid:961531]
[2009-12-03 14:52:48882](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 14:52:59738](LoginManagerImpl.java:229) [ messageReceiveStart [tester110:0] [1] +[LoginSystem]] - [login][failed][accountid:tester110]
[2009-12-03 14:53:05224](LoginManagerImpl.java:205) [ messageReceiveStart [tester110:2730] [1] +[LoginSystem]] - [login][enterWorld][accountid][tester110][playerid][2730][name][能见度][career][战士][level][80]
[2009-12-03 15:11:33544](LoginManagerImpl.java:183) [ messageReceiveStart [tester110:2730] [1] +[LoginSystem]] - [logout][accountid][tester110][playerid][2725][name][苔丝特][career][战士][level][1]
[2009-12-03 15:11:33545](LoginManagerImpl.java:183) [ messageReceiveStart [tester110:2730] [1] +[LoginSystem]] - [logout][accountid][tester110][playerid][2730][name][能见度][career][战士][level][80]
[2009-12-03 15:11:33620](LoginManagerImpl.java:183) [ messageReceiveStart [tester110:2730] [1] +[LoginSystem]] - [logout][accountid][tester110][playerid][2729][name][雨夹雪][career][法师][level][80]
[2009-12-03 15:11:34983](LoginManagerImpl.java:205) [ messageReceiveStart [tester110:2725] [1] +[LoginSystem]] - [login][enterWorld][accountid][tester110][playerid][2725][name][苔丝特][career][战士][level][1]
[2009-12-03 15:13:10239](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [5] +[CombatSystem]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 15:13:10240](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [5] +[CombatSystem]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 15:13:10241](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:2736] [5] +[CombatSystem]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 15:46:52136](LoginManagerImpl.java:229) [ messageReceiveStart [961531:0] [1] +[LoginSystem]] - [login][failed][accountid:961531]
[2009-12-03 15:46:53738](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 15:57:31679](LoginManagerImpl.java:183) [ messageReceiveEnd [tester110:2725] [3] +[PlayerSystem]] - [logout][accountid][tester110][playerid][2725][name][苔丝特][career][战士][level][1]
[2009-12-03 15:57:31698](LoginManagerImpl.java:183) [ messageReceiveEnd [tester110:2725] [3] +[PlayerSystem]] - [logout][accountid][tester110][playerid][2730][name][能见度][career][战士][level][80]
[2009-12-03 15:57:31699](LoginManagerImpl.java:183) [ messageReceiveEnd [tester110:2725] [3] +[PlayerSystem]] - [logout][accountid][tester110][playerid][2729][name][雨夹雪][career][法师][level][80]
[2009-12-03 16:16:16689](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 16:16:16690](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 16:16:16691](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 16:16:18260](LoginManagerImpl.java:205) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [login][enterWorld][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 16:22:40970](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 16:22:40970](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 16:22:40971](LoginManagerImpl.java:183) [ messageReceiveStart [961531:2736] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 16:22:42495](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:0] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2088][name][小小英雄][career][法师][level][80]
[2009-12-03 16:22:42496](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:0] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2095][name][79帅哥][career][战士][level][70]
[2009-12-03 16:22:42497](LoginManagerImpl.java:183) [ messageReceiveEnd [961531:0] [1] +[LoginSystem]] - [logout][accountid][961531][playerid][2736][name][MINI][career][战士][level][26]
[2009-12-03 16:22:49333](LoginManagerImpl.java:229) [ messageReceiveStart [96153c:0] [1] +[LoginSystem]] - [login][failed][accountid:96153c]
[2009-12-03 16:23:23488](LoginManagerImpl.java:205) [ messageReceiveStart [96153c:2732] [1] +[LoginSystem]] - [login][enterWorld][accountid][96153c][playerid][2732][name][任务享][career][法师][level][8]

[ 本帖最后由 nblity 于 2009-12-3 16:51 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
2 [报告]
发表于 2009-12-03 17:05 |只看该作者
login logout 不配对的怎么处理?

论坛徽章:
0
3 [报告]
发表于 2009-12-03 17:34 |只看该作者

回复 #2 ly5066113 的帖子

只有login没有logout的,截止到当天23:59
没有login只有logout的,从00:00起计算

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
4 [报告]
发表于 2009-12-03 17:59 |只看该作者

回复 #3 nblity 的帖子

try:

  1. $ cat test.awk
  2. #! /usr/bin/awk -f

  3. BEGIN {
  4.         FS = "[][]"
  5. }

  6. /login/ && ! /failed/ {
  7.         a[$22] = d2s($2)
  8. }
  9. /logout/ {
  10.         c[$20] = d2s($2)

  11.         if(a[$20])
  12.         {
  13.                 b[$20] += c[$20] - a[$20]
  14.         }
  15.         else
  16.         {
  17.                 b[$20] += c[$20] - d2s(substr($2, 1, 10)" 00:00:00")
  18.         }
  19. }
  20. END {
  21.         for(i in a)
  22.         {
  23.                 if(c[i] < a[i])
  24.                 {
  25.                         b[i] = d2s(strftime("%Y %m %d", a[i])" 23:59:59") - a[i]
  26.                 }
  27.         }
  28.         for(i in b)
  29.         {
  30.                 print i, b[i]
  31.         }
  32. }

  33. function d2s(d)
  34. {
  35.         gsub(/[-:]/, " ", d)
  36.         s = mktime(substr(d, 1, 19))
  37.         return s
  38. }
  39. $ awk -f test.awk urfile
  40. 2730 4974
  41. 2732 27396
  42. 2095 386298
  43. 2725 57450
  44. 2088 386298
  45. 2736 21143
  46. 2729 112144
复制代码

[ 本帖最后由 ly5066113 于 2009-12-3 18:00 编辑 ]

论坛徽章:
0
5 [报告]
发表于 2009-12-03 18:16 |只看该作者

回复 #4 ly5066113 的帖子

保存为test.awk
chmod +x test.awk
./test.awk之后
提示信息:
./test.awk: line 1: $: command not found
./test.awk: line 4: BEGIN: command not found
./test.awk: line 5: FS: command not found
./test.awk: line 6: syntax error near unexpected token `}'
./test.awk: line 6: `}'

论坛徽章:
0
6 [报告]
发表于 2009-12-03 18:45 |只看该作者

回复 #5 nblity 的帖子

晕,你不会把第一行的 $ cat test.awk也放进去了吧?

论坛徽章:
0
7 [报告]
发表于 2009-12-03 22:57 |只看该作者
第一行跟最后一行都不放进去?
呵呵,我是做java的,对shell一点都不懂
见笑了,不过正在学习

论坛徽章:
0
8 [报告]
发表于 2009-12-03 23:02 |只看该作者
$ 开头的行不要放进去,就这两个$ 中间的部分就行了,$ 是shell提示符

论坛徽章:
0
9 [报告]
发表于 2009-12-04 09:30 |只看该作者
嗯,明白了
已经测试出结果
谢谢两位
我还得继续研究研究

论坛徽章:
0
10 [报告]
发表于 2009-12-04 14:11 |只看该作者
弱弱的再问一下,怎样让上述代码的结果输出到一个文本文件中呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP