首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >此MySqlConnection已在使用中

此MySqlConnection已在使用中
EN

Stack Overflow用户
提问于 2018-12-05 16:23:48
回答 2查看 5.3K关注 0票数 4

我用Hangfire创建了一个RecurringJob,但当作业完成时,我得到了以下错误:

代码语言:javascript
复制
ERROR 2018-12-05 15:20:05,982 [fc937] Hangfire.AutomaticRetryAttribute - Failed to process the job '81': an exception occurred.
System.InvalidOperationException: This MySqlConnection is already in use.   See https://fl.vu/mysql-conn-reuse
at MySqlConnector.Core.ServerSession.StartQuerying(MySqlCommand command) in    C:\projects\mysqlconnector\src\MySqlConnector\Core\ServerSession.cs:line 149
at MySqlConnector.Core.TextCommandExecutor.ExecuteReaderAsync(String commandText, MySqlParameterCollection parameterCollection, CommandBehavior  behavior, IOBehavior ioBehavior, CancellationToken cancellationToken) in C:\projects\mysqlconnector\src\MySqlConnector\Core\TextCommandExecutor.cs:line 33
at MySql.Data.MySqlClient.MySqlCommand.ExecuteNonQueryAsync(IOBehavior ioBehavior, CancellationToken cancellationToken) in C:\projects\mysqlconnector\src\MySqlConnector\MySql.Data.MySqlClient\MySqlCommand.cs:line 261
at MySql.Data.MySqlClient.MySqlTransaction.CommitAsync(IOBehavior ioBehavior, CancellationToken cancellationToken) in C:\projects\mysqlconnector\src\MySqlConnector\MySql.Data.MySqlClient\MySqlTransaction.cs:line 25
at MySql.Data.MySqlClient.MySqlTransaction.Commit() in C:\projects\mysqlconnector\src\MySqlConnector\MySql.Data.MySqlClient\MySqlTransaction.cs:line 12
at Microsoft.EntityFrameworkCore.Storage.RelationalTransaction.Commit()
at Abp.EntityFrameworkCore.Uow.DbContextEfCoreTransactionStrategy.Commit() in D:\Github\aspnetboilerplate\src\Abp.EntityFrameworkCore\EntityFrameworkCore\Uow\DbContextEfCoreTransactionStrategy.cs:line 66
at Abp.EntityFrameworkCore.Uow.EfCoreUnitOfWork.CommitTransaction() in D:\Github\aspnetboilerplate\src\Abp.EntityFrameworkCore\EntityFrameworkCore\Uow\EfCoreUnitOfWork.cs:line 92
at Abp.Domain.Uow.UnitOfWorkBase.Complete() in D:\Github\aspnetboilerplate\src\Abp\Domain\Uow\UnitOfWorkBase.cs:line 256
at Abp.Domain.Uow.UnitOfWorkInterceptor.PerformSyncUow(IInvocation invocation, UnitOfWorkOptions options) in D:\Github\aspnetboilerplate\src\Abp\Domain\Uow\UnitOfWorkInterceptor.cs:line 68
at Castle.DynamicProxy.AbstractInvocation.Proceed()

代码如下:

代码语言:javascript
复制
public class TestJob : ITransientDependency
{
    private readonly IDapperRepository<Customer> _customerDapperRepository;
    private readonly IRepository<Customer> _customerRepository;
    private readonly IRepository<User, long> _userRepository;
    public TestJob(...)
    {
     ...
    }
    [UnitOfWork]
    [AutomaticRetry(Attempts = 0)]
    public virtual void ExecuteJob()
    {
       var someCustomerList = GetSomeCustomerList();
       foreach (var customer in someCustomerList )
       {
          //do some db operations
       }
    }
    private List<Customer> GetSomeCustomerList()
    {
       //get some Customer with conditions
    }
}

上面的代码在调试过程中没有报告错误,我搞不懂哪里出了问题。

EN

回答 2

Stack Overflow用户

发布于 2019-03-12 22:33:55

如果您像我一样使用异步编程,请确保在流程中不是使用async Task往返DB,而是在不使用Task的情况下进行新的DB异步往返,当我注意到并更改了我的代码时,它已修复

票数 3
EN

Stack Overflow用户

发布于 2019-03-13 00:49:53

尽管我不能完全确定发生了什么,但请考虑执行以下操作:

  • 在您每次使用连接时都会关闭它;
  • 考虑在using作用域中执行所有数据库操作。这样,每次查询数据库时,都会正确地处理连接实例,而不必费心将其关闭。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53627973

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档