dubbo超时重试导致数据重复

      最近在写邮件激活测试的时,测试的时候出现注册失败,显示用户名已存在,但是在表单验证和注开始都没有问题。后来debug时发现在发送邮件前,又执行了一次数据验证。相当于是又走了一遍注册流程,最后返回注册失败,并发送了邮件。在网上找了很多资料,说是dubbo超时重试机制导致重新提交了注册,在将超时时间延长之后问题解决。

    了解了一下dubbo超时重试机制:

 Dubbo的超时重试机制为服务容错、服务稳定提供了比较好的框架支持,但是在一些比较特殊的网络环境下(网络传输慢,并发多)可能

由于服务响应慢,Dubbo自身的超时重试机制(服务端的处理时间超过了设定的超时时间时,就会有重复请求)可能会带来一些麻烦。

      常见的应用场景故障:  1、发送邮件(重复) ;2、账户注册(重复).。

       解决方案:

                       1.对于核心的服务中心,去除dubbo超时重试机制,并重新评估设置超时时间

                            (1)、去掉超时重试机制  

                                  <dubbo:provider delay="-1" timeout="6000"  retries="0"/> 

                            (2)、重新评估设置超时时间

                                  <dubbo:service interface="*.*" ref="*"  timeout="延长服务时间"/>

                      2.业务处理代码必须放在服务端,客户端只做参数验证和服务调用,不涉及业务流程处理。

   我这里出现的就是第二种情况,然后设置了timeout,延长服务时间,并解决。

猜你喜欢

转载自blog.csdn.net/baoshuang189828/article/details/85159960
今日推荐