@GlobalTransactional参数详解
时间: 2023-10-28 12:53:31 浏览: 35
@GlobalTransactional 是 Seata 分布式事务框架提供的注解,用于标记一个方法作为分布式事务的入口。它包含以下参数:
- value:指定分布式事务的组名称,用于区分不同的分布式事务,可选参数。
- rollbackFor:指定在哪些异常情况下需要回滚分布式事务,默认为 Exception 类型的异常都需要回滚。
- noRollbackFor:指定在哪些异常情况下不需要回滚分布式事务,默认为空,即所有异常都需要回滚。
- timeoutMills:指定分布式事务的超时时间,单位为毫秒,默认为 60000 毫秒(1 分钟)。
使用 @GlobalTransactional 标记的方法可以调用其他带有 @GlobalTransactional 注解的方法,以形成分布式事务。在整个分布式事务执行期间,Seata 会自动协调各个分支事务的提交和回滚,并确保事务的一致性。
相关问题
@FeignClient参数详解
@FeignClient标签是用于声明一个Feign客户端的注解,它有一些常用的属性可以用来配置Feign客户端的行为。以下是对这些参数的详细解释:
1. name:指定FeignClient的名称,如果项目使用了Ribbon,name属性会作为微服务的名称,用于服务发现。
2. url:url一般用于调试,可以手动指定@FeignClient调用的地址。
3. decode404:当发生http 404错误时,如果该字段为true,会调用decoder进行解码,否则抛出FeignException。
4. configuration:Feign配置类,可以自定义Feign的Encoder、Decoder、LogLevel、Contract等。
5. fallback:定义容错的处理类,当调用远程接口失败或超时时,会调用对应接口的容错逻辑,fallback指定的类必须实现@FeignClient标记的接口。
6. fallbackFactory:工厂类,用于生成fallback类示例,通过这个属性我们可以实现每个接口通用的容错逻辑,减少重复的代码。
7. path:定义当前FeignClient的统一前缀,当我们项目中配置了server.context-path, server.servlet-path时使用。
这些参数可以根据具体的需求进行配置,以满足不同的业务场景。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
@cacheable参数详解
@Cacheable 是 Spring 框架提供的一个注解,用于标记方法的返回值可以被缓存起来,以提高方法的执行效率。当一个带有 @Cacheable 注解的方法被调用时,Spring 会首先检查缓存中是否存在该方法的返回值,如果存在,则直接从缓存中返回结果,而不执行该方法;如果缓存中不存在,则执行该方法,并将方法的返回值存入缓存。
@Cacheable 注解可以放在方法级别和类级别上,如果放在类级别上,则表示该类的所有方法的返回值都可以被缓存。在方法级别上使用 @Cacheable 注解时,可以通过设置不同的缓存名字来对不同的方法进行缓存。
@Cacheable 注解还可以指定缓存的 key,通过 SpEL 表达式来动态生成缓存的 key。这样可以根据不同的参数生成不同的缓存 key,从而实现更加精细化的缓存控制。
此外,@Cacheable 注解还支持设置缓存条件,通过设置条件表达式,可以控制方法是否执行缓存。例如,可以根据某个参数的值来判断是否进行缓存。
总结来说,@Cacheable 注解是一个非常有用的注解,可以帮助我们简化缓存的使用,并提高方法的执行效率。