如何解决在Linux上的ASP.Net Core 3.1 Web应用程序中运行预定的后台作业-Kestrel还是Nginx?
我正在开发将在Debian GNU/Linux设备上运行的ASP.Net Core 3.1 Web应用程序。
每秒,它必须执行以下操作:
- 从随附的仪表中读取最新数据
- 将最新数据保存到数据库(InfluxDB)
- 将数据发送到客户端的浏览器(SignalR)
- 通过Modbus协议发送数据
我正在考虑使用a hosted service to run a timed background task实现以上目标。 但是,如果使用IIS,看起来会遇到以下问题:
- 直到第一个HTTP请求到来,后台作业才开始
- 如果没有传入的HTTP请求,则后台作业可能会停止执行
- 后台作业也可能会受到定期回收的应用程序池的影响
在Linux上,我正在考虑使用本机ASP.Net Core's Kestrel。
问题:Kestrel是否与IIS有相同的问题?如果我使用Nginx,会有所不同吗?有没有一种方法可以将Linux上的Web服务器配置为始终执行定时任务?
我研究了Hangfire-它似乎没有InfluxDB的扩展名,并且为此目的添加额外的数据库也不是理想的选择。
拥有两个单独的项目是否是更好的设计?一个作为Web应用程序,另一个作为独立的,不断运行的后台进程,该进程每秒将新数据发送到Web服务器?我希望有一个单一的代码库,但是我不想牺牲可靠性和性能。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。