聊一聊坑人的 C# MySql.Data SDK
💡
原文中文,约7700字,阅读约需19分钟。
📝
内容提要
近期MySql.Data驱动导致程序卡死,因其同步方法实为异步包装,造成线程饥饿。建议使用纯异步写法或退回低版本以避免此问题。MySql.Data项目未开issue栏,影响社区反馈。
🎯
关键要点
- MySql.Data驱动导致程序卡死,因其同步方法实为异步包装,造成线程饥饿。
- 早期版本的MySql.Data使用同步方式访问数据库,后续版本保留了同步方法。
- MySql.Data的同步方法实际上是异步方法的包装,容易导致线程饥饿。
- 通过windbg分析发现线程池中线程都处于运行状态,且任务积压严重。
- 故障现象显示线程卡在UpdateAnswerUrl和Open方法中,均为异步转同步实现。
- 解决方法包括使用纯异步写法或退回低版本以避免问题。
- MySql.Data项目在GitHub上未开issue栏,影响社区反馈。
❓
延伸问答
MySql.Data驱动导致程序卡死的原因是什么?
MySql.Data驱动的同步方法实际上是异步方法的包装,导致线程饥饿,从而造成程序卡死。
如何解决MySql.Data驱动导致的线程饥饿问题?
可以使用纯异步写法或退回到低版本的MySql.Data以避免线程饥饿问题。
MySql.Data的早期版本与后续版本有什么不同?
早期版本使用真正的同步方式访问数据库,而后续版本保留了同步方法,但实际上是异步方法的包装。
MySql.Data驱动的同步方法是如何实现的?
MySql.Data的同步方法通过调用异步方法并使用GetAwaiter().GetResult()进行包装实现。
使用MySql.Data时需要注意哪些问题?
需要注意其同步方法可能导致线程饥饿,建议使用纯异步写法或使用低版本。
MySql.Data项目在GitHub上有什么问题?
MySql.Data项目在GitHub上未开issue栏,影响了社区反馈和开发者的介入。
➡️