文档章节

log4js日志

c
 caiyezi
发布于 2016/11/08 20:24
字数 919
阅读 15
收藏 0

安装log4js:npm install log4js

express中配置log4js中间件:

var log = require("./modules/utils/logUtil.js");
log.use(app);

logUtil工具类:

/**
 * Created by Administrator on 2015/9/8.
 */
"use strict";

var helper = {};
var log4js = require('log4js');
var fs = require("fs");
var path = require("path");
var dbOperate = require("./dbUtil.js");
helper.levels = {
    FATAL: log4js.levels.FATAL,
    ERROR: log4js.levels.ERROR,
    WARN: log4js.levels.WARN,
    DEBUG: log4js.levels.DEBUG,
    INFO: log4js.levels.INFO
};
helper.config =
{
    "appenders": [
        {
            "type": "console",
            "category": "console"
        },
        {
            "filename": "logs/",
            "pattern": "yyyyMMdd.log",
            "category": "logInfo",
            "type": "dateFile",
            "alwaysIncludePattern": true,
            "level":"INFO"
        }
    ],
    "replaceConsole": true
};

// 加载配置文件
//var objConfig = JSON.parse(fs.readFileSync(path.join(__dirname + "/config"), "utf8"));
log4js.configure(helper.config);
var logInfo = log4js.getLogger('logInfo');
var name = null;

/**
 * 日志保存
 * @param req   request请求,用于获取ip、url等信息
 * @param operateType   操作类型,例如:0000-登录,1111-退出
 * @param operateData   被操作的数据
 * @param category  日志类别(日志模块类别)
 * @param results   操作结果
 * @param msg   log信息
 * @param logLevel     日志level:详见helper.levels
 */
helper.saveLogFile = function (req, operateType,operateData, category, results, msg, logLevel) {
    var logLevel = logLevel.toString();
    var conf =
    {
        "appenders": [
            {
                "type": "console",
                "category": "console"
            },
            {
                "filename": "logs/",
                "pattern": "yyyyMMdd.log",
                "category": category,
                "type": "dateFile",
                "alwaysIncludePattern": true,
                "level":logLevel
            }
        ],
        "replaceConsole": true
    };
    log4js.configure(conf);
    name = log4js.getLogger(category);
    if (msg == null)
        msg = "";
    var username;
    if(typeof req.session.user != "undefined"){
        username = req.session.user.username;
    }else{
        username = req.body.username;
    }
    switch (logLevel) {
        case 'ERROR':
            name.error("msg:" + msg +  "user:" + username + "ip:" + req.ip + " url:" + req.originalUrl + " operateType:" + operateType +  " operateData:"
                + operateData + " results:" + results + " User-Agent:" + req.get("User-Agent"));
            break;
        case 'WARN':
            name.warn("msg:" + msg + " user:" + username + " ip:" + req.ip + " url:" + req.originalUrl + " operateType:" + operateType + " operateData:"
                + operateData + " results:" + results + " User-Agent:" + req.get("User-Agent"));
            break;
        case 'DEBUG':
            name.debug("msg:" + msg + " user:" + username + " ip:" + req.ip + " url:" + req.originalUrl + " operateType:" + operateType + " operateData:"
                + operateData + " results:" + results + " User-Agent:" + req.get("User-Agent"));
            break;
        case 'FATAL':
            name.fatal("msg:" + msg + " user:" + username + " ip:" + req.ip + " url:" + req.originalUrl + " operateType:" + operateType + " operateData:"
                + operateData + " results:" + results + " User-Agent:" + req.get("User-Agent"));
            break;
        default:
            name.info("msg:" + msg + " user:" + username + " ip:" + req.ip + " url:" + req.originalUrl + " operateType:" + operateType + " operateData:"
                + operateData + " results:" + results + " User-Agent:" + req.get("User-Agent"));
            break;
    }
};

/**
 * 日志保存
 * @param req   request请求,用于获取ip等信息
 * @param operateType   操作类型,例如:0000-登录,1111-退出
 * @param operateData   被操作的数据
 * @param category  日志类别(日志模块类别)
 * @param results   操作结果
 * @param msg   log信息
 * @param logLevel     日志level:info、debug、warn、error、fatal 0-5
 */
helper.saveLog = function (req, operateType, operateData, category, results, msg, logLevel) {
    var username;
    if(typeof req.session.user != "undefined"){
        username = req.session.user.username;
    }else{
        username = req.body.username;
    }
    var logData = {
        'category': category,
        'username': username,
        'agent': req.get("User-Agent"),
        'operateType': operateType,
        'ip': req.ip,
        'operateData': operateData,
        'url': req.originalUrl,
        'results': results,
        'msg': msg,
        'logLevel': logLevel
    };
    dbOperate.insert(logData, "dbo.sysLog", function (results) {
        console.log(results);
    }, "");
};

// 配合express用的方法
exports.use = function (app) {
    //页面请求日志, level用auto时,默认级别是WARN
    app.use(log4js.connectLogger(logInfo, {level: 'INFO'}));        //, format:':method :url'
};

exports.helper = helper;

其中helper.config里面配置log4js:

appenders:数组对象,表示log输出的路径,每一个元素都是一个appender,主要包括:console-控制台输出、dateFile-根据日期配置自动生成当前日期下的日志、file-纯粹在一个文件中输出

type:日志输出类型 pattern:日志输出格式 category:日志类别 alwaysIncludePattern:是否始终以pattern指定格式输出日志 level:日志输出级别 replaceConsole:是否以log4js格式在控制台输出控制台自身log

输出log目录(log目录必须手动先行创建):

log内容:

[2015-09-09 17:46:20.421] [INFO] logInfo - ::1 - - "GET /javascripts/jquery-easyui-1.4.3/themes/default/images/calendar_arrows.png HTTP/1.1" 304 - "http://localhost:3000/javascripts/jquery-easyui-1.4.3/themes/default/easyui.css" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:26.350] [INFO] logInfo - ::1 - - "POST /user/add HTTP/1.1" 200 16 "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:26.452] [INFO] logInfo - ::1 - - "POST /user/list HTTP/1.1" 200 1966 "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:28.872] [INFO] logInfo - ::1 - - "POST /user/list HTTP/1.1" 200 606 "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:28.883] [INFO] logInfo - ::1 - - "GET /upload/0.3529507869388908.png HTTP/1.1" 304 - "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:28.884] [INFO] logInfo - ::1 - - "GET /upload/0.09649713477119803.png HTTP/1.1" 304 - "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"
[2015-09-09 17:46:28.892] [INFO] logInfo - ::1 - - "GET /upload/0.4691608641296625.png HTTP/1.1" 200 27561 "http://localhost:3000/user/userManage.html" "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.6 Safari/537.36"

数据库中log表内容:

本文转载自:http://www.cnblogs.com/vipzhou/p/4798754.html

共有 人打赏支持
上一篇: nodejs图片上传
下一篇: js生成6位随机码
c
粉丝 1
博文 108
码字总数 0
作品 0
西安
程序员
私信 提问
玩转 Nodejs 日志管理 log4js

前言 日志对任何的应用来说都是至关重要的。在Nodejs中使用express框架并没有自带的日志模块,我们可以选择log4js来完成日志记录的功能。 如果用过JAVA中log4j的同学,肯定对日志并不陌生,学...

红薯
2014/05/13
5.7K
3
nodejs开发——log4js学习

版权声明:本文为博主原创文章,欢迎分享到其它技术社区,分享请标明出处: https://blog.csdn.net/CHENYUFENG1991/article/details/54809927 在我们开发项目时,日志是必不可少的一部分,有...

乞力马扎罗的雪CYF
2017/02/01
0
0
express+log4js+mongoose+mongoDB完成一个自己的后台篇-----express配置log4js篇

一、安装node.js 安装node.js 这里就不多说 点击 http://nodejs.cn/ 下载安装。 二、初始化一个express项目 全局安装express 在电脑创建一个文件夹,并在文件中打开命令行,输入 项目中需要使...

李康德
2017/11/07
0
0
探索 PM2 Cluster 模式下 Log4js 日志丢失

Node 应用为单线程应用,JS 虽可利用异步 I/O 避免线程阻塞,但无法利用多核 CPU 的优势提升运行效率,提高吞吐量仍需多线程。Node Cluster 可产生多个工作线程共享同一 TCP 连接,主线程通过...

呆恋小喵_sunmy
08/24
0
0
log4js 配置与使用

安装log4js 创建新文件Log4js.js 创建日志目录,并配置log4js 引用创建的Log4js.js模块 参考 http://blog.csdn.net/youbl/article/details/32708609 http://blog.csdn.net/cdnight/article/d......

朝天放歌
2016/11/15
178
0

没有更多内容

加载失败,请刷新页面

加载更多

border实现等高布局

效果图 实现上图效果的全部html+css代码 <div class="box"> <nav> <h3 class="nav">导航1</h3> <h3 class="nav">导航2</h3> </nav> <section> <div cla......

呵呵闯
6分钟前
0
0
MaxCompute 表(Table)设计规范

表的限制项 表(Table)设计规范 表设计主要目标 表设计的影响 表设计步骤 表数据存储规范 按数据分层规范数据生命周期 按数据的变更和历史规范数据的保存 数据导入通道与表设计 分区设计与逻辑...

阿里云云栖社区
12分钟前
0
0
局域网共享文件读写的实现方式

首先是设置共享目录,支持用户和密码等权限控制 然后我们可以使用Windows资源管理器操作共享目录下的文件 这中间隐藏了资源管理器帮我们建立目录映射和连接的过程,如果设置了用户名和密码,...

夏至如沫
21分钟前
2
0
Elasticsearch安装与配置

一、Docker安装ES 开发模式 可以使用以下命令快速启动Elasticsearch以进行开发或测试: $ docker run -p 9200:9200 -p 9300:9300 -d --name es -e "discovery.type=single-node" docker.ela...

吴伟祥
28分钟前
1
0
移动页面滚动穿透解决方案(荐)

移动页面滚动穿透解决方法目前有多种解决方案,我介绍下几种方案: 解决方案1:阻止冒泡。 //关键代码$(".sliders,.modals").on("touchmove",function(event){    event.preventDefau...

壹峰
28分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部