當前位置: 首頁>>代碼示例>>Java>>正文


Java EagleeyeHelper類代碼示例

本文整理匯總了Java中com.taobao.tddl.monitor.eagleeye.EagleeyeHelper的典型用法代碼示例。如果您正苦於以下問題:Java EagleeyeHelper類的具體用法?Java EagleeyeHelper怎麽用?Java EagleeyeHelper使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


EagleeyeHelper類屬於com.taobao.tddl.monitor.eagleeye包,在下文中一共展示了EagleeyeHelper類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: execByExecPlanNodeFuture

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
@Override
public Future<ISchematicCursor> execByExecPlanNodeFuture(final IDataNodeExecutor qc,
                                                         final ExecutionContext executionContext)
                                                                                                 throws TddlException {

    final Object rpcContext = EagleeyeHelper.getRpcContext();
    final Map<Object, Object> threadContext = ThreadLocalMap.getContextMap();
    final Map mdcContext = MDC.getCopyOfContextMap();
    ExecutorService concurrentExecutors = executionContext.getExecutorService();
    if (concurrentExecutors == null) {
        throw new ExecutorException("concurrentExecutors is null, cannot query parallelly");
    }

    Future<ISchematicCursor> task = concurrentExecutors.submit(new Callable<ISchematicCursor>() {

        @Override
        public ISchematicCursor call() throws Exception {
            ThreadLocalMap.setContextMap(resetContext(threadContext));
            EagleeyeHelper.setRpcContext(rpcContext);
            MDC.setContextMap(mdcContext);
            return execByExecPlanNode(qc, executionContext);
        }
    });
    return task;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:26,代碼來源:TopologyExecutor.java

示例2: commitFuture

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
@Override
public Future<ResultCursor> commitFuture(final ExecutionContext executionContext) throws TddlException {
    final Object rpcContext = EagleeyeHelper.getRpcContext();
    final Map<Object, Object> threadContext = ThreadLocalMap.getContextMap();
    final Map mdcContext = MDC.getCopyOfContextMap();
    ExecutorService concurrentExecutors = executionContext.getExecutorService();
    if (concurrentExecutors == null) {
        throw new ExecutorException("concurrentExecutors is null, cannot query parallelly");
    }

    Future<ResultCursor> task = concurrentExecutors.submit(new Callable<ResultCursor>() {

        @Override
        public ResultCursor call() throws Exception {
            EagleeyeHelper.setRpcContext(rpcContext);
            ThreadLocalMap.setContextMap(resetContext(threadContext));
            MDC.setContextMap(mdcContext);
            return commit(executionContext);
        }
    });
    return task;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:23,代碼來源:TopologyExecutor.java

示例3: rollbackFuture

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
@Override
public Future<ResultCursor> rollbackFuture(final ExecutionContext executionContext) throws TddlException {
    final Object rpcContext = EagleeyeHelper.getRpcContext();
    final Map<Object, Object> threadContext = ThreadLocalMap.getContextMap();
    final Map mdcContext = MDC.getCopyOfContextMap();
    ExecutorService concurrentExecutors = executionContext.getExecutorService();
    if (concurrentExecutors == null) {
        throw new ExecutorException("concurrentExecutors is null, cannot query parallelly");
    }

    Future<ResultCursor> task = concurrentExecutors.submit(new Callable<ResultCursor>() {

        @Override
        public ResultCursor call() throws Exception {
            EagleeyeHelper.setRpcContext(rpcContext);
            ThreadLocalMap.setContextMap(resetContext(threadContext));
            MDC.setContextMap(mdcContext);
            return rollback(executionContext);
        }
    });
    return task;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:23,代碼來源:TopologyExecutor.java

示例4: buildTraceComment

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
protected String buildTraceComment() {
    StringBuilder append = new StringBuilder();
    // 添加traceId,用於mysql記錄前台的sql和traceId的關聯
    // 格式/* $traceId/$rpcId/$t/ */
    String traceId = EagleeyeHelper.getTraceId();
    String rpcId = EagleeyeHelper.getRpcId();
    boolean t = EagleeyeHelper.isTestMode();
    append.append("/* ");
    if (StringUtils.isNotEmpty(traceId)) {
        append.append(traceId);
    }
    append.append('/');
    if (StringUtils.isNotEmpty(rpcId)) {
        append.append(rpcId);
    }
    append.append('/');
    if (t) {
        append.append(1);
    }
    append.append("/ */");
    return append.toString();
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:23,代碼來源:My_JdbcHandler.java

示例5: convertToRealTable

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
private String convertToRealTable(String tableName) {
    if (tableName == null) {
        return null;
    }

    String realTableName = tableName;
    if (logicTable2RealTable != null) {
        realTableName = logicTable2RealTable.get(tableName);
    }

    // 全鏈路壓測需求,修改為__test_xxx
    if (EagleeyeHelper.isTestMode()) {
        return EagleeyeHelper.ALL_PERF_TABLE_PREFIX + realTableName;
    } else {
        return realTableName;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:18,代碼來源:MysqlSqlVisitor.java

示例6: getTableName

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
public String getTableName() {
    // 全鏈路壓測需求
    String t = EagleeyeHelper.getUserData("t");
    if (!StringUtils.isBlank(t) && t.equals("1")) {
        return testTableName;
    } else {
        return tableName;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:10,代碼來源:GroupSequenceDao.java

示例7: getSwitchTempTable

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
public String getSwitchTempTable() {
    String t = EagleeyeHelper.getUserData("t");
    if (!StringUtils.isBlank(t) && t.equals("1")) {
        return testSwitchTempTable;
    } else {
        return switchTempTable;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:9,代碼來源:GroupSequenceDao.java

示例8: isTestSeq

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
private boolean isTestSeq() {
    String t = EagleeyeHelper.getUserData("t");
    if (!StringUtils.isBlank(t) && t.equals("1")) {
        return true;
    } else {
        return false;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:9,代碼來源:GroupSequence.java

示例9: getOriTableName

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
public String getOriTableName() {
    // 全鏈路壓測需求
    String t = EagleeyeHelper.getUserData("t");
    if (!StringUtils.isBlank(t) && t.equals("1")) {
        return this.testTableName;
    } else {
        return this.tableName;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:10,代碼來源:UnitGroupSequenceDao.java

示例10: getSwitchTableName

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
public String getSwitchTableName() {
    // 全鏈路壓測需求
    String t = EagleeyeHelper.getUserData("t");
    if (!StringUtils.isBlank(t) && t.equals("1")) {
        return this.testSwitchTempTable;
    } else {
        return this.switchTempTable;
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:10,代碼來源:UnitGroupSequenceDao.java

示例11: execByExecPlanNodesFuture

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
@Override
public Future<List<ISchematicCursor>> execByExecPlanNodesFuture(final List<IDataNodeExecutor> qcs,
                                                                final ExecutionContext executionContext)
                                                                                                        throws TddlException {
    final Object rpcContext = EagleeyeHelper.getRpcContext();
    final Map<Object, Object> threadContext = ThreadLocalMap.getContextMap();
    final Map mdcContext = MDC.getCopyOfContextMap();
    ExecutorService concurrentExecutors = executionContext.getExecutorService();
    if (concurrentExecutors == null) {
        throw new ExecutorException("concurrentExecutors is null, cannot query parallelly");
    }

    Future<List<ISchematicCursor>> task = concurrentExecutors.submit(new Callable<List<ISchematicCursor>>() {

        @Override
        public List<ISchematicCursor> call() throws Exception {
            List<ISchematicCursor> cursors = new ArrayList(qcs.size());
            EagleeyeHelper.setRpcContext(rpcContext);
            ThreadLocalMap.setContextMap(resetContext(threadContext));
            MDC.setContextMap(mdcContext);
            for (IDataNodeExecutor qc : qcs) {
                cursors.add(execByExecPlanNode(qc, executionContext));
            }

            return cursors;
        }
    });
    return task;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:30,代碼來源:TopologyExecutor.java

示例12: parse

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
private ParserResult parse(String sql) throws SQLSyntaxErrorException {
    ParserResult result = new ParserResult();
    SQLStatement statement = SQLParserDelegate.parse(sql);
    result.statement = statement;

    StringBuilder appendable = new StringBuilder();
    MysqlParameterizedSqlVistor visitor = new MysqlParameterizedSqlVistor(appendable, true);
    statement.accept(visitor);
    result.parameterizedSql = visitor.getSql();
    // 和eagleEye約定,加上!前綴
    result.index = EagleeyeHelper.index("!" + result.parameterizedSql);
    return result;
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:14,代碼來源:CobarSqlParseManager.java

示例13: startRpc

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
protected void startRpc(String sqlType) {
    if (sqlMetaData != null) {
        EagleeyeHelper.startRpc(datasourceWrapper.runTimeConf.getIp(),
            datasourceWrapper.runTimeConf.getPort(),
            datasourceWrapper.runTimeConf.getDbName(),
            sqlType);
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:9,代碼來源:TStatementWrapper.java

示例14: visit

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
@Override
public void visit(IQuery query) {
    if (query.isSubQuery() && !query.isTopQuery()) {
        sqlBuilder.append(" ( ");
    }
    if (query.isSubQuery() || query.isTopQuery()) {
        buildSelect(query);

        if (query.getTableName() == null && query.getSubQuery() == null) {
            return;
        }
        sqlBuilder.append(" from ");
    }

    if (query.getTableName() != null) {

        if (EagleeyeHelper.isTestMode()) {
            sqlBuilder.append(EagleeyeHelper.ALL_PERF_TABLE_PREFIX);
        }
        sqlBuilder.append(query.getTableName());

        if (!query.isSubQuery() && query.getAlias() != null
            && !query.getAlias().equalsIgnoreCase(query.getTableName())) {
            sqlBuilder.append(" ").append(query.getAlias());
        }
    } else if (query.getSubQuery() != null) {
        sqlBuilder.append(this.getNewVisitor(query.getSubQuery(), query.getSubQuery()).getString());
    }

    if (query.isSubQuery() || query.isTopQuery()) {
        String keyFilterStr = "";

        IFilter whereFilter = FilterUtils.and(FilterUtils.and(query.getKeyFilter(), query.getValueFilter()),
            query.getOtherJoinOnFilter());

        if (whereFilter != null) {
            MysqlPlanVisitorImpl visitor = this.getNewVisitor(whereFilter);
            keyFilterStr = visitor.getString();
        }

        if (!TStringUtil.isEmpty(keyFilterStr)) {
            sqlBuilder.append(" where ");
            sqlBuilder.append(keyFilterStr);
        }
        buildGroupBy(query);
        buildHaving(query);
        buildOrderBy(query);
        buildLimit(query);

        switch (query.getLockMode()) {
            case EXCLUSIVE_LOCK:
                sqlBuilder.append(" FOR UPDATE");
                break;
            case SHARED_LOCK:
                sqlBuilder.append(" LOCK IN SHARE MODE");
                break;
            default:
                break;
        }
    }

    if (query.isSubQuery() && !query.isTopQuery()) {
        sqlBuilder.append(" ) ");
        if (query.getAlias() != null) {
            sqlBuilder.append(" ").append(query.getAlias()).append(" ");
        }
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:69,代碼來源:MysqlPlanVisitorImpl.java

示例15: endRpc

import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
protected void endRpc(String sql, Exception e) {
    if (sqlMetaData != null) {
        EagleeyeHelper.endRpc(sqlMetaData, e);
    }
}
 
開發者ID:loye168,項目名稱:tddl5,代碼行數:6,代碼來源:TStatementWrapper.java


注:本文中的com.taobao.tddl.monitor.eagleeye.EagleeyeHelper類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。