我有一个使用 SOAP、REST 服务或仅使用数据库存储过程与多个内部和外部源通信的应用程序。显然,性能和稳定性是我正在处理的一个主要问题。即使端点处于最佳状态,对于大量数据,我也很容易看到需要 10 秒的调用。
所以,我试图通过预取数据并在本地存储来提高我的应用程序的性能——这样至少读取操作很快。
虽然我的应用程序是数据的主要消费者和生产者,但某些数据也可以从我的应用程序外部更改,我无法控制。如果我使用缓存,当此类数据从我的应用程序外部更改时,我将永远不知道何时使缓存无效。
所以我认为我唯一的选择是运行一个作业调度程序来持续更新数据库。我可以根据用户登录和使用应用程序的频率对用户进行优先级排序。
我说的是 50,000 个用户,以及至少 10 个非常慢的端点,有时一个呼叫可能需要一分钟。Quartz之类的东西会给我我需要的规模吗?我将如何绕过计划成为单点故障?
我只是在寻找不需要高维护的东西,并且至少可以加速一些不太复杂的子系统 - 如果不是大多数的话。有什么建议么?