使用Log4cxx日志输出至MySQL, 无法找到驱动错误 20C

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

1个回答

配置中的数据库连接字符串是否正确

Lock_Love_
HotCook 居然不提供修改 ‘/etc/odbc.ini 和 /etc/odbcinst.ini 应该没有错误’
接近 5 年之前 回复
Lock_Love_
HotCook /etc/odbc.ini 和 /etc/odbcinst.ini 的应该大的错误,可以使用isql进行连接。 log4cxx.xml 是根据google搜到,一位网友blog提供配置文件版本的修改(几乎一样的内容)^_^ 不知道你说的配置是哪个位置 谢谢你的回复.
接近 5 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐