asp.net core MVC 在对 mysql 数据库(在 Ubuntu 14.04/16.04 上)查询特定时间后报告错误,并显示以下消息:
" 已达到配置的 inotify 实例数量的用户限制 (128)。 "
可以确定,由于 Controller 打开了太多文件并超出了 iNotify 设置的限制(在 /proc/sys/fs/inotify/max_user_instances 中)而引发错误。但是当 ASP.NET 在每个 http 请求上打开文件时,我感到很困惑,为什么它没有正确关闭文件?有人也遇到过这个问题吗?
备注:我使用的是 Mysql.data.core 和 mysql.data.entityframeworkcore 提供程序。

    private static string classiferstring = "sports,outdoor,startup,pets,child,adult,elderly";

    [AllowAnonymous]
    [HttpGet]
    public async Task<object> Classify([FromQuery] string classifyword)
    {
        string[] classifers = classiferstring.Split(',');
        if (!classifers.Contains(classifyword))
        {
            return new
            {
                status = 0,
                info = "WrongClassifier",
                Data = ""
            };
        }

        try
        {
            var predata = await (from d in _context.descriptor
                              join a in _context.combination on d.ID equals a.ID
                              select new ProductsVM
                              {
                                  CREATETIME = a.CREATETIME,
                                  ID = a.ID,
                                  COMPANY = a.COMPANY,
                                  NAME = a.NAME,
                                  PRICE = a.PRICE,
                                  TYPE = a.TYPE,
                                  HEADPHOTO = a.HEADPHOTO,
                                  REMARK = a.REMARK,

                                  Tags = d.Tags,
                                  Classifier = d.Classifier,
                                  OriginName = d.OriginName,
                                  Briefing = d.Briefing
                              }).ToListAsync();
            var data = (from x in predata
                          where x.Classifier.Contains(classifyword.ToLower())
                          select x).ToList();

            if(predata.Count<=0)
            {
                return new
                {
                    status = 2,
                    info = "NoResult",
                    Data = ""
                };
            }else
            {
                return new
                {
                    status = 1,
                    info = "Success",
                    Data = data
                };
            };
        }
        catch(Exception e)
        {
            return new
            {
                status = 0,
                info = "Error",
                Data = e.Message
            };
        }
    }

请注意,异常仅在 try/catch 代码块中引发,而不是在调用操作后立即引发。

如果有人有解决此问题的线索,非常感谢。

最佳答案

到目前为止,我发现的最佳解决方案是通过运行以下命令来增加 fs.inotify.max_user_instances 中的 /etc/sysctl.conf:

echo fs.inotify.max_user_instances=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

资料来源:https://github.com/dotnet/aspnetcore/issues/8449#issuecomment-512275929

关于ubuntu - Asp.Net Core - 已达到配置的 inotify 实例数量的用户限制 (128),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43469400/

10-11 20:15