Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[CBRD-25771] Add -i option to DIAGDB for input file and update usage message #5743

Open
wants to merge 6 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion msg/en_US.utf8/utils.msg
Original file line number Diff line number Diff line change
Expand Up @@ -839,7 +839,8 @@ valid options:\n\
6 dump disk bitmaps\n\
7 dump catalog\n\
8 dump log\n\
9 dump heap\n
9 dump heap\n\
-i, --input-class-file=FILE input FILE of table names\n
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

내부 요구사항에 의해 추가하는 기능으로 히든 옵션으로 정리하시죠.



$set 25 MSGCAT_UTIL_SET_LOCKDB
Expand Down
3 changes: 2 additions & 1 deletion msg/ko_KR.utf8/utils.msg
Original file line number Diff line number Diff line change
Expand Up @@ -836,7 +836,8 @@ diagdb: 데이터베이스 정보 덤프\n\
6 디스크 bitmap 덤프\n\
7 카탈로그 덤프\n\
8 로그 덤프\n\
9 힙 덤프\n
9 힙 덤프\n\
-i, --input-class-file=FILE 테이블 이름이 기입된 파일\n


$set 25 MSGCAT_UTIL_SET_LOCKDB
Expand Down
2 changes: 2 additions & 0 deletions src/executables/util_admin.c
Original file line number Diff line number Diff line change
Expand Up @@ -320,6 +320,7 @@ static UTIL_ARG_MAP ua_Diag_Option_Map[] = {
{DIAG_OUTPUT_FILE_S, {ARG_STRING}, {0}},
{DIAG_EMERGENCY_S, {ARG_BOOLEAN}, {0}},
{DIAG_CLASS_NAME_S, {ARG_STRING}, {0}},
{DIAG_INPUT_FILE_S, {ARG_STRING}, {0}},
{0, {0}, {0}}
};

Expand All @@ -329,6 +330,7 @@ static GETOPT_LONG ua_Diag_Option[] = {
{DIAG_OUTPUT_FILE_L, 1, 0, DIAG_OUTPUT_FILE_S},
{DIAG_EMERGENCY_L, 0, 0, DIAG_EMERGENCY_S},
{DIAG_CLASS_NAME_L, 1, 0, DIAG_CLASS_NAME_S},
{DIAG_INPUT_FILE_L, 1, 0, DIAG_INPUT_FILE_S},
{0, 0, 0, 0}
};

Expand Down
12 changes: 10 additions & 2 deletions src/executables/util_sa.c
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

 if (diag != DIAGDUMP_HEAP && class_name != NULL)
    {
      goto print_diag_usage;
    }

해당 코드는 diag -d 9(Heap dump)외의 옵션에서 -n 옵션이 입력되었을 때, usage를 출력해주는 코드입니다.
아마, -i 옵션 또한 유사한 동작이 필요할 필요가 있다고 생각됩니다. 해당 상황이 고려되어야 한다면, 해당 위치의 코드 수정이 필요해보입니다.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

수정하여 반영하였습니다.

Original file line number Diff line number Diff line change
Expand Up @@ -1556,6 +1556,7 @@ diagdb (UTIL_FUNCTION_ARG * arg)
DIAGDUMP_TYPE diag;
THREAD_ENTRY *thread_p;
int error_code = NO_ERROR;
char *fname;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

의미있는 변수명을 사용하는 것이 좋겠습니다.

ex) class_name_list_file


db_name = utility_get_option_string_value (arg_map, OPTION_STRING_TABLE, 0);
if (db_name == NULL)
Expand Down Expand Up @@ -1587,6 +1588,9 @@ diagdb (UTIL_FUNCTION_ARG * arg)
}

class_name = utility_get_option_string_value (arg_map, DIAG_CLASS_NAME_S, 0);

fname = utility_get_option_string_value (arg_map, DIAG_INPUT_FILE_S, 0);

diag = (DIAGDUMP_TYPE) utility_get_option_int_value (arg_map, DIAG_DUMP_TYPE_S);

if (diag != DIAGDUMP_LOG && utility_get_option_string_table_size (arg_map) != 1)
Expand Down Expand Up @@ -1747,12 +1751,16 @@ diagdb (UTIL_FUNCTION_ARG * arg)
bool dump_records;
dump_records = utility_get_option_bool_value (arg_map, DIAG_DUMP_RECORDS_S);

if (class_name == NULL)
if (class_name == NULL && fname == NULL)
{
fprintf (outfp, "\n*** DUMP OF ALL HEAPS ***\n");
(void) file_tracker_dump_all_heap (thread_p, outfp, dump_records);
}
else
else if (class_name && fname)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이 부분은 전달받은 class_name 또는 fname 정보를 통해 출력을 처리하는 부분입니다. 전달받은 인자에 대한 예외처리를 수행하는 코드가 들어가게 되면, 코드 가독성이 떨어지게 됩니다. 해당 검사는 위에서 if (diag != DIAGDUMP_HEAP && fname != NULL) 검사 다음에 바로 수행하는게 좋을 것 같습니다.

{
goto print_diag_usage;
}
else if (class_name != NULL)
{
Comment on lines 1758 to 1769
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

잘 모르는 부분이라 리뷰의 의도는 아니고, 순수한 궁금증에 여쭤보고 싶은 게 있습니다.
혹시 class_name 은 NULL인데 fname 이 NULL 이 아닌 경우에, 이 로직을 타는 경우가 있을 수 있을까요?
만약 그렇다면, fname이 NULL이 아닌 경우는 에러 처리를 안해주어도 괜찮나요?
감사합니다.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

말씀하신 의도를 제가 정확히 파악했는지 모르겠습니다만, class_name이 NULL이고 fname이 NULL이 아닌 경우는 input file에 대한 heap dump를 위한 로직이 실행됩니다. 해당 코드는 다른 브랜치로 PR 예정이기 때문에 현재 PR 코드에는 보이지 않습니다.
답변이 안 되셨다면 추가로 말씀해주시면 감사하겠습니다.
감사합니다.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

아하 답변 감사드립니다. 이해되었습니다.

if (!sm_check_system_class_by_name (class_name))
{
Expand Down
2 changes: 2 additions & 0 deletions src/executables/utility.h
Original file line number Diff line number Diff line change
Expand Up @@ -1219,6 +1219,8 @@ typedef struct _ha_config
#define DIAG_EMERGENCY_L "emergency"
#define DIAG_CLASS_NAME_S 'n'
#define DIAG_CLASS_NAME_L "class-name"
#define DIAG_INPUT_FILE_S 'i'
#define DIAG_INPUT_FILE_L "input-file"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
#define DIAG_INPUT_FILE_S 'i'
#define DIAG_INPUT_FILE_L "input-file"
#define DIAG_INPUT_FILE_S 'i'
#define DIAG_INPUT_FILE_L "input-file"

Indent

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

수정하였습니다.


/* patch option list */
#define PATCH_RECREATE_LOG_S 'r'
Expand Down
Loading