tenant ctx switch
This commit is contained in:
@ -142,43 +142,46 @@ void ObTimeZoneInfoManager::TaskProcessThread::handle(void *task)
|
|||||||
int ObTimeZoneInfoManager::fetch_time_zone_info()
|
int ObTimeZoneInfoManager::fetch_time_zone_info()
|
||||||
{
|
{
|
||||||
int ret = OB_SUCCESS;
|
int ret = OB_SUCCESS;
|
||||||
if (OB_UNLIKELY(!inited_)) {
|
MTL_SWITCH(tenant_id_) {
|
||||||
ret = OB_NOT_INIT;
|
if (OB_UNLIKELY(!inited_)) {
|
||||||
LOG_WARN("not init", K(ret));
|
ret = OB_NOT_INIT;
|
||||||
} else {
|
LOG_WARN("not init", K(ret));
|
||||||
int64_t current_tz_version = -1;
|
} else {
|
||||||
ObSQLClientRetryWeak sql_client_retry_weak(&sql_proxy_, tenant_id_, OB_ALL_SYS_STAT_TID);
|
int64_t current_tz_version = -1;
|
||||||
SMART_VAR(ObMySQLProxy::MySQLResult, res) {
|
ObSQLClientRetryWeak sql_client_retry_weak(&sql_proxy_, tenant_id_, OB_ALL_SYS_STAT_TID);
|
||||||
sqlclient::ObMySQLResult *result = NULL;
|
SMART_VAR(ObMySQLProxy::MySQLResult, res) {
|
||||||
if (OB_FAIL(sql_client_retry_weak.read(res, tenant_id_, FETCH_LATEST_TZ_VERSION_SQL))) {
|
sqlclient::ObMySQLResult *result = NULL;
|
||||||
LOG_WARN("fail to execute sql", K(ret), K(tenant_id_));
|
if (OB_FAIL(sql_client_retry_weak.read(res, tenant_id_, FETCH_LATEST_TZ_VERSION_SQL))) {
|
||||||
} else if (OB_ISNULL(result = res.get_result())) {
|
LOG_WARN("fail to execute sql", K(ret), K(tenant_id_));
|
||||||
ret = OB_ERR_UNEXPECTED;
|
} else if (OB_ISNULL(result = res.get_result())) {
|
||||||
LOG_WARN("fail to get result", K(result), K(ret));
|
|
||||||
} else if (OB_FAIL(result->next())) {
|
|
||||||
if (OB_ITER_END == ret) {
|
|
||||||
// all_sys_stat中没有timezone_version,说明处于升级过程中
|
|
||||||
ret = OB_SUCCESS;
|
|
||||||
} else {
|
|
||||||
LOG_WARN("ObMySQLResult next failed", K(ret));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
ObString version_str;
|
|
||||||
EXTRACT_VARCHAR_FIELD_MYSQL(*result, "value", version_str);
|
|
||||||
bool is_valid = false;
|
|
||||||
current_tz_version = ObFastAtoi<int64_t>::atoi(version_str.ptr(),
|
|
||||||
version_str.ptr() + version_str.length(), is_valid);
|
|
||||||
if (!is_valid) {
|
|
||||||
ret = OB_ERR_UNEXPECTED;
|
ret = OB_ERR_UNEXPECTED;
|
||||||
LOG_WARN("invalid key version", K(ret), K(version_str));
|
LOG_WARN("fail to get result", K(result), K(ret));
|
||||||
|
} else if (OB_FAIL(result->next())) {
|
||||||
|
if (OB_ITER_END == ret) {
|
||||||
|
// all_sys_stat中没有timezone_version,说明处于升级过程中
|
||||||
|
ret = OB_SUCCESS;
|
||||||
|
} else {
|
||||||
|
LOG_WARN("ObMySQLResult next failed", K(ret));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ObString version_str;
|
||||||
|
EXTRACT_VARCHAR_FIELD_MYSQL(*result, "value", version_str);
|
||||||
|
bool is_valid = false;
|
||||||
|
current_tz_version = ObFastAtoi<int64_t>::atoi(version_str.ptr(),
|
||||||
|
version_str.ptr() + version_str.length(), is_valid);
|
||||||
|
if (!is_valid) {
|
||||||
|
ret = OB_ERR_UNEXPECTED;
|
||||||
|
LOG_WARN("invalid key version", K(ret), K(version_str));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if (OB_FAIL(ret)) {
|
||||||
if (OB_FAIL(ret)) {
|
} else if (OB_FAIL(fetch_time_zone_info_from_tenant_table(current_tz_version))) {
|
||||||
} else if (OB_FAIL(fetch_time_zone_info_from_tenant_table(current_tz_version))) {
|
LOG_WARN("fetch timezone info from tenant tz table failed", K(ret));
|
||||||
LOG_WARN("fetch timezone info from tenant tz table failed", K(ret));
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user