Change Cluster Version to 4.1.0.0

This commit is contained in:
tino247
2022-11-13 02:09:47 +08:00
committed by wangzelin.wzl
parent ba634cea50
commit 7f0d609c5f
13 changed files with 129 additions and 1027 deletions

View File

@ -33,54 +33,15 @@ using namespace sql;
namespace share
{
const uint64_t ObUpgradeChecker::UPGRADE_PATH[CLUTER_VERSION_NUM] = {
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 3UL), // 1.4.3
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 40UL), // 1.4.40
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 50UL), // 1.4.50
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 51UL), // 1.4.51
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 60UL), // 1.4.60
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 61UL), // 1.4.61
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 70UL), // 1.4.70
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 71UL), // 1.4.71
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 72UL), // 1.4.72
CALC_CLUSTER_VERSION(1UL, 4UL, 0UL, 76UL), // 1.4.76
CALC_CLUSTER_VERSION(2UL, 0UL, 0UL, 0UL), // 2.0.0
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 0UL), // 2.1.0
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 1UL), // 2.1.1
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 11UL), // 2.1.11
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 20UL), // 2.1.20
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 30UL), // 2.1.30
CALC_CLUSTER_VERSION(2UL, 1UL, 0UL, 31UL), // 2.1.31
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 0UL), // 2.2.0
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 1UL), // 2.2.1
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 20UL), // 2.2.20
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 30UL), // 2.2.30
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 40UL), // 2.2.40
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 50UL), // 2.2.50
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 60UL), // 2.2.60
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 70UL), // 2.2.70
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 71UL), // 2.2.71
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 72UL), // 2.2.72
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 73UL), // 2.2.73
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 74UL), // 2.2.74
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 75UL), // 2.2.75
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 76UL), // 2.2.76
CALC_CLUSTER_VERSION(2UL, 2UL, 0UL, 77UL), // 2.2.77
CALC_CLUSTER_VERSION(3UL, 1UL, 0UL, 0UL), // 3.1.0
CALC_CLUSTER_VERSION(3UL, 1UL, 0UL, 1UL), // 3.1.1
CALC_CLUSTER_VERSION(3UL, 1UL, 0UL, 2UL), // 3.1.2
CALC_CLUSTER_VERSION(3UL, 2UL, 0UL, 0UL), // 3.2.0
CALC_CLUSTER_VERSION(3UL, 2UL, 0UL, 1UL), // 3.2.1
CALC_CLUSTER_VERSION(3UL, 2UL, 0UL, 2UL), // 3.2.2
CALC_CLUSTER_VERSION(3UL, 2UL, 3UL, 0UL), // 3.2.3.0
CALC_CLUSTER_VERSION(4UL, 0UL, 0UL, 0UL) // 4.0.0.0
const uint64_t ObUpgradeChecker::UPGRADE_PATH[DATA_VERSION_NUM] = {
CALC_VERSION(4UL, 1UL, 0UL, 0UL) // 4.1.0.0
};
bool ObUpgradeChecker::check_cluster_version_exist(
bool ObUpgradeChecker::check_data_version_exist(
const uint64_t version)
{
bool bret = false;
OB_ASSERT(CLUTER_VERSION_NUM == ARRAYSIZEOF(UPGRADE_PATH));
OB_ASSERT(DATA_VERSION_NUM == ARRAYSIZEOF(UPGRADE_PATH));
for (int64_t i = 0; !bret && i < ARRAYSIZEOF(UPGRADE_PATH); i++) {
bret = (version == UPGRADE_PATH[i]);
}
@ -599,24 +560,8 @@ int ObUpgradeProcesserSet::init(
} \
} \
}
// order by cluster version asc
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 60);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 70);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 71);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 72);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 73);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 74);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 75);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 76);
INIT_PROCESSOR_BY_VERSION(2, 2, 0, 77);
INIT_PROCESSOR_BY_VERSION(3, 1, 0, 0);
INIT_PROCESSOR_BY_VERSION(3, 1, 0, 1);
INIT_PROCESSOR_BY_VERSION(3, 1, 0, 2);
INIT_PROCESSOR_BY_VERSION(3, 2, 0, 0);
INIT_PROCESSOR_BY_VERSION(3, 2, 0, 1);
INIT_PROCESSOR_BY_VERSION(3, 2, 0, 2);
INIT_PROCESSOR_BY_VERSION(3, 2, 3, 0);
INIT_PROCESSOR_BY_VERSION(4, 0, 0, 0);
// order by data version asc
INIT_PROCESSOR_BY_VERSION(4, 1, 0, 0);
#undef INIT_PROCESSOR_BY_VERSION
inited_ = true;
}
@ -737,7 +682,7 @@ int ObUpgradeProcesserSet::get_processor_idx_by_version(
}
ObBaseUpgradeProcessor::ObBaseUpgradeProcessor()
: inited_(false), cluster_version_(OB_INVALID_VERSION),
: inited_(false), data_version_(OB_INVALID_VERSION),
tenant_id_(common::OB_INVALID_ID), mode_(UPGRADE_MODE_INVALID),
sql_proxy_(NULL), rpc_proxy_(NULL), common_proxy_(NULL), schema_service_(NULL),
check_stop_provider_(NULL)
@ -751,12 +696,12 @@ int ObBaseUpgradeProcessor::check_inner_stat() const
if (!inited_) {
ret = OB_NOT_INIT;
LOG_WARN("not init yet", KR(ret));
} else if (cluster_version_ <= 0
} else if (data_version_ <= 0
|| tenant_id_ == OB_INVALID_ID
|| UPGRADE_MODE_INVALID == mode_) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("invalid processor status",
KR(ret), K_(cluster_version), K_(tenant_id), K_(mode));
KR(ret), K_(data_version), K_(tenant_id), K_(mode));
} else if (GCTX.is_standby_cluster() && OB_SYS_TENANT_ID != tenant_id_) {
ret = OB_NOT_SUPPORTED;
LOG_WARN("run upgrade job for non-sys tenant in standby cluster is not supported",
@ -771,7 +716,7 @@ int ObBaseUpgradeProcessor::check_inner_stat() const
}
int ObBaseUpgradeProcessor::init(
int64_t cluster_version,
int64_t data_version,
UpgradeMode mode,
common::ObMySQLProxy &sql_proxy,
obrpc::ObSrvRpcProxy &rpc_proxy,
@ -785,7 +730,7 @@ int ObBaseUpgradeProcessor::init(
LOG_WARN("init twice", KR(ret));
} else {
mode_ = mode;
cluster_version_ = cluster_version;
data_version_ = data_version;
sql_proxy_ = &sql_proxy;
rpc_proxy_ = &rpc_proxy;
common_proxy_ = &common_proxy;
@ -796,797 +741,8 @@ int ObBaseUpgradeProcessor::init(
return ret;
}
/* =========== 22070 upgrade processor start ============= */
int ObUpgradeFor22070Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(modify_trigger_package_source_body())) {
LOG_WARN("fail to modify trigger package source body", KR(ret));
} else {
// TODO:(xiaoyi.xy) rename oracle's database('__public' to 'PUBLIC') by ddl
}
return ret;
}
/* =========== special upgrade processor start ============= */
int ObUpgradeFor22070Processor::post_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(rebuild_subpart_partition_gc_info())) {
LOG_WARN("fail to rebuild subpart partition gc info", KR(ret));
}
return ret;
}
// bugfix: https://aone.alibaba-inc.com/task/30451372
int ObUpgradeFor22070Processor::modify_trigger_package_source_body()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
int64_t start_ts = ObTimeUtility::current_time();
LOG_INFO("start modify_trigger_package_source_body", K(tenant_id));
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else {
const static char* update_all_tenant_trigger_str =
"update %s "
"set "
"package_spec_source = replace("
"package_spec_source,"
"'FUNCTION UPDATING(column VARCHAR2 := NULL) RETURN BOOL;',"
"'FUNCTION UPDATING(column_name VARCHAR2 := NULL) RETURN BOOL;'"
"),"
"package_body_source = replace(replace("
"package_body_source,"
"'\n"
"PROCEDURE init_trigger(update_columns IN STRINGARRAY) IS\n"
"BEGIN\n"
" NULL;\n"
"END;\n"
"',"
"'\n"
"PROCEDURE init_trigger(update_columns IN STRINGARRAY) IS\n"
"BEGIN\n"
" update_columns_ := STRINGARRAY();\n"
" update_columns_.EXTEND(update_columns.COUNT);\n"
" FOR i IN 1 .. update_columns.COUNT LOOP\n"
" update_columns_(i) := update_columns(i);\n"
" END LOOP;\n"
"END;\n"
"'),"
"'\n"
"FUNCTION UPDATING(column VARCHAR2 := NULL) RETURN BOOL IS\n"
"BEGIN\n"
" RETURN (dml_event_ = 4);\n"
"END;\n"
"',"
"'\n"
"FUNCTION UPDATING(column_name VARCHAR2 := NULL) RETURN BOOL IS\n"
" is_updating BOOL;\n"
"BEGIN\n"
" is_updating := (dml_event_ = 4);\n"
" IF (is_updating AND column_name IS NOT NULL) THEN\n"
" is_updating := FALSE;\n"
" FOR i IN 1 .. update_columns_.COUNT LOOP\n"
" IF (UPPER(update_columns_(i)) = UPPER(column_name)) THEN is_updating := TRUE; EXIT; END IF;\n"
" END LOOP;\n"
" END IF;\n"
" RETURN is_updating;\n"
"END;\n"
"');";
const static char* update_all_tenant_trigger_history_str =
"update %s "
"set "
"package_spec_source = replace("
"package_spec_source,"
"'FUNCTION UPDATING(column VARCHAR2 := NULL) RETURN BOOL;',"
"'FUNCTION UPDATING(column_name VARCHAR2 := NULL) RETURN BOOL;'"
"),"
"package_body_source = replace(replace("
"package_body_source,"
"'\n"
"PROCEDURE init_trigger(update_columns IN STRINGARRAY) IS\n"
"BEGIN\n"
" NULL;\n"
"END;\n"
"',"
"'\n"
"PROCEDURE init_trigger(update_columns IN STRINGARRAY) IS\n"
"BEGIN\n"
" update_columns_ := STRINGARRAY();\n"
" update_columns_.EXTEND(update_columns.COUNT);\n"
" FOR i IN 1 .. update_columns.COUNT LOOP\n"
" update_columns_(i) := update_columns(i);\n"
" END LOOP;\n"
"END;\n"
"'),"
"'\n"
"FUNCTION UPDATING(column VARCHAR2 := NULL) RETURN BOOL IS\n"
"BEGIN\n"
" RETURN (dml_event_ = 4);\n"
"END;\n"
"',"
"'\n"
"FUNCTION UPDATING(column_name VARCHAR2 := NULL) RETURN BOOL IS\n"
" is_updating BOOL;\n"
"BEGIN\n"
" is_updating := (dml_event_ = 4);\n"
" IF (is_updating AND column_name IS NOT NULL) THEN\n"
" is_updating := FALSE;\n"
" FOR i IN 1 .. update_columns_.COUNT LOOP\n"
" IF (UPPER(update_columns_(i)) = UPPER(column_name)) THEN is_updating := TRUE; EXIT; END IF;\n"
" END LOOP;\n"
" END IF;\n"
" RETURN is_updating;\n"
"END;\n"
"') "
"where is_deleted = 0;";
ObSqlString sql;
int64_t affected_rows = 0;
// update __all_tenant_tigger
if (OB_FAIL(sql.assign_fmt(update_all_tenant_trigger_str, OB_ALL_TENANT_TRIGGER_TNAME))) {
LOG_WARN("fail to assign sql", KR(ret));
} else if (OB_FAIL(sql_proxy_->write(tenant_id, sql.ptr(), affected_rows))) {
LOG_WARN("failed to execute", KR(ret), K(affected_rows), K(sql));
} else {
LOG_INFO("update __all_tenant_trigger",
KR(ret), K(tenant_id), K(affected_rows), K(sql));
}
// update __all_tenant_tigger_history
if (OB_SUCC(ret)) {
sql.reset();
affected_rows = 0;
if (OB_FAIL(sql.assign_fmt(update_all_tenant_trigger_history_str,
OB_ALL_TENANT_TRIGGER_HISTORY_TNAME))) {
LOG_WARN("fail to assign sql", KR(ret));
} else if (OB_FAIL(sql_proxy_->write(tenant_id, sql.ptr(), affected_rows))) {
LOG_WARN("failed to execute", KR(ret), K(affected_rows), K(sql));
} else {
LOG_INFO("update __all_tenant_trigger_history",
KR(ret), K(tenant_id), K(affected_rows), K(sql));
}
}
}
LOG_INFO("finish modify_trigger_package_source_body",
KR(ret), K(tenant_id), "cost", ObTimeUtility::current_time() - start_ts);
return ret;
}
int ObUpgradeFor22070Processor::modify_oracle_public_database_name()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
int64_t start_ts = ObTimeUtility::current_time();
LOG_INFO("[UPGRADE] start modify_oracle_public_database_name", K(tenant_id));
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else {
ObSqlString sql;
int64_t affected_rows = 0;
uint64_t exec_tenant_id = ObSchemaUtils::get_exec_tenant_id(tenant_id);
uint64_t tenant_id_in_sql = ObSchemaUtils::get_extract_tenant_id(exec_tenant_id, tenant_id);
uint64_t db_id_in_sql = ObSchemaUtils::get_extract_schema_id(exec_tenant_id, OB_PUBLIC_SCHEMA_ID);
const static char* upd_all_database_sql =
"update %s set database_name = 'PUBLIC' where tenant_id = %ld and database_id = %ld;";
const static char* upd_all_database_history_sql =
"update %s set database_name = 'PUBLIC' where tenant_id = %ld and \
database_id = %ld and database_name = '__public';";
lib::Worker::CompatMode compat_mode = lib::Worker::CompatMode::INVALID;
if (OB_FAIL(ObCompatModeGetter::get_tenant_mode(exec_tenant_id, compat_mode))) {
LOG_WARN("fail to get tenant mode", K(ret), K(exec_tenant_id));
}
if (OB_SUCC(ret) && lib::Worker::CompatMode::ORACLE == compat_mode) {
// update __all_database
if (OB_FAIL(sql.assign_fmt(upd_all_database_sql,
OB_ALL_DATABASE_TNAME,
tenant_id_in_sql,
db_id_in_sql))) {
LOG_WARN("fail to assign sql", K(ret));
} else if (OB_FAIL(sql_proxy_->write(exec_tenant_id, sql.ptr(), affected_rows))) {
LOG_WARN("failed to execute", K(ret), K(affected_rows), K(sql));
} else {
LOG_INFO("[UPGRADE] update __all_database",
KR(ret), K(exec_tenant_id), K(affected_rows), K(sql));
}
// update __all_database_history
if (OB_SUCC(ret)) {
sql.reset();
affected_rows = 0;
if (OB_FAIL(sql.assign_fmt(upd_all_database_history_sql,
OB_ALL_DATABASE_HISTORY_TNAME,
tenant_id_in_sql,
db_id_in_sql))) {
LOG_WARN("fail to assign sql", K(ret));
} else if (OB_FAIL(sql_proxy_->write(exec_tenant_id, sql.ptr(), affected_rows))) {
LOG_WARN("failed to execute", K(ret), K(affected_rows), K(sql));
} else {
LOG_INFO("[UPGRADE] update __all_database_history",
KR(ret), K(exec_tenant_id), K(affected_rows), K(sql));
}
}
}
}
LOG_INFO("[UPGRADE] finish modify_oracle_public_database_name",
KR(ret), K(tenant_id), "cost", ObTimeUtility::current_time() - start_ts);
return ret;
}
// bugfix: https://aone.alibaba-inc.com/risk/29845662
int ObUpgradeFor22070Processor::rebuild_subpart_partition_gc_info()
{
return OB_NOT_SUPPORTED;
}
/* =========== 22070 upgrade processor end ============= */
int ObUpgradeFor22075Processor::post_upgrade()
{
ObSchemaGetterGuard guard;
lib::Worker::CompatMode compat_mode = lib::Worker::CompatMode::INVALID;
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(ObCompatModeGetter::get_tenant_mode(tenant_id, compat_mode))) {
LOG_WARN("fail to get tenant mode", K(ret), K(tenant_id));
} else if (compat_mode == lib::Worker::CompatMode::ORACLE) {
ObSqlString sql;
int64_t affected_rows = 0;
OZ (sql.assign_fmt("grant create table, create type, create trigger, "
"create procedure, create sequence to resource"));
CK (sql_proxy_ != NULL);
OZ (sql_proxy_->write(tenant_id, sql.ptr(), affected_rows, ORACLE_MODE));
}
return ret;
}
int ObUpgradeFor22077Processor::post_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(create_inner_keystore_for_sys_tenant())) {
LOG_WARN("fail to create inner keystore", KR(ret));
} else if (OB_FAIL(alter_default_profile())) {
LOG_WARN("fail to alter default profile", K(ret));
}
return ret;
}
// TDE is forbidden in sys tenant, so there isn't an inner keystore. The master key of sys tenant
// is used in encrypted zone since 22077. TDE remains forbidden by add check in create tablespace
int ObUpgradeFor22077Processor::create_inner_keystore_for_sys_tenant()
{
int ret = OB_SUCCESS;
uint64_t tenant_id = get_tenant_id();
ObSchemaGetterGuard guard;
const ObKeystoreSchema *ks_schema = NULL;
LOG_INFO("create inner keystore for sys tenant start", K(tenant_id), K(ret));
if (OB_SYS_TENANT_ID != tenant_id) {
// do nothing
} else if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(guard.get_keystore_schema(tenant_id, ks_schema))) {
LOG_WARN("fail to get keystore schema", KR(ret));
} else if (OB_NOT_NULL(ks_schema)) {
/*do nothing*/
} else {
obrpc::ObKeystoreDDLArg arg;
ObKeystoreSchema &keystore_schema = arg.schema_;
arg.exec_tenant_id_ = tenant_id;
arg.type_ = obrpc::ObKeystoreDDLArg::DDLType::CREATE_KEYSTORE;
int64_t keystore_id = OB_MYSQL_TENANT_INNER_KEYSTORE_ID;
keystore_schema.set_keystore_id(keystore_id);
keystore_schema.set_tenant_id(tenant_id);
keystore_schema.set_status(2);
keystore_schema.set_keystore_name("mysql_keystore");
if (OB_FAIL(common_proxy_->do_keystore_ddl(arg))) {
LOG_WARN("create keystore error", K(ret));
}
}
LOG_INFO("create inner keystore for sys tenant end", K(tenant_id), K(ret));
return ret;
}
int ObUpgradeFor22077Processor::alter_default_profile()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
const char* ddl_string = "alter profile default limit FAILED_LOGIN_ATTEMPTS unlimited"
" PASSWORD_LOCK_TIME 1";
ObSchemaGetterGuard guard;
lib::Worker::CompatMode compat_mode = lib::Worker::CompatMode::INVALID;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(ObCompatModeGetter::get_tenant_mode(tenant_id, compat_mode))) {
LOG_WARN("fail to get tenant mode", K(ret), K(tenant_id));
} else if (OB_ISNULL(sql_proxy_)) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("sql proxy is null", K(ret));
} else if (compat_mode == lib::Worker::CompatMode::ORACLE) {
int64_t affected_rows = 0;
LOG_INFO("alter_default_profile start", K(tenant_id), K(ret));
OZ (sql_proxy_->write(tenant_id, ddl_string, affected_rows, ObCompatibilityMode::ORACLE_MODE));
LOG_INFO("alter_default_profile end", K(tenant_id), K(ret));
}
return ret;
}
/* =========== 3100 upgrade processor start ============= */
int ObUpgradeFor3100Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
}
return ret;
}
int ObUpgradeFor3100Processor::post_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(revise_check_cst_schema())) {
LOG_WARN("fail to rebuild subpart partition gc info", KR(ret));
}
return ret;
}
// fill the info of check constraint columns into __all_tenant_constraint_column
// which is a new inner table from 3.1.0
int ObUpgradeFor3100Processor::revise_check_cst_schema()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
ObSchemaGetterGuard schema_guard;
ObSArray<uint64_t> table_ids;
ObSArray<int64_t> check_cst_counts_in_each_tbl;
if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, schema_guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(compute_check_cst_counts_in_each_table(
tenant_id, table_ids, check_cst_counts_in_each_tbl))) {
LOG_WARN("compute check cst count in each table failed",
K(ret), K(tenant_id), K(table_ids), K(check_cst_counts_in_each_tbl));
} else if (OB_FAIL(update_check_csts(
tenant_id, table_ids, check_cst_counts_in_each_tbl, schema_guard))) {
LOG_WARN("update check csts failed", K(ret), K(check_cst_counts_in_each_tbl));
}
return ret;
}
int ObUpgradeFor3100Processor::compute_check_cst_counts_in_each_table(
const uint64_t tenant_id,
ObSArray<uint64_t> &table_ids,
ObSArray<int64_t> &check_cst_counts_in_each_table)
{
int ret = OB_SUCCESS;
table_ids.reset();
check_cst_counts_in_each_table.reset();
uint64_t table_id = OB_INVALID_ID;
int64_t check_cst_count = 0;
ObSqlString sql;
const uint64_t exec_tenant_id = ObSchemaUtils::get_exec_tenant_id(tenant_id);
SMART_VAR(ObMySQLProxy::MySQLResult, res) {
common::sqlclient::ObMySQLResult *result = NULL;
/*
sql is :
SELECT table_id, count(1) AS check_csts_count
FROM __all_constraint
WHERE tenant_id = XXX and constraint_type = 3
GROUP BY(table_id);
*/
if (OB_FAIL(sql.append_fmt("SELECT table_id, count(1) as check_csts_count FROM"))) {
LOG_WARN("failed to append sql", K(ret));
} else if (OB_FAIL(sql.append_fmt(
" %s WHERE tenant_id = %lu and CONSTRAINT_TYPE = %d GROUP BY(table_id)",
OB_ALL_CONSTRAINT_TNAME,
ObSchemaUtils::get_extract_tenant_id(exec_tenant_id, tenant_id),
CONSTRAINT_TYPE_CHECK))) {
// Why need to use tenant_id to filter while revising cst schemas ?
// Because old datas in inner table of sys tenant had't been removed after schema-split.
// https://work.aone.alibaba-inc.com/issue/35188973
LOG_WARN("failed to append sql for sys tenant",
K(ret), K(tenant_id), K(OB_ALL_CONSTRAINT_TNAME));
} else if (OB_FAIL(sql_proxy_->read(res, tenant_id, sql.ptr()))) {
LOG_WARN("failed to execute sql", K(ret), K(sql));
} else if (OB_ISNULL(result = res.get_result())) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("failed to get result", K(ret));
} else {
while (OB_SUCC(ret) && OB_SUCC(result->next())) {
EXTRACT_INT_FIELD_MYSQL_WITH_TENANT_ID(*result, "table_id", table_id, tenant_id);
EXTRACT_INT_FIELD_MYSQL(*result, "check_csts_count", check_cst_count, int64_t);
if (OB_SUCC(ret)) {
if (OB_FAIL(table_ids.push_back(table_id))) {
LOG_WARN("push_back table_id into array failed", K(ret), K(table_id));
} else if (OB_FAIL(check_cst_counts_in_each_table.push_back(check_cst_count))) {
LOG_WARN("push_back check_cst_count into array failed", K(ret), K(check_cst_count));
}
}
}
if (OB_LIKELY(OB_ITER_END == ret)) {
ret = OB_SUCCESS;
} else if (OB_FAIL(ret)) {
LOG_WARN("fail to get sql result, iter quit", K(ret), K(sql));
} else if (OB_SUCC(ret)) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("ret should be OB_ITER_END", K(ret), K(sql));
}
}
}
return ret;
}
int ObUpgradeFor3100Processor::generate_constraint_schema(
obrpc::ObSchemaReviseArg &arg,
share::schema::ObSchemaGetterGuard &schema_guard,
ObIAllocator &allocator,
bool &is_need_to_revise)
{
int ret = OB_SUCCESS;
uint64_t tenant_id = arg.tenant_id_;
uint64_t table_id = arg.table_id_;
ObRawExprFactory expr_factory(allocator);
ObRawExpr *expr = NULL;
ObSqlString sql;
is_need_to_revise = true; // for reentrant
SMART_VAR(sql::ObSQLSessionInfo, session) {
if (OB_FAIL(session.init(0 /*default session id*/,
0 /*default proxy id*/,
&allocator))) {
LOG_WARN("init session failed", K(ret));
} else if (OB_FAIL(session.load_default_sys_variable(false, false))) {
LOG_WARN("session load default system variable failed", K(ret));
} else {
ObResolverParams params;
params.expr_factory_ = &expr_factory;
params.allocator_ = &allocator;
params.session_info_ = &session;
const ObTableSchema *table_schema = NULL;
bool is_oracle_mode = false;
if (OB_FAIL(schema_guard.get_table_schema(tenant_id, table_id, table_schema))) {
LOG_WARN("get table schema failed", K(ret), K(table_id));
} else if (OB_ISNULL(table_schema)) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("table_schema is null", K(ret));
} else if (OB_FAIL(table_schema->check_if_oracle_compat_mode(is_oracle_mode))) {
LOG_WARN("fail to check oracle comapt mode", KR(ret), KPC(table_schema));
} else {
lib::CompatModeGuard g(is_oracle_mode ?
lib::Worker::CompatMode::ORACLE :
lib::Worker::CompatMode::MYSQL);
for (ObTableSchema::const_constraint_iterator iter = table_schema->constraint_begin();
OB_SUCC(ret) && (iter != table_schema->constraint_end());
++iter) {
if (CONSTRAINT_TYPE_CHECK == (*iter)->get_constraint_type()) {
if ((*iter)->get_column_cnt() > 0) {
is_need_to_revise = false; // The csts in this table have been revised already.
break;
} else {
ObConstraint cst;
const ParseNode *node = NULL;
ObRawExpr *check_constraint_expr = NULL;
if (OB_FAIL(cst.assign(**iter))) {
LOG_WARN("fail to assign ObConstraint", K(ret));
} else if (OB_FAIL(ObRawExprUtils::parse_bool_expr_node_from_str(
cst.get_check_expr_str(), *params.allocator_, node))) {
LOG_WARN("parse expr node from string failed", K(ret), K(cst));
} else if (OB_FAIL(ObResolverUtils::resolve_check_constraint_expr(
params, node, *table_schema, cst, check_constraint_expr))) {
LOG_WARN("resolve check constraint expr", K(ret), K(cst));
} else if (0 == cst.get_column_cnt()) {
// no need to revise the cst if the const check expr likes '123 > 123'
continue;
} else if (OB_FAIL(arg.csts_array_.push_back(cst))) {
LOG_WARN("push back cst to csts failed", K(ret), K(cst));
}
}
}
}
if (OB_SUCC(ret) && 0 == arg.csts_array_.count()) {
// no need to revise if all the csts in this table are const check exprs
is_need_to_revise = false;
}
}
}
}
return ret;
}
// 对拥有 check 约束的表补充 check 约束的列信息
int ObUpgradeFor3100Processor::update_check_csts(
const uint64_t tenant_id,
ObSArray<uint64_t> &table_ids,
ObSArray<int64_t> &check_cst_counts_in_each_tbl,
share::schema::ObSchemaGetterGuard &schema_guard)
{
int ret = OB_SUCCESS;
ObArenaAllocator allocator("UpdateCheckCst");
const int64_t DEFAULT_TIMEOUT = 10 * 1000 * 1000L; // 10s
const int64_t TIMEOUT_PER_RPC = GCONF.rpc_timeout; // default rpc timeout is 2s
if (table_ids.count() != check_cst_counts_in_each_tbl.count()) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("the count of table_ids is not equal to the count of check_cst_counts_in_each_tbl",
K(ret), K(tenant_id), K(table_ids.count()), K(check_cst_counts_in_each_tbl.count()));
} else {
bool need_to_revise = true; // to guarantee reentrant
for (int64_t i = 0; OB_SUCC(ret) && i < table_ids.count(); ++i) {
obrpc::ObSchemaReviseArg arg;
need_to_revise = true;
arg.exec_tenant_id_ = tenant_id;
arg.tenant_id_ = tenant_id;
arg.table_id_ = table_ids.at(i);
arg.type_ = obrpc::ObSchemaReviseArg::SchemaReviseType::REVISE_CONSTRAINT_COLUMN_INFO;
arg.csts_array_.reset();
if (OB_FAIL(arg.csts_array_.reserve(check_cst_counts_in_each_tbl.at(i)))) {
LOG_WARN("reserve space for csts failed",
K(ret), K(table_ids.at(i)), K(check_cst_counts_in_each_tbl.at(i)));
} else if (OB_FAIL(generate_constraint_schema(arg, schema_guard, allocator, need_to_revise))) {
LOG_WARN("generate constraint schemas failed", K(ret), K(arg));
} else if (need_to_revise) {
if (arg.csts_array_.count() != check_cst_counts_in_each_tbl.at(i)) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("the count of csts in arg is not equal to check_cst_count_in_each_tbl",
K(ret), K(tenant_id), K(table_ids.at(i)),
K(arg.csts_array_.count()), K(check_cst_counts_in_each_tbl.at(i)));
} else if (OB_ISNULL(rpc_proxy_)) {
ret = OB_NOT_INIT;
LOG_WARN("rpc proxy is not inited");
} else if (OB_FAIL(rpc_proxy_->timeout(max(DEFAULT_TIMEOUT, TIMEOUT_PER_RPC)).schema_revise(arg))) {
LOG_WARN("schema revise failed", K(ret), K(arg));
}
}
}
}
return ret;
}
/* =========== 3100 upgrade processor end ============= */
/* =========== 3102 upgrade processor start ============= */
int ObUpgradeFor3102Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
}
return ret;
}
int ObUpgradeFor3102Processor::post_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(revise_not_null_cst_schema())) {
LOG_ERROR("fail to revise not null cst schema", KR(ret), K(get_tenant_id()));
}
return ret;
}
int ObUpgradeFor3102Processor::revise_not_null_cst_schema()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
ObSchemaGetterGuard schema_guard;
ObSArray<uint64_t> table_ids;
oceanbase::lib::Worker::CompatMode compat_mode;
if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, schema_guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(schema_guard.get_tenant_compat_mode(tenant_id, compat_mode))) {
LOG_WARN("get tenant compat mode failed", K(ret), K(tenant_id));
} else if (lib::Worker::CompatMode::MYSQL == compat_mode) {
// do nothing for mysql tenant
} else if (OB_FAIL(get_all_table_with_not_null_column(tenant_id, schema_guard, table_ids))) {
LOG_WARN("get not null column ids of each table failed",
K(ret), K(tenant_id), K(table_ids));
} else {
const int64_t DEFAULT_TIMEOUT = 10 * 1000 * 1000L; // 10s
const int64_t TIMEOUT_PER_RPC = GCONF.rpc_timeout; // default rpc timeout is 2s
for (int64_t i = 0; OB_SUCC(ret) && i < table_ids.count(); ++i) {
obrpc::ObSchemaReviseArg arg;
arg.exec_tenant_id_ = tenant_id;
arg.tenant_id_ = tenant_id;
arg.table_id_ = table_ids.at(i);
arg.type_ = obrpc::ObSchemaReviseArg::SchemaReviseType::REVISE_NOT_NULL_CONSTRAINT;
if (OB_FAIL(rpc_proxy_->timeout(max(DEFAULT_TIMEOUT, TIMEOUT_PER_RPC)).schema_revise(arg))) {
LOG_WARN("schema revise failed", K(ret), K(arg));
}
}
}
return ret;
}
int ObUpgradeFor3102Processor::get_all_table_with_not_null_column(
const uint64_t tenant_id,
ObSchemaGetterGuard &schema_guard,
ObSArray<uint64_t> &table_ids)
{
return OB_NOT_SUPPORTED;
}
/* =========== 3102 upgrade processor end ============= */
/* =========== 3200 upgrade processor start ============= */
int ObUpgradeFor3200Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
}
return ret;
}
int ObUpgradeFor3200Processor::post_upgrade()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
oceanbase::lib::Worker::CompatMode compat_mode;
ObSchemaGetterGuard schema_guard;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, schema_guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(schema_guard.get_tenant_compat_mode(tenant_id, compat_mode))) {
LOG_WARN("get tenant compat mode failed", K(ret), K(tenant_id));
} else if (OB_FAIL(grant_directory_privilege_for_dba_role(compat_mode, tenant_id))) {
LOG_WARN("fail to grant directory privilege for dba role", K(ret), K(compat_mode), K(tenant_id));
}
return ret;
}
int ObUpgradeFor3200Processor::grant_directory_privilege_for_dba_role(
const lib::Worker::CompatMode compat_mode,
const uint64_t tenant_id)
{
int ret = OB_SUCCESS;
if (lib::Worker::CompatMode::ORACLE == compat_mode) {
// only grant privilege under oracle mode
ObSqlString sql;
int64_t affected_rows = 0;
OZ (sql.assign_fmt("grant create any directory, drop any directory to dba"));
CK (sql_proxy_ != NULL);
OZ (sql_proxy_->write(tenant_id, sql.ptr(), affected_rows, ORACLE_MODE));
}
return ret;
}
/* =========== 3200 upgrade processor end ============= */
/* =========== 3201 upgrade processor start ============= */
int ObUpgradeFor3201Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
}
return ret;
}
int ObUpgradeFor3201Processor::post_upgrade()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
oceanbase::lib::Worker::CompatMode compat_mode;
ObSchemaGetterGuard schema_guard;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, schema_guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(schema_guard.get_tenant_compat_mode(tenant_id, compat_mode))) {
LOG_WARN("get tenant compat mode failed", K(ret), K(tenant_id));
} else if (OB_FAIL(init_tenant_optstat_global_prefs(compat_mode, tenant_id))) {
LOG_WARN("failed to init tenant optstat global prefs", K(ret), K(compat_mode), K(tenant_id));
}
return ret;
}
int ObUpgradeFor3201Processor::init_tenant_optstat_global_prefs(
const lib::Worker::CompatMode compat_mode,
const uint64_t tenant_id)
{
int ret = OB_SUCCESS;
if (lib::Worker::CompatMode::ORACLE == compat_mode) {
ObSqlString raw_sql;
int64_t affected_rows = 0;
if (OB_FAIL(ObDbmsStatsPreferences::gen_init_global_prefs_sql(raw_sql))) {
LOG_WARN("failed gen init global prefs sql", K(ret), K(raw_sql));
} else if (OB_UNLIKELY(raw_sql.empty()) || OB_ISNULL(sql_proxy_)) {
ret = OB_ERR_UNEXPECTED;
LOG_WARN("get unexpected error", K(ret), K(raw_sql), K(sql_proxy_));
} else if (OB_FAIL(sql_proxy_->write(tenant_id, raw_sql.ptr(), affected_rows))) {
LOG_WARN("failed to exec sql", K(ret), K(raw_sql));
}
}
return ret;
}
/* =========== 3201 upgrade processor end ============= */
/* =========== 4000 upgrade processor start ============= */
int ObUpgradeFor4000Processor::pre_upgrade()
{
int ret = OB_SUCCESS;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
}
return ret;
}
int ObUpgradeFor4000Processor::post_upgrade()
{
int ret = OB_SUCCESS;
const uint64_t tenant_id = get_tenant_id();
oceanbase::lib::Worker::CompatMode compat_mode;
ObSchemaGetterGuard schema_guard;
if (OB_FAIL(check_inner_stat())) {
LOG_WARN("fail to check inner stat", KR(ret));
} else if (OB_FAIL(schema_service_->get_tenant_full_schema_guard(tenant_id, schema_guard))) {
LOG_WARN("fail to get schema guard", KR(ret), K(tenant_id));
} else if (OB_FAIL(schema_guard.get_tenant_compat_mode(tenant_id, compat_mode))) {
LOG_WARN("get tenant compat mode failed", K(ret), K(tenant_id));
} else if (OB_FAIL(grant_debug_privilege_for_dba_role(compat_mode, tenant_id))) {
LOG_WARN("fail to grant directory privilege for dba role", K(ret), K(compat_mode), K(tenant_id));
} else if (OB_FAIL(grant_context_privilege_for_dba_role(compat_mode, tenant_id))) {
LOG_WARN("fail to grant context privilege for dba role", K(ret), K(compat_mode), K(tenant_id));
}
return ret;
}
int ObUpgradeFor4000Processor::grant_debug_privilege_for_dba_role(
const lib::Worker::CompatMode compat_mode,
const uint64_t tenant_id)
{
int ret = OB_SUCCESS;
if (lib::Worker::CompatMode::ORACLE == compat_mode) {
// only grant privilege under oracle mode
ObSqlString sql;
int64_t affected_rows = 0;
OZ (sql.assign_fmt("grant debug connect session, debug any procedure to dba"));
CK (sql_proxy_ != NULL);
OZ (sql_proxy_->write(tenant_id, sql.ptr(), affected_rows, ORACLE_MODE));
}
return ret;
}
int ObUpgradeFor4000Processor::grant_context_privilege_for_dba_role(
const lib::Worker::CompatMode compat_mode,
const uint64_t tenant_id)
{
int ret = OB_SUCCESS;
if (lib::Worker::CompatMode::ORACLE == compat_mode) {
// only grant privilege under oracle mode
ObSqlString sql;
int64_t affected_rows = 0;
OZ (sql.assign_fmt("grant create any context, drop any context to dba"));
CK (sql_proxy_ != NULL);
OZ (sql_proxy_->write(tenant_id, sql.ptr(), affected_rows, ORACLE_MODE));
}
return ret;
}
/* =========== 4000 upgrade processor end ============= */
/* =========== upgrade processor end ============= */
/* =========== special upgrade processor end ============= */
} // end share
} // end oceanbase