Java的环境配置的步骤,帮你解决90%的问题!
# **架构原则:“4 要 1 不要”**
如果你是一个架构师,你首先要勾勒出一个轮廓,想一想如何构建一个超大流量**并发读写、高性能,以及高可用的系统**,这其中有哪些要素需要考虑?
我把这些要素总结为“4 要 1 不要”:
* **数据要尽量少**
* **请求数要尽量少**
* **路径要尽量短**
* **依赖要尽量少**
* **不要有单点**
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631432897332.jpg)
# **“秒杀系统”实体机单机部署**
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631433560556.jpg)
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631433723762.jpg)
# **在设计秒杀系统中:如何有针对性的处理好动态热点数据和静态热点数据**
“热点数据”比较好理解,那就是用户的热点请求对应的数据。而热点数据又分为“**静态热点数据**”和“**动态热点数**据”
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434669340.jpg)
# **高可用系统建设**
**1\. 架构阶段**:架构阶段主要考虑系统的可扩展性和容错性,要避免系统出现单点问题。例如多机房单元化部署,即使某个城市的某个机房出现整体故障,仍然不会影响整体网站的运转。
**2\. 编码阶段**:编码最重要的是保证代码的健壮性,例如涉及远程调用问题时,要设置合理的超时退出机制,防止被其他系统拖垮,也要对调用的返回结果集有预期,防止返回的结果超出程序处理范围,最常见的做法就是对错误异常进行捕获,对无法预料的错误要有默认处理结果。
**3\. 测试阶段**:测试主要是保证测试用例的覆盖度,保证最坏情况发生时,我们也有相应的处理流程。
**4\. 发布阶段**:发布时也有一些地方需要注意,因为发布时最容易出现错误,因此要有紧急的回滚机制。
**5\. 运行阶段**:运行时是系统的常态,系统大部分时间都会处于运行态,运行态最重要的是对系统的监控要准确及时,发现问题能够准确报警并且报警数据要准确详细,以便于排查问题。
**6\. 故障发生**:故障发生时首先最重要的就是及时止损,例如由于程序问题导致商品价格错误,那就要及时下架商品或者关闭购买链接,防止造成重大资产损失。然后就是要能够及时恢复服务,并定位原因解决问题。
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434260369.jpg)
# **开关系统管理**
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434689919.jpg)
# **限流系统**
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434688944.jpg)
# **大纲目录**
![超火GitHub秒杀系统文档:从基础架构到系统建设,标星55K+Star](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434931012.jpg)
#
# 更多:Java进阶核心知识集
包含:JVM,JAVA集合,网络,JAVA多线程并发,JAVA基础,Spring原理,微服务,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存等等
![image](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631434877065.jpg)
> **[点击免费领取我的学习笔记:学习视频+大厂面试真题+微服务+MySQL+Java+Redis+算法+网络+Linux+Spring全家桶+JVM+学习笔记图](https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB)**
# 高效学习视频
![image](http://www.icode9.com/i/li/?n=2&i=images/20210707/1625631435921584.jpg)