代码拉取完成,页面将自动刷新
console
日志、all.log
、error.log
。json
格式化,打印 console
日志(非 json
)、all.log
(json
格式,可用于 filebeat
收集)。logstash
,打印 console
日志,并将日志输出到 logstash
(建议关闭掉 file
输出)。console
日志。<dependency>
<groupId>net.dreamlu</groupId>
<artifactId>mica-logging</artifactId>
<version>${version}</version>
</dependency>
compile("net.dreamlu:mica-logging:${version}")
配置项 | 默认值 | 说明 |
---|---|---|
mica.logging.console.close-after-start | false | 是否启动完成后将自动关闭控制台日志,默认false。非开发环境建议设置为 true |
mica.logging.files.enabled | true | 是否开启日志文件 all.log 和 error.log |
mica.logging.files.use-json-format | false | 使用 json 格式化(需 logstash-logback-encoder 依赖),设置后文件打印 json 日志,可用于 filebeat 收集日志文件 |
特别注意: 需要配置服务名
和环境
,例如:
spring:
application:
name: mica-test
profiles:
active: dev
json
文件或 logstash
必须添加该依赖!!!<dependency>
<groupId>net.logstash.logback</groupId>
<artifactId>logstash-logback-encoder</artifactId>
<version>${version}</version>
</dependency>
logstash
默认使用的 disruptor
异步,额外还需要添加依赖<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>${version}</version>
</dependency>
配置项 | 默认值 | 说明 |
---|---|---|
mica.logging.logstash.enabled | false | 是否开启 logstash 日志收集,直接收集到 logstash |
mica.logging.logstash.custom-field-map | {} | 自定义字段 key、value 形式。 |
mica.logging.logstash.destinations | localhost:5000 | 目标地址,默认: localhost:5000,示例: host1.domain.com,host2.domain.com:5560 |
mica.logging.logstash.ring-buffer-size | 512 | logstash 队列大小 |
<dependency>
<groupId>com.github.loki4j</groupId>
<artifactId>loki-logback-appender-jdk8</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>com.github.loki4j</groupId>
<artifactId>loki-logback-appender</artifactId>
<version>1.3.2</version>
</dependency>
<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
<version>3.14.9</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.13</version>
</dependency>
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>3.15.1</version>
</dependency>
<dependency>
<groupId>org.xerial.snappy</groupId>
<artifactId>snappy-java</artifactId>
<version>1.1.8.4</version>
</dependency>
配置项 | 默认值 | 说明 |
---|---|---|
mica.logging.loki.enabled | false | 是否开启 loki 日志收集 |
mica.logging.loki.batch-max-bytes | 0 | |
mica.logging.loki.batch-max-items | 1000 | 通用配置 |
mica.logging.loki.batch-timeout-ms | 60000 | |
mica.logging.loki.drain-on-stop | true | |
mica.logging.loki.encoder | json | 编码方式 Json 或 ProtoBuf |
mica.logging.loki.format-label-pattern | appName=${appName},profile=${profile},host=${HOSTNAME},level=%level,traceId=%X{traceId:-NAN},requestId=%X{requestId:-NAN} |
format 配置 |
mica.logging.loki.format-label-pattern-extend | format 配置扩展格式同 format-label-pattern | |
mica.logging.loki.format-label-pair-separator | , | |
mica.logging.loki.format-label-key-value-separator | = | |
mica.logging.loki.format-label-no-pex | true | |
mica.logging.loki.format-message-pattern | l=%level c=%logger{20} t=%thread %msg %ex | 消息体格式 |
mica.logging.loki.format-sort-by-time | false | |
mica.logging.loki.format-static-labels | false | |
mica.logging.loki.http-auth-username | ||
mica.logging.loki.http-auth-password | ||
mica.logging.loki.http-auth-tenant-id | ||
mica.logging.loki.http-url | http 配置,默认:http://localhost:3100/loki/api/v1/push | |
mica.logging.loki.http-sender | http sender,支持 java11、OKHttp、ApacheHttp,默认: 从项目依赖中查找,顺序 java11 -> okHttp -> ApacheHttp | |
mica.logging.loki.http-connection-timeout-ms | 30000 | |
mica.logging.loki.http-request-timeout-ms | 5000 | |
mica.logging.loki.metrics-enabled | false | 开启 metrics |
mica.logging.loki.send-queue-max-bytes | 41943040 | |
mica.logging.loki.use-direct-buffers | true | 使用堆外内存 |
mica.logging.loki.verbose | false |
2021-03-25 21:03:55.275 INFO 2354 --- [XNIO-1 task-3] n.d.mica.mybatis.logger.SqlLogFilter :
======= Sql Logger ======================
select id, parent_id, title, name, seq , path, permission, component, icon, is_frame , type, cache, hidden, status, remark , created_by, created_at, updated_by, updated_at from sys_menu where type in (0, 1) and hidden = false and status = 0
======= Sql Execute Time: 3.438ms =======
{"loggingLevelRoot":"info","appName":"mica-fast","profile":"dev","level":"INFO","logger_name":"o.s.b.w.e.u.UndertowWebServer","message":"Undertow started on port(s) 8080 (http)","thread_name":"main","@timestamp":"2021-03-25T13:10:34.371Z"}
{
"port" => 57146,
"@version" => "1",
"profile" => "dev",
"logger_name" => "net.dreamlu.mica.mybatis.logger.SqlLogFilter",
"appName" => "mica-fast",
"thread_name" => "XNIO-1 task-3",
"level" => "INFO",
"level_value" => 20000,
"message" => "\n\n======= Sql Logger ======================\nselect id, parent_id, title, name, seq , path, permission, component, icon, is_frame , type, cache, hidden, status, remark , created_by, created_at, updated_by, updated_at from sys_menu where type in (0, 1) and hidden = false and status = 0\n======= Sql Execute Time: 3.438ms =======\n",
"loggingLevelRoot" => "info",
"host" => "localhost",
"requestId" => "d17d635f0a479f01f846199231008ec9",
"@timestamp" => 2021-03-25T13:03:55.275Z
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。