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

 更新时间:2017年01月21日 11:42:44   作者:逝水-无痕  
这篇文章主要给大家介绍了关于MongoDB运行日志实现自动分割的方法,文中以一个MongoDB实例为例,写了一个脚本来实现自动分割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运行日志自动分割的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

相关文章

  • 详解linux 使用docker安装mongodb方法

    详解linux 使用docker安装mongodb方法

    这篇文章主要介绍了linux 使用docker安装mongodb方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • centos7安装mongo数据库的方法(mongo4.2.8)

    centos7安装mongo数据库的方法(mongo4.2.8)

    这篇文章给大家介绍了centos7安装mongo4.2.8数据库的详细过程,包括mongo数据库安装和启动方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2022-01-01
  • mongodb数据库入门之CURD简单操作示例

    mongodb数据库入门之CURD简单操作示例

    这篇文章主要介绍了mongodb数据库入门之CURD简单操作,结合简单示例形式分析了MongoDB数据库基本的CURD增删改查相关操作技巧与注意事项,需要的朋友可以参考下
    2019-10-10
  • Mongodb增加、移除Shard Server实例

    Mongodb增加、移除Shard Server实例

    这篇文章主要介绍了Mongodb增加、移除Shard Server实例,shard服务器(Shard Server).Shard服务器是存储实际数据的分片,每个Shard可以是一个mongod实例,也可以是一组mongod实例构成的Replica Sets,需要的朋友可以参考下
    2015-01-01
  • Mongodb多键索引中索引边界的混合问题小结

    Mongodb多键索引中索引边界的混合问题小结

    Mongodb为提高数组的查询效率,针对数组构建了多键索引,而Mongodb在应用多键数组查询时,也通过构建,减少数组查询的数值范围,来提高查询性能,本文结合Mongodb官方文档,阐述Mongodb在使用多键索引时的边界优化,感兴趣的朋友一起看看吧
    2024-07-07
  • express+mongoose实现对mongodb增删改查操作详解

    express+mongoose实现对mongodb增删改查操作详解

    这篇文章主要介绍了express+mongoose实现对mongodb增删改查操作,结合实例形式分析了express+mongoose对mongodb增删改查操作基本实现方法与操作注意事项,需要的朋友可以参考下
    2020-05-05
  • mongoDB 4.0事务回滚的辛酸历程探究

    mongoDB 4.0事务回滚的辛酸历程探究

    这篇文章主要给大家介绍了关于mongoDB 4.0事务回滚的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • MongoDB中文学习入门教程(包括安装配置和增删改查)

    MongoDB中文学习入门教程(包括安装配置和增删改查)

    本文主要介绍了MongoDB的基本知识和操作,MongoDB是一种面向文档的无结构化数据库系统,具有灵活性、可扩展性和高性能等优点,安装和配置MongoDB也非常简单,使用MongoDB的API进行操作也非常方便,在实际使用中,MongoDB可以作为常规数据存储或NoSQL解决方案的替代品
    2024-01-01
  • 详解MongoDB的条件查询和排序

    详解MongoDB的条件查询和排序

    MongoDB 提供了丰富的查询功能,包括条件组合、反向查询、查询结果过滤、排序等,借助 MongoDB 多样化的查询方式,可以完成业务上的各类查询需要。
    2021-06-06
  • Java操作MongoDB数据库方法详解

    Java操作MongoDB数据库方法详解

    本文给大家分享的是使用Java操作MongoDB的一些基本方法,包含多种数据库的连接方式,增删改查等方法,非常的实用,有需要的小伙伴可以参考下
    2018-01-01

最新评论