前言
此系列将以精简的言语讲述技术人,必须掌握基础性IT知识技能,请持续关注,希望给大家都是一些精简的干货.
一.分布式事务
事务的意义在于:保证所提交的事务(或者叫做任务)要么成功要么失败,且要保证数据的正确性.
而在分布式架构之下,所有的服务运行在不同的环境不同的地域之下,各自做着不同的事情,而业务数据的处理逻辑的正确性至关重要,
分布式事务就显得格外重要,也是分布式架构下必要考虑的一环.
市面上流行的流行的解决方案有:2PC,3PC,TCC,本地消息表,带有分布式事务的MQ
PS:设计到事务就必然想到了分布式的离散的问题的解决手段:依靠中心
分布式避免中心,但离不开中心,有中心就应该有高可用做支撑.
2PC
在各个节点执行commit前,问问协调器,我可不可以提交?只有所有的相关节点都就绪了,所有的节点才能执行提交.
也就是说:各个节点准备就绪后,都会各自告诉协调器,协调器知道了所有都准备就绪才会告诉大家可以commit了.
先完成的要阻塞等待没有完成的,所以协调器不能出问题,且性能阻塞不好.
3PC
在2PC的机制上,添加了一个提交前的PreCommit的预提交阶段,也就说:大家收到了准备就绪,多确认一次;
同时添加了再协调器和提交者双端添加超时机制,超时也表示失败;
这两点增强了2PC的稳定性,但未解决性能问题;
TCC(Try-Confirm-Cancel)又称补偿事务
注意多了一个补偿机制,当有一个节点失败,此事务相关的节点就要执行补偿方法.性能还行,需要注意幂等.
本地消息表
所谓的本地消息表,就是把某一事务相关的系列数据,通过MQ放到一个中心数据库中.
由一个中心扫描程序进行监控整个事务的执行情况,没有成功就重新提交MQ.失败数太多就最终放弃,并通知相关人:运维,运营,技术,业务发起人.
第二部分:必须掌握的设计模式的6大基本原则
23个设计模式,都是从这六大设计模式中演化而来,所以这六大原则是产生23个设计模式的原则,作为技术人,可以不知道23个设计模式,但不能不知道这六个原则,这是心法
23个设计模式那是招式,所以基本原则比23个设计模式更为重要
原则一:单一职责
定义:一个类只负责一个功能领域中的相应职责;
亦即:你定义的类就一个因素可以引起它的变化。
简化理解:一个类单纯地干好一个活。
思考:继承关系(IS-A)是否有些违背了这一原则,在以后软件生命周期中,编码人需要考虑:基类要对子类负责。是不是Has-A更好呢?
原则二:开闭原则
定义:一个软件模块(或类)仅对扩展开放,对修改关闭。
亦即:不要想着修改现有功能,而是如何扩展现有功能。
简化理解:修改现有的功能,就意味着一切从来,带来不稳定。
思考:这一原则是对既有功能稳定性的维护,另一方面体现了面向抽象(接口)编程的重要性,接口不变,实现内容里面做调整。
原则三:迪特米法则
定义:最少知识原则
亦即:软件模块(或类)间尽量避免相互影响,相互不该知道就不要暴露。
简化理解:这是对安全和稳定性的维护
思考:安全领域的一个思想就是:权限最小化。
原则四:接口隔离原则
定义:类所需的接口应该是最小的,是自己需要的。
亦即:使用多个专门的接口,而不使用单一的总接口,即客户端不应该依赖那些它不需要的接口。
简化理解:不要设计一个很大的接口,自以为包罗万象,带来的是冗余。
原则五:依赖导致原则
定义:抽象不应该依赖于细节,细节应当依赖于抽象。换言之,要针对接口编程,而不是针对实现编程。
思考:为什么IOC大行其道?解决的问题是为了什么?
原则六:里氏替换原则
定义:使用的基类可以在任何地方使用继承的子类,完美的替换基类。
思考:面向抽象编程,面向接口编程
第二部分:数据在内存中的存储形式
2.1 三码的表示方式
计算机的二进制在内存中的存储形式:补码,且因CPU架构等不同采用了大小端存储在内存中,关于大小端大家自行阅读相关文章,至于有什么用,目前我能告诉你的是:
当我们设计底层编程及对数据存储和通讯时,我们可以头脑清醒.
正数的原码、反码、补码都是就是原码;提示,因为计算机采用补码,所以技术人脑子里面应该是补码,多转几圈没有必要.
负数的反码=符号位不变,其他位取反;
负数的补码=反码+1;
[+1]原 = 0000 0001
[-1]原 = 1000 0001
[+1] = [00000001]原 = [00000001]反
[-1] = [10000001]原 = [11111110]反
[+1] = [00000001]原 = [00000001]反 = [00000001]补
[-1] = [10000001]原 = [11111110]反 = [11111111]补
2.1 为什么计算机内采用补码
原因如下:
1.原码不能表示减法: 1 - 1 = 1 + (-1) = [00000001]原 + [10000001]原 = [10000010]原 = -2
2.反码出现+0,-0:
1 - 1 = 1 + (-1) = [0000 0001]原 + [1000 0001]原= [0000 0001]反 + [1111 1110]反 = [1111 1111]反 = [1000 0000]原 = -0
3.所以出现补码
PS:所以作为技术人,先记住你的数据在内存中是补码
注意:有一个行规,最大的负数的补码用1000...00进行表示
所以:类似于int的取值范围用(2^-31 -->2^31-1)进行表示 (中间有一个0)
先写道这里,下次继续。