zoukankan      html  css  js  c++  java
  • 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.

  • 相关阅读:
    [转]一致性hash算法
    [转]算法的时间复杂度和空间复杂度详解
    [转]B树(多向平衡查找树)详解
    spring中ApplicationContextAware接口描述
    [转]web.xml中<url-pattern>详解
    [转]linux中vim命令
    [转]Java GC的原理
    [转]浅谈UML的概念和模型之UML九种图
    Jmeter做读取csv接口测试
    IDLE崩溃:IDLE's subprocess didn't make connection. Either IDLE can't start a...
  • 原文地址:https://www.cnblogs.com/alexlo/p/6022782.html
Copyright © 2011-2022 走看看