From e330aed6f4e5c83c539da85ca4bb91f21bbd98cd Mon Sep 17 00:00:00 2001 From: SnailClimb Date: Thu, 21 Mar 2019 12:02:54 +0800 Subject: [PATCH] =?UTF-8?q?Fix=20=E9=94=99=E5=88=AB=E5=AD=97?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...于大型网站系统架构你不得不懂的10个问题.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/架构/【面试精选】关于大型网站系统架构你不得不懂的10个问题.md b/架构/【面试精选】关于大型网站系统架构你不得不懂的10个问题.md index 415661fd..47ba541f 100644 --- a/架构/【面试精选】关于大型网站系统架构你不得不懂的10个问题.md +++ b/架构/【面试精选】关于大型网站系统架构你不得不懂的10个问题.md @@ -24,7 +24,7 @@ ### 1. 你使用过哪些组件或者方法来提升网站性能,可用性以及并发量 1. **提高硬件能力、增加系统服务器**。(当服务器增加到某个程度的时候系统所能提供的并发访问量几乎不变,所以不能根本解决问题) -2. **使用缓存**(本地缓存:本地可以使用JDK自带的 Map、Guava Cache.分布式缓存:Redis、Memcache.本地缓存不适用于提高系统并发量,一般是用处用在程序中。比如Spring是如何实现单例的呢?大家如果看过源码的话,应该知道,Spiring把已经初始过的变量放在一个Map中,下次再要使用这个变量的时候,先判断Map中有没有,这也就是系统中常见的单例模式的实现。) +2. **使用缓存**(本地缓存:本地可以使用JDK自带的 Map、Guava Cache.分布式缓存:Redis、Memcache.本地缓存不适用于提高系统并发量,一般是用处用在程序中。比如Spring是如何实现单例的呢?大家如果看过源码的话,应该知道,S把已经初始过的变量放在一个Map中,下次再要使用这个变量的时候,先判断Map中有没有,这也就是系统中常见的单例模式的实现。) 3. **消息队列** (解耦+削峰+异步) 4. **采用分布式开发** (不同的服务部署在不同的机器节点上,并且一个服务也可以部署在多台机器上,然后利用 Nginx 负载均衡访问。这样就解决了单点部署(All In)的缺点,大大提高的系统并发量) 5. **数据库分库(读写分离)、分表(水平分表、垂直分表)**