我有一个正在运行的Apache James邮件服务器,但只是将其转换为使用MySQL数据库而不是文件系统。
它创建了(某些)表,但它不会写入它们。这使它无法发送任何邮件。
由于它将与数据库交互并插入用户,我认为我的数据库数据源和用户配置正确...
<data-source name="maildb" class="org.apache.james.util.dbcp.JdbcDataSource">
<driver>com.mysql.jdbc.Driver</driver>
<dburl>jdbc:mysql://127.0.0.1/james</dburl>
<user>xxxx</user>
<password>yyyy</password>
<max>20</max>
</data-source>
但是当我尝试发送电子邮件时,我没有从客户端收到任何错误,但我在任何表中的数据库中都没有得到任何结果。 我得到的只是James控制台上的这个错误......
exception! javax.mail.MessagingException: Exception caught while storing mail Container: ;
nested exception is:
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value: '' for column 'last_updated' at row 1
这是来自mailet log的完整堆栈跟踪...
10/12/14 16:23:18 INFO James.Mailet: Error while storing mail.
javax.mail.MessagingException: Exception caught while storing mail Container: ;
nested exception is:
com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value: '' for column 'last_updated' at row 1
at org.apache.james.mailrepository.JDBCMailRepository.store(JDBCMailRepository.java:764)
at org.apache.james.transport.mailets.ToMultiRepository.storeMail(ToMultiRepository.java:230)
at org.apache.james.transport.mailets.ToMultiRepository.service(ToMultiRepository.java:154)
at org.apache.james.transport.mailets.LocalDelivery.service(LocalDelivery.java:66)
at org.apache.james.transport.LinearProcessor.service(LinearProcessor.java:424)
at org.apache.james.transport.JamesSpoolManager.process(JamesSpoolManager.java:405)
at org.apache.james.transport.JamesSpoolManager.run(JamesSpoolManager.java:309)
at java.lang.Thread.run(Thread.java:745)
Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value: '' for column 'last_updated' at row 1
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2973)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1600)
at com.mysql.jdbc.ServerPreparedStatement.serverExecute(ServerPreparedStatement.java:1129)
at com.mysql.jdbc.ServerPreparedStatement.executeInternal(ServerPreparedStatement.java:681)
at com.mysql.jdbc.PreparedStatement.execute(PreparedStatement.java:803)
at org.apache.commons.dbcp.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:168)
at org.apache.james.mailrepository.JDBCMailRepository.store(JDBCMailRepository.java:752)
10/12/14 16:23:18 INFO James.Mailet: ToRepository: Storing mail Mail1418257398530-1 in dbfile://maildb/deadletter/error
以下是我指定存储库的方式......
<mailet match="All" class="ToRepository">
<repositoryPath> db://maildb/deadletter/error </repositoryPath>
</mailet>
由于它似乎抱怨一个空的last_updated日期时间,我允许该列为null,但这没有帮助。 我不是以任何方式改变java,所以不应该有任何我搞砸了。我甚至都不知道它的日期时间。
有人能看到我错过的东西吗?
答案 0 :(得分:0)
解决:我在Apache bug档案中发现了一个不起眼的帖子,提到添加这个parm ......
<dburl>jdbc:mysql://127.0.0.1/james?useServerPrepStmts=false</dburl>
...到数据源区域。实际上,该帖子说要在这里添加2个parms,但我发现它只接受一个parm。
我不知道我应该如何知道这些参与或他们做了什么,但这使得一切都神奇地起作用。有时使用开源软件会教你更多关于研究而不是编程。