log4net引用了Mysql.Data.dll,但是就是不能写到mysql数据库的解决办法

这两天遇到log4net写日志到mysql数据库中,有时候在A项目中可以,有时候B项目就有问题,有时候测试环境没问题,到正式部署环境又出问题,经过两天的煎熬,终于理清楚了其中的头绪。

1.配置现状

config文件中log4net配置节









6.8.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />














































 

项目引用的MySql.Data的版本号是:5.1.5.0

本机安装过:C:\Program Files (x86)\MySQL\MySQL Connector Net 6.8.3

各位看官,在这种不堪的环境下,调用log4net写日志到mysql,不成功是理所当然的事儿!!!

 

2.原因分析:

项目启动后,根据配置节connectionType中指定的MySql.Data.dll的版本号,先在bin目录下寻找6.8.5.0的MySql.Data.dll,结果发现bin下没有,就去mysql安装驱动的地方C:\Program Files (x86)\MySQL\MySQL Connector Net 6.8.3寻找,同样也没找到。

最后无法加载该版本的MySql.Data.dll,于是就出现了在调用写日志的时候,就写不成功了。怎样修改日志才能写入成功呢?

 

3.解决办法:

方法一:

修改6.8.5.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" />

为:

那么,系统在加载MySql.Data.dll时,先在bin下寻找版本号为5.1.5.0的MySql.Data.dll。加载成功,故可以成功写入。

 

方法二:

修改

为:

那么,系统在加载MySql.Data.dll时,先在bin下寻找版本号为6.8.3.0的MySql.Data.dll,没有找到,那么去系统的安装目录下找,结果找到,加载成功,故可以成功写入。

 

方法三:

找到版本为6.8.5.0的MySql.Data.dll,然后项目直接引用版本号为6.8.5.0的MySql.Data.dll。也可以成功。

 

综合以上三种方法,最推荐的是项目引用的Dll版本和config文件中log4net的connectionType 节指定的版本一致,就算部署环境变化,log4net写日志到mysql数据库也能正常的工作。

 

同时注意:

项目的版本最好和mysql.data.dll的运行时版本一致,都是基于2.0,3.5或者都是4.0,4.5。

 

你可能感兴趣的:(log4net引用了Mysql.Data.dll,但是就是不能写到mysql数据库的解决办法)