zoukankan      html  css  js  c++  java
  • log4j配置目标到mongodb

    首先,具体采用什么技术作为集中式存储方案在99%的应用中应该来说并没有多大区别,最重要的是要定期清理不必要的日志,以及日志格式设计(也可以重写org.log4mongo.MongoDbPatternLayoutAppender.append())的在出现问题时能够方便地查找到所有的上下关联的信息、同时考虑搜索message时的性能。对于分布式系统而言尤其如此,其日志通常跨越多个服务器,确保每个环节的日志能够衔接起来才是日志服务器的关键,纯粹的将日志从分散存储归集到集中式存储除了增加系统不稳定性和成本外,没有任何益处。

    因为我们初步采用的mongodb作为存储,故整理如下:

    1、安装mongodb,可从https://www.mongodb.com/download-center#community下载对应的tgz版本,并解压;

    2、使用nohup mongod --dbpath /data/$MONGODB_HOME/db & 启动mongo服务器;

    3、maven增加log4mongo(https://github.com/log4mongo/log4mongo-java)依赖,如下:

            <dependency>
                <groupId>org.log4mongo</groupId>
                <artifactId>log4mongo-java</artifactId>
                <version>0.7.4</version>
            </dependency>

    4、log4j配置如下:

    log4j.rootCategory=INFO, stdout, R, MongoDB
    log4j.appender.MongoDB=org.log4mongo.MongoDbAppender  
    log4j.appender.MongoDB.databaseName=osm-route  #建议应用名称
    log4j.appender.MongoDB.collectionName=log   #随意
    log4j.appender.MongoDB.hostname=localhost
    log4j.appender.MongoDB.port=27017

    如果要配置主从,可按照如下配置:

    log4j.appender.MongoDB.hostname=Server01 Server02  
    log4j.appender.MongoDB.port=27017 27017

     根据实际的运行来看,稳定性不是特别好,建议使用logpool

  • 相关阅读:
    C# 生成随机数
    C#经典机试题(猫叫)
    C#开发微信公众平台-就这么简单(附Demo)(转)
    对于初学者文档应该怎么编写呢?使用什么模板或格式?
    c#基础系列(转)
    如何写软件设计文档(转)
    C# 使用线程池,设置每个线程的执行时间,过了时间强制结束
    C#多线程编程总结
    最全的sublime插件整理
    Node.js安装及环境配置之Windows篇
  • 原文地址:https://www.cnblogs.com/zhjh256/p/6690003.html
Copyright © 2011-2022 走看看