* add state and callback pattern * add command and template-method pattern * add iterator pattern * add bridege and DI pattern * fix issue #1600 * add converter,proxy,visitor pattern * add caching,composite,delegation,dirty-flag,interpreter patterns * add dao and producer-consumer * add dto and provate class data pattern * fix #1646 png path problems * fix #1646 composite png path case problem * add abstract document pattern and version-number pattern * add ambassador pattern * add acyclic-visitor and api-gateway pattern * add abstract-factory pattern * add active-object pattern * add aggregator-microservices and arrange-act-assert pattern * update async-method-invocation pattern * add balking and business-delegate pattern * add bytecode and circuit-break pattern * update arrange/act/assert pattern problems * add csch pattern * add language code, correct pic path * #1805 update permalink Co-authored-by: Subhrodip Mohanta <subhrodipmohanta@gmail.com> Co-authored-by: Mike <admin@xiaod.info> Co-authored-by: Ilkka Seppälä <iluwatar@users.noreply.github.com>
		
			
				
	
	
		
			31 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| layout: pattern  
 | |
| title: Sharding 
 | |
| folder: sharding  
 | |
| permalink: /patterns/sharding/  
 | |
| categories: Behavioral
 | |
| language: zh
 | |
| tags:  
 | |
|  - Performance
 | |
|  - Cloud distributed
 | |
| ---
 | |
| 
 | |
| ## 含义 
 | |
| 分片模式是指将数据存储划分为水平分区或分片。每个分片都有相同的模式,但持有自己独特的数据子集。
 | |
| 
 | |
| 一个分片本身就是一个数据存储(它可以包含许多不同类型的实体的数据),运行在作为存储节点的服务器上。
 | |
| 
 | |
| ## 类图
 | |
| 
 | |
| 
 | |
| ## 适用场景 
 | |
| 这种设计模式提供了一下的好处:
 | |
| 
 | |
| - 你可以通过增加在额外的存储节点上,运行的更多分片来实现系统扩容。
 | |
| - 系统可以使用现成的廉价硬件,而不是为每个存储节点使用专门(或者昂贵)的服务器硬件。
 | |
| - 你可以通过平衡各分片之间的工作负载来减少竞争,以提高性能。
 | |
| - 在云环境中,分片可以在物理上靠近访问该节点数据的用户。
 | |
| 
 | |
| ## 引用
 | |
| 
 | |
| * [Sharding pattern](https://docs.microsoft.com/en-us/azure/architecture/patterns/sharding) |