From 6b6aceac022623ac16ef81ccb7ce84c20b158a1e Mon Sep 17 00:00:00 2001 From: wshi8 Date: Tue, 5 Sep 2023 18:14:53 +0800 Subject: [PATCH 1/5] update: fix el9 compile error --- deps/3rd/dep_create.sh | 3 +++ deps/3rd/obproxy.el8.x86_64.deps | 2 +- src/lib/allocator/ob_mod_define.cpp | 2 +- src/lib/ob_define.h | 4 ++-- src/obproxy/cmd/ob_show_memory_handler.cpp | 2 +- src/obproxy/ob_proxy_main.cpp | 2 +- src/obproxy/utils/ob_proxy_lib.h | 2 +- 7 files changed, 10 insertions(+), 7 deletions(-) diff --git a/deps/3rd/dep_create.sh b/deps/3rd/dep_create.sh index 6ea9d229..36e6dca7 100644 --- a/deps/3rd/dep_create.sh +++ b/deps/3rd/dep_create.sh @@ -56,6 +56,9 @@ function get_os_release() { version_ge "8.0" && OS_RELEASE=8 && return version_ge "7.0" && OS_RELEASE=7 && return ;; + almalinux) + version_ge "8.0" && compat_centos8 && return + ;; debian) version_ge "9" && compat_centos7 && return ;; diff --git a/deps/3rd/obproxy.el8.x86_64.deps b/deps/3rd/obproxy.el8.x86_64.deps index 04d6a67f..84691730 100644 --- a/deps/3rd/obproxy.el8.x86_64.deps +++ b/deps/3rd/obproxy.el8.x86_64.deps @@ -7,7 +7,7 @@ devdeps-openssl-static-1.0.1e-3.el8.x86_64.rpm devdeps-libcurl-static-7.29.0-3.el8.x86_64.rpm devdeps-mariadb-connector-c-3.1.12-3.el8.x86_64.rpm devdeps-prometheus-cpp-0.8.0-4.el8.x86_64.rpm -devdeps-gtest-1.8.0-3.el8.x86_64.rpm +devdeps-gtest-1.8.0-132022101316.el8.x86_64.rpm devdeps-grpc-1.20.1-3.el8.x86_64.rpm devdeps-sqlite-3.38.1-5.el8.x86_64.rpm diff --git a/src/lib/allocator/ob_mod_define.cpp b/src/lib/allocator/ob_mod_define.cpp index 82851e11..3cba86ef 100644 --- a/src/lib/allocator/ob_mod_define.cpp +++ b/src/lib/allocator/ob_mod_define.cpp @@ -94,7 +94,7 @@ void ObModSet::print_mod_memory_usage(bool print_glibc) const _OB_LOG(INFO, "=== malloc_stats ==="); malloc_stats(); _OB_LOG(INFO, "=== main heap info ==="); - struct mallinfo info = mallinfo(); + struct mallinfo2 info = mallinfo2(); _OB_LOG(INFO, "mmap_chunks=%d", info.hblks); _OB_LOG(INFO, "mmap_bytes=%d", info.hblkhd); _OB_LOG(INFO, "sbrk_sys_bytes=%d", info.arena); diff --git a/src/lib/ob_define.h b/src/lib/ob_define.h index e80ff17f..9aa4a41b 100644 --- a/src/lib/ob_define.h +++ b/src/lib/ob_define.h @@ -1216,7 +1216,7 @@ inline void reset_tid_cache() get_tid_cache() = -1; } -inline int64_t gettid() +inline int64_t gettid_ob() { int64_t &tid = get_tid_cache(); if (OB_UNLIKELY(tid <= 0)) { @@ -1224,6 +1224,6 @@ inline int64_t gettid() } return tid; } -#define GETTID() gettid() +#define GETTID() gettid_ob() #endif // OCEANBASE_COMMON_DEFINE_H_ diff --git a/src/obproxy/cmd/ob_show_memory_handler.cpp b/src/obproxy/cmd/ob_show_memory_handler.cpp index 98909ba0..61a6267b 100644 --- a/src/obproxy/cmd/ob_show_memory_handler.cpp +++ b/src/obproxy/cmd/ob_show_memory_handler.cpp @@ -111,7 +111,7 @@ int ObShowMemoryHandler::handle_show_memory(int event, void *data) } if (OB_SUCC(ret)) { // dump memory allocated by glibc - struct mallinfo mi = mallinfo(); + struct mallinfo2 mi = mallinfo2(); int64_t allocated = mi.arena + mi.hblkhd; int64_t used = allocated - mi.fordblks; if (OB_FAIL(dump_mod_memory("GLIBC", "user", allocated, used, mi.hblks))) { diff --git a/src/obproxy/ob_proxy_main.cpp b/src/obproxy/ob_proxy_main.cpp index 3a5161b3..ce216435 100644 --- a/src/obproxy/ob_proxy_main.cpp +++ b/src/obproxy/ob_proxy_main.cpp @@ -909,7 +909,7 @@ void ObProxyMain::print_memory_usage() void ObProxyMain::print_glibc_memory_usage() { - struct mallinfo mi = mallinfo(); + struct mallinfo2 mi = mallinfo2(); int64_t hold = mi.arena + mi.hblkhd; int64_t used = hold - mi.fordblks; int64_t count = mi.hblks; diff --git a/src/obproxy/utils/ob_proxy_lib.h b/src/obproxy/utils/ob_proxy_lib.h index 98768673..b3f1e749 100644 --- a/src/obproxy/utils/ob_proxy_lib.h +++ b/src/obproxy/utils/ob_proxy_lib.h @@ -91,7 +91,7 @@ struct ifafilt; typedef unsigned int in_addr_t; #endif #include -#include +//#include #include #include #include From 843bf9f721030d9a4bca438cc522401c76d004e4 Mon Sep 17 00:00:00 2001 From: wshi8 Date: Wed, 6 Sep 2023 14:29:12 +0800 Subject: [PATCH 2/5] fix format error --- src/lib/allocator/ob_mod_define.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/lib/allocator/ob_mod_define.cpp b/src/lib/allocator/ob_mod_define.cpp index 3cba86ef..03dc7874 100644 --- a/src/lib/allocator/ob_mod_define.cpp +++ b/src/lib/allocator/ob_mod_define.cpp @@ -95,13 +95,13 @@ void ObModSet::print_mod_memory_usage(bool print_glibc) const malloc_stats(); _OB_LOG(INFO, "=== main heap info ==="); struct mallinfo2 info = mallinfo2(); - _OB_LOG(INFO, "mmap_chunks=%d", info.hblks); - _OB_LOG(INFO, "mmap_bytes=%d", info.hblkhd); - _OB_LOG(INFO, "sbrk_sys_bytes=%d", info.arena); - _OB_LOG(INFO, "sbrk_used_chunk_bytes=%d", info.uordblks); - _OB_LOG(INFO, "sbrk_not_in_use_chunks=%d", info.ordblks); - _OB_LOG(INFO, "sbrk_not_in_use_chunk_bytes=%d", info.fordblks); - _OB_LOG(INFO, "sbrk_top_most_releasable_chunk_bytes=%d", info.keepcost); + _OB_LOG(INFO, "mmap_chunks=%ld", info.hblks); + _OB_LOG(INFO, "mmap_bytes=%ld", info.hblkhd); + _OB_LOG(INFO, "sbrk_sys_bytes=%ld", info.arena); + _OB_LOG(INFO, "sbrk_used_chunk_bytes=%ld", info.uordblks); + _OB_LOG(INFO, "sbrk_not_in_use_chunks=%ld", info.ordblks); + _OB_LOG(INFO, "sbrk_not_in_use_chunk_bytes=%ld", info.fordblks); + _OB_LOG(INFO, "sbrk_top_most_releasable_chunk_bytes=%ld", info.keepcost); _OB_LOG(INFO, "=== detailed malloc_info ==="); //malloc_info(0, stderr); } From 086613dcbdbc4471541fa244fce97aed74b4df5d Mon Sep 17 00:00:00 2001 From: phoeniwx Date: Wed, 6 Sep 2023 16:00:47 +0800 Subject: [PATCH 3/5] fix: add EL9_PLATFORM macro --- configure.ac | 7 +++++++ src/lib/allocator/ob_mod_define.cpp | 12 ++++++++++++ src/lib/random/ob_random.cpp | 2 +- src/obproxy/cmd/ob_show_memory_handler.cpp | 4 ++++ src/obproxy/ob_proxy_main.cpp | 4 ++++ src/obproxy/proxy/mysql/ob_mysql_client_session.cpp | 2 +- src/obproxy/proxy/route/ob_cache_cleaner.cpp | 2 +- 7 files changed, 30 insertions(+), 3 deletions(-) diff --git a/configure.ac b/configure.ac index 8c3530a6..bdec1a2c 100644 --- a/configure.ac +++ b/configure.ac @@ -61,6 +61,13 @@ AM_CFLAGS="${AM_CFLAGS} -fuse-ld=lld -ffunction-sections -Wl,--no-warn-symbol-ordering,--symbol-ordering-file,${ac_abs_confdir}/hotfuncs.txt" fi + #check el9, add -DEL9_PlATFORM for el9 + is_el9=`cat /proc/version | grep el9` + if test "$is_el9" != ""; then + AM_CXXFLAGS="${AM_CXXFLAGS} -DEL9_PlATFORM" + AM_CXXFLAGS="${AM_CXXFLAGS} -DEL9_PlATFORM" + fi + #check gcc version, add -Wno-ignored-qualifiers flag for gcc version greater than 4.3.0 GCC_VERSION=`$CC -dumpfullversion -dumpversion` if test $? -eq 0; then diff --git a/src/lib/allocator/ob_mod_define.cpp b/src/lib/allocator/ob_mod_define.cpp index 03dc7874..0c7401ba 100644 --- a/src/lib/allocator/ob_mod_define.cpp +++ b/src/lib/allocator/ob_mod_define.cpp @@ -94,6 +94,7 @@ void ObModSet::print_mod_memory_usage(bool print_glibc) const _OB_LOG(INFO, "=== malloc_stats ==="); malloc_stats(); _OB_LOG(INFO, "=== main heap info ==="); +#ifdef EL9_PLATFORM struct mallinfo2 info = mallinfo2(); _OB_LOG(INFO, "mmap_chunks=%ld", info.hblks); _OB_LOG(INFO, "mmap_bytes=%ld", info.hblkhd); @@ -102,7 +103,18 @@ void ObModSet::print_mod_memory_usage(bool print_glibc) const _OB_LOG(INFO, "sbrk_not_in_use_chunks=%ld", info.ordblks); _OB_LOG(INFO, "sbrk_not_in_use_chunk_bytes=%ld", info.fordblks); _OB_LOG(INFO, "sbrk_top_most_releasable_chunk_bytes=%ld", info.keepcost); +#else + struct mallinfo info = mallinfo(); + _OB_LOG(INFO, "mmap_chunks=%d", info.hblks); + _OB_LOG(INFO, "mmap_bytes=%d", info.hblkhd); + _OB_LOG(INFO, "sbrk_sys_bytes=%d", info.arena); + _OB_LOG(INFO, "sbrk_used_chunk_bytes=%d", info.uordblks); + _OB_LOG(INFO, "sbrk_not_in_use_chunks=%d", info.ordblks); + _OB_LOG(INFO, "sbrk_not_in_use_chunk_bytes=%d", info.fordblks); + _OB_LOG(INFO, "sbrk_top_most_releasable_chunk_bytes=%d", info.keepcost); +#endif _OB_LOG(INFO, "=== detailed malloc_info ==="); + //malloc_info(0, stderr); } ObObjFreeListList::get_freelists().dump(); diff --git a/src/lib/random/ob_random.cpp b/src/lib/random/ob_random.cpp index a9be32da..d56cf6f4 100644 --- a/src/lib/random/ob_random.cpp +++ b/src/lib/random/ob_random.cpp @@ -35,7 +35,7 @@ int64_t ObRandom::rand(const int64_t a, const int64_t b) { static __thread uint16_t seed[3] = {0, 0, 0}; if (0 == seed[0] && 0 == seed[1] && 0 == seed[2]) { - seed[0] = static_cast(gettid()); + seed[0] = static_cast(GETTID()); seed[1] = seed[0]; seed[2] = seed[1]; seed48(seed); diff --git a/src/obproxy/cmd/ob_show_memory_handler.cpp b/src/obproxy/cmd/ob_show_memory_handler.cpp index 61a6267b..a04132d7 100644 --- a/src/obproxy/cmd/ob_show_memory_handler.cpp +++ b/src/obproxy/cmd/ob_show_memory_handler.cpp @@ -111,7 +111,11 @@ int ObShowMemoryHandler::handle_show_memory(int event, void *data) } if (OB_SUCC(ret)) { // dump memory allocated by glibc +#ifdef EL9_PLATFORM struct mallinfo2 mi = mallinfo2(); +#else + struct mallinfo mi = mallinfo(); +#endif int64_t allocated = mi.arena + mi.hblkhd; int64_t used = allocated - mi.fordblks; if (OB_FAIL(dump_mod_memory("GLIBC", "user", allocated, used, mi.hblks))) { diff --git a/src/obproxy/ob_proxy_main.cpp b/src/obproxy/ob_proxy_main.cpp index ce216435..ea376a9a 100644 --- a/src/obproxy/ob_proxy_main.cpp +++ b/src/obproxy/ob_proxy_main.cpp @@ -909,7 +909,11 @@ void ObProxyMain::print_memory_usage() void ObProxyMain::print_glibc_memory_usage() { +#ifdef EL9_PLATFORM struct mallinfo2 mi = mallinfo2(); +#else + struct mallinfo mi = mallinfo(); +#endif int64_t hold = mi.arena + mi.hblkhd; int64_t used = hold - mi.fordblks; int64_t count = mi.hblks; diff --git a/src/obproxy/proxy/mysql/ob_mysql_client_session.cpp b/src/obproxy/proxy/mysql/ob_mysql_client_session.cpp index aae717e1..058773c2 100644 --- a/src/obproxy/proxy/mysql/ob_mysql_client_session.cpp +++ b/src/obproxy/proxy/mysql/ob_mysql_client_session.cpp @@ -296,7 +296,7 @@ int ObMysqlClientSession::new_connection( session_manager_new_.set_mutex(mutex_); MUTEX_TRY_LOCK(lock, mutex_, this_ethread()); if (OB_LIKELY(lock.is_locked())) { - current_tid_ = gettid(); + current_tid_ = GETTID(); hooks_on_ = true; MYSQL_INCREMENT_DYN_STAT(CURRENT_CLIENT_CONNECTIONS); diff --git a/src/obproxy/proxy/route/ob_cache_cleaner.cpp b/src/obproxy/proxy/route/ob_cache_cleaner.cpp index f81a0e0c..b9503adc 100644 --- a/src/obproxy/proxy/route/ob_cache_cleaner.cpp +++ b/src/obproxy/proxy/route/ob_cache_cleaner.cpp @@ -991,7 +991,7 @@ int ObCacheCleaner::do_delete_cluster_resource() cr->destroy(); } LOG_INFO("this thread has clean cluster resource complete", - "thread_id", gettid(), KPC(cr)); + "thread_id", GETTID(), KPC(cr)); cr_actor->free(); // will dec cr ref cr_actor = NULL; cr = NULL; From 6da4552da216e22755f14d4f37fd445f9f8e87d6 Mon Sep 17 00:00:00 2001 From: wshi8 Date: Wed, 6 Sep 2023 16:04:55 +0800 Subject: [PATCH 4/5] fix: EL9_PLATFORM control sysctl.h --- src/obproxy/utils/ob_proxy_lib.h | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/obproxy/utils/ob_proxy_lib.h b/src/obproxy/utils/ob_proxy_lib.h index b3f1e749..cb778858 100644 --- a/src/obproxy/utils/ob_proxy_lib.h +++ b/src/obproxy/utils/ob_proxy_lib.h @@ -91,7 +91,10 @@ struct ifafilt; typedef unsigned int in_addr_t; #endif #include -//#include +#ifdef EL9_PLATFORM +#else +#include +#endif #include #include #include From fbe6ed1d6ad4e703137c2c4a40a68472f89f8202 Mon Sep 17 00:00:00 2001 From: wshi8 Date: Wed, 6 Sep 2023 16:17:12 +0800 Subject: [PATCH 5/5] fix: spell error --- configure.ac | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/configure.ac b/configure.ac index bdec1a2c..2169292f 100644 --- a/configure.ac +++ b/configure.ac @@ -64,8 +64,8 @@ #check el9, add -DEL9_PlATFORM for el9 is_el9=`cat /proc/version | grep el9` if test "$is_el9" != ""; then - AM_CXXFLAGS="${AM_CXXFLAGS} -DEL9_PlATFORM" - AM_CXXFLAGS="${AM_CXXFLAGS} -DEL9_PlATFORM" + AM_CXXFLAGS="${AM_CXXFLAGS} -DEL9_PLATFORM" + AM_CFLAGS="${AM_CFLAGS} -DEL9_PLATFORM" fi #check gcc version, add -Wno-ignored-qualifiers flag for gcc version greater than 4.3.0