前言

为了监听一些数据的采集等功能,需要随时监听设备的状态,所以需要运行的时候将日志打入到数据库中。

正文

第一步:

首先是jar包,由于我使用的是springboot,所以,在springboot-starter中已经包含了log4j的jar,不需要再导包,如果不是的话,需要导入log4j的包和mysql-connect的包。

第二步:

接下来是创建log4j的配置文件:log4j.properties配置文件,内容如下(这里只有输入到数据库中的配置,如果同时需要输入到控制台或者文件,请自行配置)

# Define the root logger with appender file
log4j.rootLogger = DEBUG, DB
# Define the DB appender
log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender
# Set JDBC URL
log4j.appender.DB.URL=jdbc:mysql://localhost:3306/test
# Set Database Driver
log4j.appender.DB.driver=com.mysql.jdbc.Driver
# Set database user name and password
log4j.appender.DB.user=root
log4j.appender.DB.password=root
# Set the SQL statement to be executed.
log4j.appender.DB.sql=INSERT INTO LOG (CREATE_TIME,TYPE,SYSTEM,HOST,TOTAL_MEMORY,FREE_MEMORY,TOTAL_DISK,FREE_DISK,CPU_CANUSE,DB_CONNECT,LOCATION,LOG_LEVEL,MESSAGE) VALUES (NOW(),'%X{TYPE}','%X{SYSTEM}','%X{HOST}','%X{TOTAL_MEMORY}','%X{FREE_MEMORY}','%X{TOTAL_DISK}','%X{FREE_DISK}','%X{CPU_CANUSE}','%X{DB_CONNECT}','%l','%p','%m')
# Define the layout for file appender
log4j.appender.DB.layout=org.apache.log4j.PatternLayout

对于上面代码的解释:

第一:写入数据库中日志的时候,可以指定sql语句。比如上面的 insert语句。另外需要指定url,username和password,这样才能正常插入。

第二:插入的表结构可以自己设定,需要和自己的语句对应,否则会插入错误。

第三:我的表结构如下:

DROP TABLE IF EXISTS `log`;
CREATE TABLE `log` (
`ID` int(11) NOT NULL AUTO_INCREMENT,
`CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',
`TYPE` varchar(255) NOT NULL COMMENT '类型:1表示系统信息,2表示日志内容信息',
`SYSTEM` varchar(255) DEFAULT NULL COMMENT '系统类型-位数,当type=1时候启用',
`HOST` varchar(255) DEFAULT NULL COMMENT 'ip,当type=1时候启用',
`TOTAL_MEMORY` varchar(255) DEFAULT NULL COMMENT '总内存量,当type=1时候启用',
`FREE_MEMORY` varchar(255) DEFAULT NULL COMMENT '空闲内存,当type=1时候启用',
`TOTAL_DISK` varchar(255) DEFAULT NULL COMMENT '工作盘总容量,当type=1时候启用',
`FREE_DISK` varchar(255) DEFAULT NULL COMMENT '工作盘剩余容量,当type=1时候启用',
`CPU_CANUSE` varchar(255) DEFAULT NULL COMMENT 'CPU可用百分比,当type=1时候启用',
`DB_CONNECT` varchar(255) DEFAULT NULL COMMENT '连接目标数据库结果,当type=1时候启用',
`LOCATION` varchar(255) DEFAULT NULL,
`LOG_LEVEL` varchar(255) DEFAULT NULL,
`MESSAGE` varchar(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;

第四:插入sql的书写,在书写的时候,必须使用'%X{TYPE}' 来表示你需要插入的时候传入值。特别注意:这里是大些的X,小写的不会识别。

第五:最后一些符号的详情如下

最后是代码了:

import org.apache.log4j.Logger;
import org.apache.log4j.MDC;
import org.hyperic.sigar.*; import java.io.IOException;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.math.BigDecimal;
import java.net.InetAddress;
import java.util.Properties; /**
* @Auther: Administrator
* @Date: 2018/8/20 09:37
* @Description:
*/
public class Config { private static Logger logger = Logger.getLogger(Config.class); public static void main(String[] args) throws IOException, SigarException, Exception {
Properties props = System.getProperties();
InetAddress addr = InetAddress.getLocalHost();
MDC.put("TYPE","1");
MDC.put("HOST",addr.getHostAddress());
MDC.put("SYSTEM",props.getProperty("os.name") + "-" + props.getProperty("os.arch")); Sigar sigar = new Sigar();
Mem mem = sigar.getMem();
MDC.put("TOTAL_MEMORY",new BigDecimal(mem.getTotal() / 1024 /1024 / 1024d).setScale(2,BigDecimal.ROUND_HALF_UP) + "GB");
MDC.put("FREE_MEMORY",new BigDecimal(mem.getFree() / 1024 /1024 / 1024d).setScale(2,BigDecimal.ROUND_HALF_UP) + "GB"); CpuInfo[] infos= sigar.getCpuInfoList();
CpuPerc[] cpuList = sigar.getCpuPercList();
Double totalFree = 0.0d; for (int i = 0; i < infos.length; i++) {// 不管是单块CPU还是多CPU都适用
CpuPerc cpu = cpuList[i];
totalFree += cpu.getIdle();
} MDC.put("CPU_CANUSE",String.valueOf(totalFree/cpuList.length));
FileSystem[] fslist = sigar.getFileSystemList(); String totalDisk = null;
String freeDisk = null;
for (int i = 0; i < fslist.length; i++) {
FileSystem fs = fslist[i];
if (fs.getDevName().contains("E")) {
FileSystemUsage usage = sigar.getFileSystemUsage(fs.getDirName());
if (fs.getType() == 2) {
// 文件系统总大小
MDC.put("TOTAL_DISK",new BigDecimal(usage.getTotal() / 1024d / 1024).setScale(2,BigDecimal.ROUND_HALF_UP) + "GB");
MDC.put("FREE_DISK",new BigDecimal(usage.getFree() / 1024d / 1024).setScale(2,BigDecimal.ROUND_HALF_UP) + "GB");
}
}
}
MDC.put("DB_CONNECT",true);
try{ int[] arr = {1,2,3};
for (int i = 0; i < arr.length + 1 ; i++) {
System.out.println(arr[i]);
}
}catch (Exception e){
logger.error("出现了异常", e);
logger.error("出现异常:" + getExceptionMsg(e));
} } private static String getExceptionMsg(Exception e){
StringWriter sw = new StringWriter();
PrintWriter pw = new PrintWriter(sw, true);
e.printStackTrace(pw);
pw.flush();
sw.flush();
return sw.toString();
}
}

写在最后:需要特别特别注意的是:因为我们要插入数据,很多数据都是自己事先指定的数据,所以,我们得使用MDC来把这些数据放入,然后直接打日志就可以存入数据库中了。

还有:注意导包的时候一定要使用log4j的logger对象,否则可能无法完成日志的插入。

关于slf4j来完成,目前我使用一直无法写入数据库,晚点更新结果。

附录:完整版本的log4j.properties配置文件

log4j.rootLogger = DEBUG,D,I,E,A,DB

log4jFileName = dailywork

log4j.appender.A = org.apache.log4j.ConsoleAppender
log4j.appender.A.Target = System.out
log4j.appender.A.Threshold=debug
log4j.appender.A.layout = org.apache.log4j.PatternLayout
log4j.appender.A.layout.ConversionPattern = %d{yyyy-MM-dd HH\:mm\:ss,SSS}%6p [%F\:%L] - %m%n log4j.appender.I=org.apache.log4j.RollingFileAppender
log4j.appender.I.File=${log4jFileName}_info.log
log4j.appender.I.Threshold=INFO
log4j.appender.I.MaxFileSize = 20MB
log4j.appender.I.MaxBackupIndex = 5
log4j.appender.I.Append=true
log4j.appender.I.layout=org.apache.log4j.PatternLayout
log4j.appender.I.layout.ConversionPattern= %d{yyyy-MM-dd HH\:mm\:ss,SSS}%6p [%F\:%L] - %m%n log4j.appender.D=org.apache.log4j.RollingFileAppender
log4j.appender.D.File=${log4jFileName}_debug.log
log4j.appender.D.Threshold=DEBUG
log4j.appender.D.MaxFileSize = 20MB
log4j.appender.D.MaxBackupIndex = 5
log4j.appender.D.Append=true
log4j.appender.D.layout=org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern= %d{yyyy-MM-dd HH\:mm\:ss,SSS}%6p [%F\:%L] - %m%n log4j.appender.W=org.apache.log4j.RollingFileAppender
log4j.appender.W.File=${log4jFileName}_warn.log
log4j.appender.W.Threshold=WARN
log4j.appender.W.MaxFileSize = 20MB
log4j.appender.W.MaxBackupIndex = 5
log4j.appender.W.Append=true
log4j.appender.W.layout=org.apache.log4j.PatternLayout
log4j.appender.W.layout.ConversionPattern= %d{yyyy-MM-dd HH\:mm\:ss,SSS}%6p [%F\:%L] - %m%n log4j.appender.E=org.apache.log4j.RollingFileAppender
log4j.appender.E.File=${log4jFileName}_error.log
log4j.appender.E.Threshold=ERROR
log4j.appender.E.MaxFileSize = 20MB
log4j.appender.E.MaxBackupIndex = 5
log4j.appender.E.Append=true
log4j.appender.E.layout=org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern= %d{yyyy-MM-dd HH\:mm\:ss,SSS}%6p [%F\:%L] - %m%n log4j.appender.DB=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DB.URL=jdbc:mysql://localhost:3306/test
log4j.appender.DB.driver=com.mysql.jdbc.Driver
log4j.appender.DB.user=root
log4j.appender.DB.password=root
log4j.appender.DB.sql=INSERT INTO LOG (CREATE_TIME,TYPE,SYSTEM,HOST,TOTAL_MEMORY,FREE_MEMORY,TOTAL_DISK,FREE_DISK,CPU_CANUSE,DB_CONNECT,LOCATION,LOG_LEVEL,MESSAGE) VALUES (NOW(),'%X{TYPE}','%X{SYSTEM}','%X{HOST}','%X{TOTAL_MEMORY}','%X{FREE_MEMORY}','%X{TOTAL_DISK}','%X{FREE_DISK}','%X{CPU_CANUSE}','%X{DB_CONNECT}','%l','%p','%m')
log4j.appender.DB.layout=org.apache.

Log4j(一):Log4j将日志信息写入数据库的更多相关文章

  1. Log4J是Apache组织的开源一个开源项目,通过Log4J,可以指定日志信息输出的目的地,如console、file等。Log4J采用日志级别机制,请按照输出级别由低到高的顺序写出日志输出级别。

    Log4J是Apache组织的开源一个开源项目,通过Log4J,可以指定日志信息输出的目的地,如console.file等.Log4J采用日志级别机制,请按照输出级别由低到高的顺序写出日志输出级别. ...

  2. 将不同级别的logging 日志信息写入不同文件

    将不同级别的logging 日志信息写入不同文件 # -*- coding: utf-8 -*- import os import time from logging.handlers import ...

  3. c#.NET中日志信息写入Windows日志中解决方案

    1. 目的应用系统的开发和维护离不开日志系统,选择一个功能强大的日志系统解决方案是应用系统开发过程中很重要的一部分.在.net环境下的日志系统解决方案有许多种,log4net是其中的佼佼者.在Wind ...

  4. log4j+AOP 记录错误日志信息到文件中

    AOP 采用异常通知切入,把指定包的异常记录到日志文件. 先看log4j.properties ,控制台输出的是普通信息, 文件输出的是异常信息. log4j.rootLogger=DEBUG, Co ...

  5. log4j教程 12、日志记录到数据库

    log4j API提供 org.apache.log4j.jdbc.JDBCAppender 对象,它能够将日志信息在指定的数据库. JDBCAppender 配置: Property 描述 buff ...

  6. php之将用户信息写入数据库

    session高级应用将用户信息写入到数据库中 首先建立数据库表 在实验数据库sqldb中建立session表,用于存储数据 在根文件夹下建立须要用到的文件(重点是session,class.php这 ...

  7. 解决在web项目使用log4j中无法将log信息写入文件

    这是log4j.properties中关于的配置 log4j.appender.appender2.File=F:/myeclipseworkspace2/SecondBook2/log/second ...

  8. 怎样借助log4j把日志写入数据库中

            log4j是一个优秀的开源日志记录项目.我们不仅能够对输出的日志的格式自定义,还能够自定义日志输出的目的地,比方:屏幕.文本文件,数据 库,甚至能通过socket输出.本节使用MySQ ...

  9. Log4j写入数据库详解

    log4j是一个优秀的开源日志记录项目,我们不仅可以对输出的日志的格式自定义,还可以自己定义日志输出的目的地,比如:屏幕,文本文件,数据库,甚至能通过socket输出.本节主要讲述如何将日志信息输入到 ...

随机推荐

  1. 牛客国庆集训派对Day7 Solution

    A    Relic Discovery 水. #include <bits/stdc++.h> using namespace std; int t, n; int main() { s ...

  2. ZOJ Monthly, January 2019

    A: Little Sub and Pascal's Triangle Solved. 题意: 求杨辉三角第n行奇数个数 思路: 薛聚聚说找规律,16说Lucas 答案是 $2^p \;\;p 为 n ...

  3. TED #01#

    Laura Vanderkam: How to gain control of your free time 1.我们总是不缺乏时间去做重要的事情,即便我们再忙; “我没时间” 的同义词是“我不想做” ...

  4. SNMP学习笔记之SNMPWALK 命令

    SNMPWALK是一个通过SNMP GET-NEXT类型PDU,实现对目标AGENT的某指定MIB分支信息进行完整提取输出的命令工作. 命令行: snmpwalk [选项] agent [oid] 选 ...

  5. Spring Cloud 开发的一些推荐规划

    1.提供一个统一的 父 pom 依赖    作用:统一版本与引入必要依赖 2.提供一个模板模型. 作用: 开发人员不必关系具体基础启动项 3.提供一个统一基础配置模型 作用: 开发人员不比太过关注与必 ...

  6. __autoload自动加载类

    在使用PHP的OO模式开发系统时,通常大家习惯上将每个类的实现都存放在一个单独的文件里,这样会很容易实现对类进行复用,同时将来维护时也很便利.这也是OO设计的基本思想之一.在PHP5之前,如果需要使用 ...

  7. 使用javascript模拟常见数据结构(二)

    四.链表 每种语言都实现了数组.这种数据结构非常方便,提供了一个便利的[]语法来访问它的元素.然而,这种数据结构有一个缺点:(在大多数语言中)数组的大小是固定的,从数组的起点或中间插入或移除项的成本很 ...

  8. Composite(组合)

    意图: 将对象组合成树形结构以表示“部分-整体”的层次结构.C o m p o s i t e 使得用户对单个对象和组合对象的使用具有一致性. 适用性: 你想表示对象的部分-整体层次结构. 你希望用户 ...

  9. 在多节点上运行分布式Intel Caffe

    一般有2种并行模式:数据并行(Data parallelism)和模型并行(model parallelism). 在模型并行化( model parallelism )方法里,分布式系统中的不同机器 ...

  10. Rails-Treasure chest1 (自定义Model网址;多语言包; 时区设置, TimeZone类; 格式日期时间; 表单单选UI; 表单多选UI;Select2 Plugin)

    自定义Model网址: 随机值网址SecureRandom.base58 多语言包, 包括默认语言设置和user自设置. 时区设置, TimeZone类 ,增加user自选时区功能 格式日期时间: x ...