摘要: 分布式缓存 说完进程内缓存,自然就过度到进程外缓存了。与进程内缓存不同,进程外缓存在应用运行的进程之外,它拥有更大的缓存容量,并且可以部署到不同的物理节点,通常会用分布式缓存的方式实现。 分布式缓存是与应用分离的缓存服务,最大的特点是,自身是一个独立的应用/服务,与本地应用隔离,多个应用可直接共享一 阅读全文
posted @ 2019-08-30 22:06 笑傲运维 阅读(1878) 评论(0) 推荐(1) 编辑
摘要: 进程内缓存 通过了客户端,CDN,负载均衡器,我们终于来到了应用服务器。应用服务器上部署着一个个应用,这些应用以进程的方式运行着,那么在进程中的缓存是怎样的呢? 进程内缓存又叫托管堆缓存,以 Java 为例,这部分缓存放在 JVM 的托管堆上面,同时会受到托管堆回收算法的影响。 由于其运行在内存中, 阅读全文
posted @ 2019-08-30 21:51 笑傲运维 阅读(509) 评论(0) 推荐(0) 编辑
摘要: 说完客户端(HTTP)缓存和 CDN 缓存,我们离应用服务越来越近了,在到达应用服务之前,请求还要经过负载均衡器。 虽说它的主要工作是对应用服务器进行负载均衡,但是它也可以作缓存。可以把一些修改频率不高的数据缓存在这里,例如:用户信息,配置信息。通过服务定期刷新这个缓存就行了。 负载均衡缓存工作简图 阅读全文
posted @ 2019-08-30 21:43 笑傲运维 阅读(420) 评论(0) 推荐(0) 编辑
摘要: CDN 缓存 HTTP 缓存主要是对静态数据进行缓存,把从服务器拿到的数据缓存到客户端/浏览器。 如果在客户端和服务器之间再加上一层 CDN,可以让 CDN 为应用服务器提供缓存,如果在 CDN 上缓存,就不用再请求应用服务器了。并且 HTTP 缓存提到的两种策略同样可以在 CDN 服务器执行。 C 阅读全文
posted @ 2019-08-30 21:39 笑傲运维 阅读(406) 评论(0) 推荐(0) 编辑
摘要: 假设一个网站,需要提高性能,缓存可以放在浏览器,可以放在反向代理服务器,还可以放在应用程序进程内,同时可以放在分布式缓存系统中。 缓存策略图 从用户请求数据到数据返回,数据经过了浏览器,CDN,代理服务器,应用服务器,以及数据库各个环节。每个环节都可以运用缓存技术。 从浏览器/客户端开始请求数据,通 阅读全文
posted @ 2019-08-30 21:22 笑傲运维 阅读(218) 评论(0) 推荐(0) 编辑