• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MongoDB运行日志实现自动分割的方法实例

    前言

    其实所谓自动分割MongoDB日志文件,就是指Rotate MongoDB log files,即让MongoDB每天(或每个星期,可自定义控制)生成一个日志文件,而不是将MongoDB所有的运行日志都放置在一个文件中,这样每个日志文件都相对较小,定位问题也更容易。

    实现自动分割MongoDB日志的方法可以参考:https://docs.mongodb.com/manual/tutorial/rotate-log-files/

    现在以一个MongoDB实例为例,可以写一个脚本来实现自动分割MongoDB日志

    1、配置MongoDB实例启动参数

    security: 
     keyFile: /usr/local/mongodb/authentication/keyFile 
    sharding: 
     clusterRole: shardsvr 
    replication: 
     replSetName: rs3 
    net: 
     port: 27023 
    storage: 
     dbPath: /data/db_delay_rs3 
    systemLog: 
     path: /data/log_delay_rs3/mongodb.log 
     destination: file 
     logAppend: true 
     logRotate: rename 
    processManagement: 
     fork: true 

    配置MongoDB系统日志保存路径,并配置logRotate参数为rename

    2、编写自动分割MongoDB日志脚本

    #!/bin/bash 
    #Rotate the MongoDB logs to prevent a single logfile from consuming too much disk space. 
     
    app=mongod 
     
    mongodPath=/usr/local/mongodb/bin/ 
     
    pidArray=$(pidof $mongodPath/$app) 
     
    for pid in $pidArray;do 
    if [ $pid ] 
    then 
     kill -SIGUSR1 $pid 
    fi 
    done 
     
    exit 

    :wq保存,并命名为logRotate.sh,保存到目录/data/logRotate/

    3、设置Linux定时任务

    vi /etc/crontab

    在打开的文件底部添加如下内容

    59 23 * * * root /data/logRotate/logRotate.sh 

    :wq保存,表示配置一个定时任务,定时每天23:59以root身份执行脚本/data/logRotate/logRotate.sh,实现定时自动分割MongoDB日志

    至此,就实现了自动分割MongoDB日志,MongoDB每天都会生成一个新的日志文件,日志文件的命名带有标识文件日期的时间戳。

    如下所示:

    mongodb.log  mongodb.log.2016-12-08T15-59-01 mongodb.log.2016-12-13T15-59-01
    mongodb.log.2016-12-06T07-14-10 mongodb.log.2016-12-09T15-59-01 mongodb.log.2016-12-14T15-59-01
    mongodb.log.2016-12-06T15-59-01 mongodb.log.2016-12-10T15-59-01 mongodb.log.2016-12-15T15-59-01
    mongodb.log.2016-12-07T01-54-05 mongodb.log.2016-12-11T15-59-01 mongodb.log.2016-12-16T15-59-01
    mongodb.log.2016-12-07T15-59-01 mongodb.log.2016-12-12T15-59-01

    总结

    以上就是关于MongoDB运行日志自动分割的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

    您可能感兴趣的文章:
    • Docker mongoDB 4.2.1 安装并收集springboot日志的步骤详解
    • MongoDB中4种日志的详细介绍
    • 如何利用MongoDB存储Docker日志详解
    • MongoDB数据库的日志文件深入分析
    • SpringBoot中logback日志保存到mongoDB的方法
    • Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录
    • 深入讲解MongoDB的慢日志查询(profile)
    • 使用MongoDB分析Nginx日志的方法详解
    • Node.js和MongoDB实现简单日志分析系统
    • MongoDB日志文件过大的解决方法
    • 详解MongoDB中的日志模块
    上一篇:centos7防火墙导致java程序访问mongodb3.0.1时报错的问题分析
    下一篇:Mongodb如何开启用户访问控制详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MongoDB运行日志实现自动分割的方法实例 MongoDB,运行,日志,实现,自动,