Hi, guys!
用log4cxx日志框架对log内容输出至数据库(MySQL)一直未成功,不知道是什么步骤出现了问题。希望大伙们能帮帮忙,或者有什么更好的日志系统可以推荐,谢谢各位了。 ^_^
运行环境: Ubuntu 12.04 32bit + Eclipse CDT
log4cxx : apache-log4cxx-0.10.0
log4cxx支持两种ODBC选项(iODBC/unixODBC),这里选择了unixODBC形式进行管理
通过添加选项 ./configure --with-ODBC=unixODBC,编译通过.
之后对unixODBC的驱动和数据源进行配置,可以通过终端 isql log4cxx 成功建立连接
但是代码中使用Log4cxx进行输出的时候一直报下面的错误
log4cxx: Failed to connect to database. - [unixODBC][Driver Manager]Data source name not found, and no default driver specified
怀疑一:
Ecplise中是否没有加环境变量;
查阅ODBC资料,在Eclipse中加入ODBCSYSINI,ODBCINSTINI,ODBCINI变量后,还是没有效果.
怀疑二:
log4cxx配置写的不对;这个有没有什么官方的写法,晕呐!
配置内容:
/etc/odbcinst.ini
[MySQL]
Description = MySQL
Driver = /usr/lib/i386-linux-gnu/odbc/libmyodbc.so
Setup = /usr/lib/i386-linux-gnu/odbc/libodbcmyS.so
FileUsage = 1
/etc/odbc.ini
[log4cxx]
Description = The Database for Logging System
Trace = on
TraceFile = stderr
Driver = MySQL
SERVER = localhost
PORT = 3306
DATABASE = log
USER = root
PASSWORD = 56789
log4cxx.xml
<appender name="OdbcMysqlAppender" class="org.apache.log4j.odbc.ODBCAppender">
<param name="URL"
value="Driver={MySQL};Server=localhost;Database=log;User=root;Password=56789;" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="INSERT INTO logs (message) VALUES ('%d - %c - %p - %m')" />
</layout>
</appender>
<root>
<priority value="all" />
<appender-ref ref="OdbcMysqlAppender" />
</root>
进展: _Time: 20150702_
查看Log4cxx源码,采用数据库方式记录Log,使用的是ODBCAppender src/main/cpp/odbcappender.cpp
作者原先的代码采用的是 SQLxxxW() 进行DriverConnect和SQLExecDirect操作,根据ODBC的描述,有 W 修饰是采用Unicode编码方式。总之我一直陷在这,一直报找不到数据源。于是乎我将 SQLxxxW()
修改成 SQLxxx()
方式的调用,同时将原先SQLWCHAR
修改成对应 SQLCHAR
,即采用非宽字节的操作方式,成功的找到数据源,并且可以进行调用。
不过这就导致了中文的问题了.
疑惑
在odbcinst.ini中配置的Driver确实是libmyodbc5w.so,即驱动使用Unicode方式的呀! (*与之相对应的是libmyodbc5a.so*). 至今还不知道自己是哪里出错,作者不可能毫无依据的就采用 SQLxxxW() 形式进行ODBC连接的吧.
我在ODBCAppender.cpp中添加了
#define SQL_WCHART_CONVERT,否则make的时候过不去, 即
#if !defined(LOG4CXX)
#define LOG4CXX 1
#endif
#include <log4cxx/private/log4cxx_private.h>
#if LOG4CXX_HAVE_ODBC
#if defined(WIN32) || defined(_WIN32)
#include <windows.h>
#endif
#define SQL_WCHART_CONVERT
#include <sqlext.h>
#endif