基础知识 - 系统架构

构建一个应对高并发的分布式系统并不是很容易,别人的架构不一定适合你。但也不是很复杂,因为很多场景问题都有成熟的解决方案。系统是不断优化演变的,不需要一开始就搭建多么完美的架构。搜索一下“架构演变”会有很多文章,比如:
[url=http://www.blogjava.net/BlueDavy/archive/2008/09/03/226749.html]大型网站架构演变和知识体系[/url]
[url=http://www.cnblogs.com/leefreeman/p/3993449.html]大型网站系统架构的演化[/url]
[url=http://www.cnblogs.com/xiaoMzjm/p/5223799.html]浅谈web网站架构演变过程[/url]
[url=http://www.hollischuang.com/archives/728]大型网站架构演化历程[/url]
[url=http://blog.jobbole.com/40289/]从100PV到1亿级PV网站架构演变[/url]
[url=http://www.hollischuang.com/archives/1036]各大互联网公司架构演进之路汇总[/url]
[url=http://blog.aliyun.com/967]图片服务架构演进[/url]
等等

[b]各种词汇:[/b]
高可用High-Availability、高可扩展性(高可伸缩性)High-Scalability
解耦LooselyCoupled
吞吐量Throughput(QPS/TPS)、并发量C10K
冗余Redundancy、分区Partitions、缓存Caches、代理Proxies、索引Indexes、队列Queues
集群Cluster、主从Master-Slave、水平/垂直切分Sharding
请求负载均衡LoadBalancing、请求路由Route、状态复制Replication
故障转移Failover、故障回复Failback、心跳检测Healthcheck/Heartbeat
纵向扩展Scale-up、横向扩展Scale-out
自动升降级Auto-upgrade/downgrade
AWS – Design for Failure

[b]发展趋势:[/b]
集中式 -> 分布式 -> 广义集中式(云服务)

根据系统拆分方法:
单体式 -> 分布式 -> SOA -> 微服务

[b](1)运维角度[/b]
网上的文章大多都是站在运维的角度,大致是以下这样的优化过程:
1)单机(Web、DB、File)
2)服务器分离 Web/DB/File
3)DB服务器优化
缓存
读写分离
分库分表
全文索引
NoSQL
4)Web服务器优化
负载均衡(硬负载、软负载L4/L7、DNS负载)
动静分离
CDN和反向代理
应用拆分
5)服务化
消息队列
6)云服务

[b](2)开发角度[/b]
1)分层架构Layered Architecture(N-Tier Architecture)
MVC(Model-View-Controller)
展示层Presentation Layer、业务层Business Layer、持久层Persistence Layer、数据库层Database Layer

也有按功能分包:
Feature1(Controller、Service、Repository)
Feature2(Controller、Service、Repository)
Feature3(Controller、Service、Repository)

2)事件驱动架构Event-Driven Architecture
消息队列
Publish-subscribe
Broadcast
Point-to-point

3)微内核架构Microkernel Architecture(Plug-in Architecture)
核心系统core system、插件模块plug-in modules

4)微服务架构Microservices Architecture
相比单块架构(Monolithic Architecture)更轻量化

5)基于空间的架构Space-Based Architecture(Cloud Architecture)
处理单元processing unit、虚拟化中间件virtualized middleware

[b](3)Web Service[/b]
1)SOA(Service Oriented Architecture)面向服务的架构
ESB(Enterprise Service Bus,企业服务总线)
RPC(Remote Procedure Call Protocol)远程过程调用协议 CORBA/RMI/Thrift
SOAP(Simple Object Access Protocol)简单对象访问协议 UDDI/WSDL
REST(REpresentational State Transfer)表述性状态传递

2)MSA(Micro Service Architecture,微服务架构)

[b](4)架构应该考虑的问题[/b]
全局设置、安全设置、权限管理***、会话管理***、排他控制、异常处理、日志输出、计划任务***、页面模板、数据校验、上传下载***、数据分页、重复提交、消息通知、邀请码验证码、浏览器识别、个性化网址、保留字敏感词、国际化、数据库迁移、第三方登录、单点登录等
***的部分是分布式环境下需要注意的问题。

[b](5)其他[/b]
系统环境:
[list][*]Development
[*]Testing/QA
[*]Staging/Pre-production
[*]Production/Live[/list]
系统部署:
[list][*]Blue Green Deployment
[*]A/B Testing
[*]Canary Release[/list]

参考:
[url=http://colobu.com/2015/04/08/software-architecture-patterns/]http://colobu.com/2015/04/08/software-architecture-patterns/[/url]
[url=http://www.infoq.com/articles/scalability-principles]http://www.infoq.com/articles/scalability-principles[/url]
[url=http://www.infoq.com/cn/news/2015/04/micro-service-architecture]http://www.infoq.com/cn/news/2015/04/micro-service-architecture[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值