电子邮件需要零信任安全模型?
五个架构原则 数据要尽量少 首先是指用户请求的数据能少就少。请求的数据包括上传给系统的数据和系统返回给用户的数据(通常就是网页)。 请求数要尽量少 用户请求的页面返回后,浏览器渲染这个页面还要包含其他的额外请求,比如说,这个页面依赖的 CSS/JavaScript、图片,以及 Ajax 请求等等都定义为“额外请求”,这些额外请求应该尽量少。
路径要尽量短 如上图,我们在同一个工程里,创建了两个MySQL数据库连接池,指向了相同的MySQL地址。使用这种方式,连接池的操作,就能够相对做到互不影响。 但到现在为止,还没完,因为你的Tomcat连接池依然是共享的。 慢查询相关的,从连接池中获取连接的策略,要改一下,不能一直等待,而应该采用FailFast的方式(获取连接短时间的超时也是可以的),否则症状还是一样。 时下流行的熔断概念,也在一定程度上实践这种隔离性。 End 我们还可以联想到类似的场景: JVM发生STW,停顿期间,受影响最大的,就是那些又快请求又大的接口。而那些耗时接口,由于平常就是那个鸟样,倒没人关注它的异常情况。 一堆接口连接了同一个数据库,当数据库发生抖动,受影响最大的,依然是那些又快请求又大的接口。因为那些耗时的慢查询,一直就是那样表现的,没人会怀疑到它们身上来。 殊不知,只要这些烂接口请求量一上升,就会像一颗老鼠屎,坏了整锅汤,所有的请求都会被拖累。 这有点类似于我们平常的工作:低效的人一增多,就会拖累整个项目的进度。领导一直在纳闷,为什么那么多技术好手,效率那么低呢? 这是因为,他们被拖累了。过于关注个体,最根本性的问题却掩盖在表象之下。
公司内部的研发,从来不应该一视同仁。不同技术追求的员工,也应该做到类似的隔离,宁缺毋滥。 而这些显示信息非常少的堆栈,才是问题的根本原因。 3. 如何解决 增加Tomcat连接池的大小,或者增加连接池的大小,并不能解决问题,大概率还会复现。 最好的解决方式,当然是把耗时的服务和正常的服务拆分开来,比如时下流行的微服务。你的服务查询慢,自己访问超时,和我的服务,一丁点儿关系都没有。 但是,你的服务即然能遇到这种问题,就证明你的公司缺乏这种改造的条件。就只能在单体服务上来做文章。
这种做法,就是隔离。 (编辑:衡水站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |