zm
2020-05-18 a18bfacbf56b401f6e0fdae8710fbca4df8cff77
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package com.codingapi.tx.dubbo.filter;
 
import com.alibaba.dubbo.rpc.*;
import com.codingapi.tx.aop.bean.TxTransactionLocal;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
/**
 * Created by lorne on 2017/6/30.
 */
public class TransactionFilter implements Filter {
 
 
    private Logger logger = LoggerFactory.getLogger(TransactionFilter.class);
 
    @Override
    public Result invoke(Invoker<?> invoker, Invocation invocation) throws RpcException {
 
        TxTransactionLocal txTransactionLocal = TxTransactionLocal.current();
        String groupId = txTransactionLocal == null ? null : txTransactionLocal.getGroupId();
 
        logger.info("LCN-dubbo TxGroup info -> groupId:"+groupId);
 
        if(txTransactionLocal!=null){
            RpcContext.getContext().setAttachment("tx-group",groupId);
        }
 
        return invoker.invoke(invocation);
    }
}