log4j JDBCAppender rotate table name

前端 未结 3 1689
旧巷少年郎
旧巷少年郎 2021-01-22 13:31

I have successfully configured an application that uses log4j for it\'s logging to log into a MySQL database. (Using org.apache.log4j.jdbc.JDBCAppender).

I also have som

相关标签:
3条回答
  • 2021-01-22 13:40

    I figured out how to do this:

    log4j.appender.SQ=org.apache.log4j.jdbc.JDBCAppender
    log4j.appender.SQ.Driver=com.mysql.jdbc.Driver
    log4j.appender.SQ.URL=jdbc:mysql://localhost:3306/logs
    log4j.appender.SQ.sql=INSERT INTO accesslog_%d{yyyy_MM} (date, time, tz, ...
    

    It appears you can just put date format strings into the SQL statement, and JDBCAppender will expand them and log into the coresponding table.

    However, it will not create new tables at the start of the new month, so currently I have to manualy create the tables beforehand, which is far from ideal.

    0 讨论(0)
  • 2021-01-22 13:53

    You'd have to write your own appender to do this.

    Another option would be to stay with the existing appender and do this:

    You have a table in your database named log. Why not make a Perl script that makes a new table at end of every month, let's say log_12 for December, copies everything from log to log_12 and then delete everything from log? That way you don't have to mess around with making another appender.

    0 讨论(0)
  • 2021-01-22 14:02

    How about a script to run monthly and dump that particular table into a back up file and then zip it for archiving. Upon complete, truncate the table or delete rows within date range.

    0 讨论(0)
提交回复
热议问题