目前spring中事务用到比较多的三种方式:
1、通过AOP统一拦截事务,事务粒度最小只能控制到方法,一般针对不同的方法配置不同的事务策略。例如get*方法配置只读事务, add*或者update*方法配置REQUIRES_NEW等等;
2、通过注解的方式,在service层不同的方法上配置不同的事务策略,例如@Transactional(propagation=Propagation.REQUIRES_NEW);
3、硬编码事务处理,这种情形,事务粒度可以控制在语句级别;但缺点是事务与代码的耦合度比较高。
个人推荐第2种处理方式。spring的事务相关框架都在org.springframework.transaction包里面,其中事务的定义在类TransactionDefinition中,spring的代码写的比较简洁,很容易看懂,具体的你可以查看源代码,至于涉及到多个数据源的分布式事务,spring一般是通过jta的方式来处理的,具体的处理方法你也可以查看源代码,不过一般来说,分布式的事务用的不好容易出问题,尽量避免。
至于你所说的action中的多个service来处理业务,且都配置有事务,这个是否在同一个事务中,要看你事务策略中配置的事务传播规则,每个规则的含义具体见TransactionDefinition类。
PS:借用侯捷的一句话 —— 源码之前了无秘密。