Spring Boot集成syslog快速入门Demo

1.什么syslog?

Syslog-ng是由Balabit IT Security Ltd.维护的一套开源的Unix和类Unix系统的日志服务套件。它是一个灵活的、可伸缩的系统日志记录程序。对于服务器日志集中收集,使用它是一个不错的解决方案。syslog-ng (syslog-Next generation) 是syslog的升级版

Syslog-ng主要特性有:

  • 支持SSL/TSL协议

  • 支持将日志写入数据库中,支持的数据库有MySQL, Microsoft SQL (MSSQL),Oracle, PostgreSQL, and SQLite.

  • 支持标准的syslog协议

  • 支持filter、parse以及rewrite

  • 支持更多的平台

  • 更高的负载能力

2.环境准备

docker-compose.yml

version: '3.6'
services: syslog: image: lscr.io/linuxserver/syslog-ng:latest container_name: syslog-ng
ports: - 514:5514/udp - 601:6601/tcp - 6514:6514/tcp volumes: - ./data/config:/config - ./data/log:/var/log #optional restart: unless-stopped

run

docker-compose -f docker-compose.yml up -d

down

docker-compose -f docker-compose.yml down

3.代码工程

实验目的

实现将springboot应用日志发送到syslog-ng

pom.xml

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0"         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <parent>        <artifactId>springboot-demo</artifactId>        <groupId>com.et</groupId>        <version>1.0-SNAPSHOT</version>    </parent>    <modelVersion>4.0.0</modelVersion>
<artifactId>syslog</artifactId>
<properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-logging</artifactId> </exclusion> </exclusions> </dependency>
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-autoconfigure</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-log4j2</artifactId> </dependency> </dependencies></project>

controller

package com.et.syslog.controller;
import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;import java.util.Map;
@RestControllerpublic class HelloWorldController { private final Logger logger = LoggerFactory.getLogger(HelloWorldController.class);
@RequestMapping("/hello") public Map<String, Object> showHelloWorld(@RequestParam("n") String name){ logger.info("Say hello to {}", name); Map<String, Object> map = new HashMap<>(); map.put("msg", "HelloWorld"); return map; }}

log4j2-spring.xml

<?xml version="1.0" encoding="UTF-8"?><Configuration>    <Appenders>        <Console name="ConsoleAppender" target="SYSTEM_OUT">            <PatternLayout                    pattern="%style{%date{DEFAULT}}{yellow} %highlight{%-5level}{FATAL=bg_red, ERROR=red, WARN=yellow, INFO=green} %message%n"/>        </Console>        <Syslog name="Syslog" format="RFC5424" host="localhost" port="514"                protocol="UDP" appName="liuhaihua.cn" facility="LOCAL0" />    </Appenders>
<Loggers> <Root level="info"> <AppenderRef ref="ConsoleAppender"/> <AppenderRef ref="Syslog"/>
</Root> </Loggers></Configuration>

以上只是一些关键代码,所有代码请参见下面代码仓库

代码仓库

  • https://github.com/Harries/springboot-demo

4.测试

  • 启动spring boot应用

  • 访问http://127.0.0.1:8088/hello?n=niki

  • 查看syslog-ng日志 (/var/log/messages,/var/log/messages-kv.log)

5.引用

  • https://docs.spring.io/spring-integration/reference/syslog.html

  • http://www.liuhaihua.cn/archives/710916.html

相关推荐

  • 揭秘支付对账:确保每一分钱的安全之旅
  • [开源]一个使用简单且功能强大的自动化测试基础框架,操作易上手
  • 发现一个冷门生意:微信有几百个同城好友就能赚钱
  • 豆包的浏览器插件上线了播客和视频总结功能;DomoAI唇形同步功能已升级
  • SpringBoot 自定义启动画面
  • 急缺!高校GPU告急,李飞飞辛顿求救
  • AI引爆计算格局变革,“Arm技术授权订阅”一揽子解决创“芯”焦虑
  • 【议题征集】国际开源及RISC-V人才暨开源技术与生态之旅
  • 国外程序员吃饱了撑的?居然将Windows NT移植到“上古”的苹果麦金塔电脑
  • 这份简历模板确实简洁大方!
  • 上海AI lab开源LLaMAX,用3.5万小时的A100训练让大模型掌握上百种语言翻译
  • OpenAI凌晨发布新研究成果!证明者和验证者无限套娃,大模型黑盒变可解释又近一大步!
  • 看了世界首个AI小姐选美大赛的结果,我开始有点担心未来的择偶市场
  • 8轮融资后,上海明星独角兽要IPO了
  • Google Cloud 在预览版中引入了用于云存储的分层命名空间
  • 图灵奖数据库大师 Stonebraker 师徒对数据库近 20 年发展与展望的 2 万字论文
  • 别找啦!AIGC+金融场景的绝佳案例都在这!| FCon
  • 2024 可信数据库发展大会圆满落幕,共探数据库技术新未来!
  • 开源独角兽 GitLab 走上“卖身”路!前工程师拆台:赚钱的业务不好好运营,开发了一堆没用的功能
  • OpenAI 封了中国 API 后,国外开发者却先转向了 Claude