作者回复: 你好,网关是服务对外的一个出入口,其性能影响整个网站的稳定性,所以除了异步Servlet措施,网关上同时需要做好限流熔断。建议配合Hystrix做,通过Hystrix信号量可以实现服务限流和隔离,另外严格控制服务超时,Hystrix支持超时熔断,对于一些特别慢的服务可以单独设定超时,或者也可以考虑为特别慢的服务单独部署一套网关,这也是一种物理隔离策略,避免一小部分很慢的服务影响大部分正常服务。
作者回复: 这个是AsncServlet的一种用法,背后使用线程池,像一个队列,提交丢进去即可,不需返回,后台线程会处理请求。Callable只是后台线程要处理的一个任务,也不需返回,任务被处理时会处理http request/response
作者回复: 可以,需注意做好压力测试和监控,如有性能问题及时优化或扩容。
作者回复: 谢支持🌹后面继续增加实践环节
作者回复: 可以需定制
作者回复: zuul网关的自助路由能力,目前还没有成熟开源的,需定制自研,核心原理就是网关路由表可以由开发人员自助管理,具体实现也不是特别复杂,简单做个基于数据库的web应用,能够管理网关路由表,zuul集群定期去抓取更新这个路由表。开源产品traefik(golang实现),这块做得较完善,有界面可自助管理路由,可参考。内部服务不暴露,如果用eureka的话,可以在app上附一些元数据(标识内外服务),然后ribbon做一些过滤。