alex_lo

导航

Spring AOP /代理模式/事务管理/读写分离/多数据源管理

参考文章:

http://www.cnblogs.com/MOBIN/p/5597215.html

http://www.cnblogs.com/fenglie/articles/4097759.html

http://blog.csdn.net/arthur0088/article/details/5377736

http://www.xuebuyuan.com/324257.html

http://blog.csdn.net/dreamthen/article/details/26687727

 

 

设计模式、框架源码、编写底层框架

1.代理模式

作用:

以非侵入式的方式,为某个或某类方法实行增强。即不需要修改原来的类和方法,即可在调用某方法之前或之后,添加新的功能。

实现方式:

静态代理(预先写好代理类),缺点不灵活. a.代理类和委托类实现了相同的接口,导致委托类新增方法的时候,代理类代码也要修改。b.代理对象只服务于一种类型的对象,即一个代理类智能代理一个接口,而动态代理可以代理一组接口。

动态代理,JDK动态代理cglib 动态代理.java动态代理是利用反射机制生成一个实现代理接口的匿名类,在调用具体方法前调用InvokeHandler来处理。而cglib动态代理是利用asm开源包,对代理对象类的class文件加载进来,通过修改其字节码生成子类来处理。

JDK动态代理实现原理,

  1. 通过实现 InvocationHandler 接口创建自己的调用处理器;
  2. 通过为 Proxy 类指定 ClassLoader 对象和一组 interface 来创建动态代理类;
  3. 通过反射机制获得动态代理类的构造函数,其唯一参数类型是调用处理器接口类型;
  4. 通过构造函数创建动态代理类实例,构造时调用处理器对象作为参数被传入。

简单来说, 通过InvocationHandler 接口创建自己的调用处理器,然后通过通过Proxy 类和反射机制,来创建动态代理类实例。

方法一:

方法二:将2~4步骤封装好的简便方法来创建动态代理对象

 

2.Spring AOP 原理

 spring AOP 可以使用JDK动态代理 或cglib 动态代理。默认JDK动态代理。如何选择?从灵活性,cglib更灵活可以代理接口,也可以代理类。但是cglib需要引入新的包,而且JDK动态代理性能更好。而且代码也习惯用接口来做。所以还是选用了JDK动态代理。

 

切入点,通知。切面

在选择JDK动态代理情况下,spring 就是使用InvokeHandler和PROXY类实现的。切入点,就是委托类要进行增强的方法。通知就是具体的增强方法。而InvokeHandler处理器,相当于就是切面,切面里面可以加入前后通知。

3.事务管理、底层jdbc框架、多数据源、数据库读写分离。

基础事务管理:

声明式事务,对业务层方法实现AOP切面,负责管理事务。事务开启管理,传播机制等等。

多数据源管理:

再定一个切面,对业务层这个切入点,增加一个切面来进行数据源管理。注:同一个切入点的不同切面的执行顺序,需要通过ORDER参数来保证,必须让数据源管理在事务管理之前。

a.读写库分离

b.读库的均衡策略 :简单办法 。 使用AtomicInteger 自增取余的hash算法,来均衡请求。

c.外部数据源的选择

read-only,只读事务管理:(可忽略,可直接声明式事务为SUPPORTS,而不适用read-only配置)

由于使用的是spring的DataSourceTransactionManager,不是HibernateTransactionManager。里面对声明式事务配置的 read-only没做处理。导致对只读事务,使用的事务传播性是required.而这些读方法不需要进行开启事务,让费了资源。

做法:在多数据源管理的切面类,实现BeanPostProcessor接口,即可在相应bean被ico实例化后做统一处理,设置read-only的方法的事务传播性为SUPPORTS.

posted on 2016-11-02 14:19  alex_lo  阅读(325)  评论(0编辑  收藏  举报