设为首页 收藏本站
查看: 1058|回复: 0

[经验分享] 实战6 Nginx的web日志导入到MongoDB数据库

[复制链接]

尚未签到

发表于 2018-10-27 08:01:54 | 显示全部楼层 |阅读模式
#!/bin/bash  
file=/usr/local/nginx/logs/2014/06/access_20140612.log
  
dir=/usr/local/nginx/logs/ng_mongodb
  
function fenxi () {
  
cat $file | awk -F "uid=" '{print $2}' | awk '{print $1}' | grep -v "^$" | awk '{print "\""$0"\""}' > ${dir}/cookieId.log
  
cat $file | awk '{print $4}' | awk '{print "\""$0"\""}' >  ${dir}/ip.log
  
cat $file | awk '{print $1}'| awk '{print "\""$0"\""}' > ${dir}/appKey.log
  
cat $file | awk '{print $2}' | awk -F "[" '{print $2}'| awk '{print "\""$0"\""}' > ${dir}/visitdate.log
  
cat $file | awk -F "\"" '{print $6}'| awk '{print "\""$0"\""}' >  ${dir}/browsertype.log
  
cat $file | awk -F "\"" '{print $4}'| awk '{print "\""$0"\""}' > ${dir}/referer.log
  
cat $file | awk -F "\"" '{print $6}' |awk '{print $1}'| awk '{print "\""$0"\""}'> ${dir}/os.log
  
cat $file | awk -F "\"" '{print $2}' | awk -F "=" '{print $2}'|awk -F "&" '{print $1}'|awk '{print $1}' >${dir}/videoId.log
  
}
  
if [ -f $file ];then
  
        if [ -d $dir ];then
  
                fenxi
  
        else
  
                mkdir $dir
  
                fenxi
  
        fi
  
else
  
        echo "sorry! the directory "/usr/local/nginx/logs/access.log" is not exsit"
  
fi
  
#截取后的日志文件如下
  
[root@AY140514131444517dd8Z ng_mongodb]# ll
  
total 1612
  
-rw-r--r-- 1 root root  42528 Jun 17 18:18 appKey.log
  
-rw-r--r-- 1 root root 330977 Jun 17 18:18 browsertype.log
  
-rw-r--r-- 1 root root 111615 Jun 17 18:18 cookieId.log
  
-rw-r--r-- 1 root root  58954 Jun 17 18:18 ip.log
  
-rw-r--r-- 1 root root  46791 Jun 17 18:18 os.log
  
-rw-r--r-- 1 root root 121244 Jun 17 18:18 referer.log
  
-rw-r--r-- 1 root root 804258 Jun 17 18:18 test1.dat
  
-rw-r--r-- 1 root root  10275 Jun 17 18:18 videoId.log
  
-rw-r--r-- 1 root root  81512 Jun 17 18:18 visitdate.log
  
#然后把以上八个文件汇总成一个文件并用特殊符号分开
  
注意:说到这里,我得感谢 小武的帮忙 paste命令
  
[root@AY140514131444517dd8Z ~]# man paste
  
格式:
  
paste -d -s file1 file2
  
参数
  
    -d:指定不同于空格或tab键的域分隔符。例如用@分隔域,使用- d @
  
    -s:将每个文件合并成行而不是按行粘贴
  
paste的用法:http://os.chinaunix.net/a2008/0921/985/000000985401.shtml
  
#合并到一个文件中并用逗号隔开
  
[root@AY140514131444517dd8Z ~]# paste -d , browsertype.log cookieId.log appKey.log ip.log os.log referer.log videoId.log visitdate.log > test1.dat



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-626941-1-1.html 上篇帖子: 监控开发之用munin来自定义插件监控redis和mongodb 下篇帖子: 数据库高可用架构(MySQL、Oracle、MongoDB、Redis)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表