
Security News
RubyGems Adds Cooldown Feature to Bundler for Newly Published Gems
RubyGems and Bundler 4.0.13 introduced an opt-in cooldown feature that delays newly published gems during dependency resolution.
fastify-logger
Advanced tools
bnpm install fastify-logger --save
//
let logOpt = {
console: process.env.NODE_ENV !== 'production', // 是否开启console.log 。。。
level: 'debug',
streams: [], // fastify-logger/lib/LogStream.js 的子类
format: function(data) {}, // 自定义format
genReqId: (function(){ // 请求id生成器
var maxInt = 2147483647
var nextReqId = 0
return function(req) {
return nextReqId = (nextReqId + 1) & maxInt
}
})(),
serializers: { // 需要的额外数据
req: function(req) {
return {
method: req.xxx
}
}
},
file: path.join(process.cwd(), 'logs/fastify.log'), // 文件路径
maxBufferLength: 4096, // 日志写入缓存队列最大长度
flushInterval: 1000, // flush间隔
logrotator: { // 分割配置
byHour: true,
byDay: false,
hourDelimiter: '_'
}
}
// 其实只需要配置一下 file字段, 因为线上环境,路径不同,不配置的话使用默认路径
logOpt = {
file: '/path/to/log/lalala.log'
}
const {opt, hook} = require('fastify-logger')(logOpt);
const fastify = require('fastify')({
logger: opt
})
hook(fastify);
// Declare a route
fastify.get('/', function(request, reply) {
request.log.info('123412342234', 'wwwwwwwwwwwww', { as: 23 })
reply.send({ hello: 'world' })
})
// Run the server!
fastify.listen(3000, '0.0.0.0', function(err) {
if (err) throw err
console.log(
`server listening on http://${fastify.server.address().address}:${
fastify.server.address().port
}`
)
})
customSteam.js
const LogStream = require('fastify-logger/lib/LogStream')
class CustomStream extends LogStream {
constructor(options) {
super(options)
// ...自己的逻辑代码
}
// 复写log方法
log(data) {
// 想怎么写就怎么写
}
}
FAQs
fastify 框架的logger
We found that fastify-logger demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
RubyGems and Bundler 4.0.13 introduced an opt-in cooldown feature that delays newly published gems during dependency resolution.

Security News
pnpm 11.5 now recognizes npm staged publish approvals in release metadata, preventing those releases from being mistaken for lower-trust package publishes.

Security News
Federal audit finds NIST lacked a plan to clear the NVD backlog, wasted funds on duplicate work, and delayed use of CISA data.