本文整理匯總了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;
}
示例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;
}
示例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;
}
示例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();
}
示例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;
}
}
示例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;
}
}
示例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;
}
}
示例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;
}
}
示例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;
}
}
示例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;
}
}
示例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;
}
示例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;
}
示例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);
}
}
示例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(" ");
}
}
}
示例15: endRpc
import com.taobao.tddl.monitor.eagleeye.EagleeyeHelper; //導入依賴的package包/類
protected void endRpc(String sql, Exception e) {
if (sqlMetaData != null) {
EagleeyeHelper.endRpc(sqlMetaData, e);
}
}