nodejs+express使用log4js总结

为方便定位问题,推荐大家使用log4js组件

目前已实现如下功能:

1、运行日志run.log,每一个最大8M,最多5个,循环覆盖。

2、错误日志error.log,每一个最大8M,最多10个,循环覆盖。

3、不再使用日志文件名,日期文件名无法解决文件过大,且时间长了需要手工清理。

配置文件log4js_config.js

module.exports = {
  appenders: {
    console: {
      "type": "console",
      "category": "console"
    },
    everything: {
      type: "file",
      filename: "log/run.log",
      //最大文件大小,按字节计算 1024 * 1024 * 8 = 8M 
      //integer (optional) - the maximum size (in bytes) for the log file. If not specified, then no log rolling will happen.
      maxLogSize: 1024 * 1024 * 8,
      //文件保留数量 
      //integer (optional, default value = 5) - the number of old log files to keep during log rolling.
      backups: 5,
      keepFileExt: true,
      compress: false
    },
    errorFile: {
      type: 'file',
      filename: "log/error.log",
      //最大文件大小,按字节计算 1024 * 1024 * 8 = 8M 
      //integer (optional) - the maximum size (in bytes) for the log file. If not specified, then no log rolling will happen.
      maxLogSize: 1024 * 1024 * 8,
      //文件保留数量 
      //integer (optional, default value = 5) - the number of old log files to keep during log rolling.
      backups: 10,
      keepFileExt: true,
      compress: false
    },
    errors: { type: 'logLevelFilter', level: 'error', appender: 'errorFile' }
  },
  "categories": {
    "default": {
      "appenders": [
        "everything",
        "errors",
        "console"
      ],
      //设置日志记录级别,记录当前级别及以后 ALL < TRACE < DEBUG < INFO < WARN < ERROR < FATAL < MARK < OFF
      //调试时可以设置为all,线上可设置为INFO
      "level": "INFO"
    }
  },
  //若您的 app 使用了 pm2,则这里必须设置为true,否则日志将不会工作(另外您还得下载 pm2-intercom作为 pm2模块: pm2 install pm2-intercom)
  "pm2": true,
  //(默认 ‘NODE_APP_INSTANCE’):如果您使用pm2并更改了默认名称,则这里必须要设置。
  // pm2InstanceVar: 'INSTANCE_ID',
  //使用的 log4js 忽略集群环境(clustered environments)或者你在 pm2 日志中遇到了麻烦。每一个工作进程都将进行自己的日志记录。请小心使用这里如果你要把日志记录输出到文件。
  // disableClustering: true,
  "replaceConsole": true
};

 

app.js中增加

var path = require('path');
var log4js = require('log4js');
var log4js_config = require('./config/log4js_config');

 

//接管console日志,自动区分类别
log4js.configure(log4js_config);
const loggerOfConsole = log4js.getLogger('console');
console.log = loggerOfConsole.info.bind(loggerOfConsole); // do the same for others - console.debug, etc.
console.debug = loggerOfConsole.info.bind(loggerOfConsole);

app.use(log4js.connectLogger(loggerOfConsole, { level: 'auto' }));
//app.use(log4js.connectLogger(log4js.getLogger("http"), { level: 'auto' }));
//log4js.replaceConsole(log4js.getLogger("db"));

 

记录日志的代码:

var log = log4js.getLogger(path.basename(__filename));
log.info('app start...');
// log.trace('log trace test');
// log.debug('log debug test');
// log.info('log info test');
// log.warn('log warn test');
// log.error('log error test');
// log.fatal('log fatal test');
console.log('请在程序运行目录下查看log4js日志');//这里打一个console.log是为了让程序调试时,运行时,或者在pm2里,能够得一个提示,如果不输出任何信息可能会被识以为未启动,因为log4js可能已经接管了console。

 可以微信联系我哦

 

 

以下是一个基于 NodejsExpress 和 EJS 的分页查询实现示例: 首先,安装必要的依赖: ``` npm install express ejs mongoose express-flash express-session ``` 然后,创建一个名为 `app.js` 的文件,引入所需模块: ```javascript const express = require('express'); const mongoose = require('mongoose'); const session = require('express-session'); const flash = require('express-flash'); const bodyParser = require('body-parser'); const app = express(); const port = process.env.PORT || 3000; // 连接 MongoDB 数据库 mongoose.connect('mongodb://localhost:27017/test', {useNewUrlParser: true, useUnifiedTopology: true}); // 定义数据库模型 const Article = mongoose.model('Article', { title: String, content: String, created_at: Date }); // 设置模板引擎和静态文件目录 app.set('view engine', 'ejs'); app.use(express.static(__dirname + '/public')); // 设置 session 和 flash app.use(session({ secret: 'mysecretkey', resave: true, saveUninitialized: true })); app.use(flash()); // 设置 bodyParser app.use(bodyParser.urlencoded({ extended: true })); // 定义路由 app.get('/', async function(req, res) { const perPage = 5; const page = req.query.page || 1; const articles = await Article.find() .skip((perPage * page) - perPage) .limit(perPage); const count = await Article.countDocuments(); const totalPages = Math.ceil(count / perPage); res.render('index', { articles: articles, current: page, pages: totalPages }); }); app.listen(port, function() { console.log('Server listening on port ' + port); }); ``` 在 `views` 文件夹中创建一个名为 `index.ejs` 的文件,用于显示分页数据: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>分页查询</title> </head> <body> <h1>文章列表</h1> <% if (articles.length > 0) { %> <ul> <% articles.forEach(function(article) { %> <li><%= article.title %></li> <% }); %> </ul> <% } else { %> <p>没有文章。</p> <% } %> <% if (pages > 1) { %> <div class="pagination"> <ul> <% if (current == 1) { %> <li class="disabled"><span>«</span></li> <% } else { %> <li><a href="?page=<%= current - 1 %>">«</a></li> <% } %> <% for (var i = 1; i <= pages; i++) { %> <% if (i == current) { %> <li class="active"><span><%= i %></span></li> <% } else { %> <li><a href="?page=<%= i %>"><%= i %></a></li> <% } %> <% } %> <% if (current == pages) { %> <li class="disabled"><span>»</span></li> <% } else { %> <li><a href="?page=<%= current + 1 %>">»</a></li> <% } %> </ul> </div> <% } %> </body> </html> ``` 在上面的示例中,我们使用了 `mongoose` 连接 MongoDB 数据库,并定义了一个名为 `Article` 的数据库模型。在路由中,我们使用 `await` 关键字来等待查询结果,并通过 `skip()` 和 `limit()` 方法来实现分页查询。在视图中,我们使用 EJS 模板引擎来生成分页链接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大鹏展翅888

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值