From f9146149239d78f1aa5c8a3c063b5a9dcbed77c1 Mon Sep 17 00:00:00 2001 From: qinjingyuan <18737351293@139.com> Date: Wed, 23 Aug 2023 16:57:11 +0800 Subject: [PATCH] Resolve three scenarios that may cause workload to fail --- src/backend/commands/prepare.c | 25 ++++++++++++++++++- src/backend/utils/error/elog.c | 45 ++++++++++++++++++++++++++++++++-- src/backend/utils/misc/guc.c | 10 ++++++++ src/include/commands/prepare.h | 3 ++- src/include/utils/guc.h | 1 + 5 files changed, 80 insertions(+), 4 deletions(-) diff --git a/src/backend/commands/prepare.c b/src/backend/commands/prepare.c index 875ef778b1d..b96f50ad02a 100644 --- a/src/backend/commands/prepare.c +++ b/src/backend/commands/prepare.c @@ -51,7 +51,8 @@ static void InitQueryHashTable(void); static ParamListInfo EvaluateParams(PreparedStatement *pstmt, List *params, const char *queryString, EState *estate); static Datum build_regtype_array(Oid *param_types, int num_params); - +// store prepare params info +char current_prepared_params_string[MAX_PREPARED_PARAMS_LEN]; /* * Implements the 'PREPARE' utility statement. */ @@ -530,6 +531,28 @@ FetchPreparedStatement(const char *stmt_name, bool throwError) NULL); else entry = NULL; + // get prepare params for solving parameterization problem + if(entry){ + StringInfoData current_prepared_params; + Oid* oid_list ; + + initStringInfo(¤t_prepared_params); + oid_list = entry->plansource->param_types; + appendStringInfoString(¤t_prepared_params,entry->stmt_name); + for(int i=0;iplansource->num_params;i++){ + Type tmp = typeidType(oid_list[i]); + char * typname = typeTypeName(tmp); + ReleaseSysCache(tmp); + appendStringInfoChar(¤t_prepared_params,','); + appendStringInfoString(¤t_prepared_params,typname); + } + if(current_prepared_params.len < MAX_PREPARED_PARAMS_LEN) + memcpy(current_prepared_params_string,current_prepared_params.data,current_prepared_params.len); + else + memcpy(current_prepared_params_string,current_prepared_params.data,MAX_PREPARED_PARAMS_LEN); + }else{ + current_prepared_params_string[0] = '\0'; + } if (!entry && throwError) ereport(ERROR, diff --git a/src/backend/utils/error/elog.c b/src/backend/utils/error/elog.c index fba9f79bf22..459c9da7d4f 100644 --- a/src/backend/utils/error/elog.c +++ b/src/backend/utils/error/elog.c @@ -77,6 +77,8 @@ #include "utils/guc.h" #include "utils/memutils.h" #include "utils/ps_status.h" +#include "catalog/namespace.h" +#include "commands/prepare.h" /* POLAR */ #include "utils/polar_backtrace.h" @@ -116,8 +118,9 @@ char *Log_destination_string = NULL; bool syslog_sequence_numbers = true; bool syslog_split_messages = true; /* POLAR */ -#define LOG_CHANNEL_WRITE_BUFFER_SIZE 128 * 1024 /* 128k */ +#define LOG_CHANNEL_WRITE_BUFFER_SIZE 64 * 1024 /* 64k */ int polar_auditlog_max_query_length = POLAR_DEFAULT_MAX_AUDIT_LOG_LEN; +bool polar_auditlog_max_query_length_limit = true; int polar_audit_log_flush_timeout = 0; /* POLAR end */ @@ -2603,6 +2606,19 @@ log_line_prefix(StringInfo buf, ErrorData *edata) appendStringInfoString(buf, formatted_log_time); break; /* POLAR: new format for polar */ + case 'L': + if (padding != 0) + appendStringInfo(buf, "%*s", padding, current_prepared_params_string); + else + appendStringInfoString(buf, current_prepared_params_string); + current_prepared_params_string[0] = '\0'; + break; + case 'N': + if (padding != 0) + appendStringInfo(buf, "%*s", padding, namespace_search_path); + else + appendStringInfoString(buf, namespace_search_path); + break; case 'S': if (edata->is_audit_log || edata->is_slow_log) { @@ -4246,7 +4262,8 @@ polar_construct_logdata_postprocess(StringInfoData *logbuf, ErrorData *edata) else { // NOTE(wormhole.gl): make sure logbuf length is not larger than PIPE_MAX_PAYLOAD - polar_shrink_audit_log(logbuf, 0); + if (polar_auditlog_max_query_length_limit) + polar_shrink_audit_log(logbuf, 0); } appendStringInfoChar(logbuf, '\n'); @@ -4287,6 +4304,8 @@ polar_write_audit_log(ErrorData *edata, const char *fmt, ...) int dest; char *logbuf_base = NULL; int logbuf_len = 0; + int residual_buf_len = 0; + int writed_buf_len = 0; StringInfoData logbuf; @@ -4333,6 +4352,28 @@ polar_write_audit_log(ErrorData *edata, const char *fmt, ...) log_channel_write_buffer_pos); log_channel_write_buffer_pos = 0; polar_last_audit_log_flush_time = GetCurrentTimestamp(); + // solving incomplete audit sql log problem + writed_buf_len = logbuf_len - PIPE_HEADER_SIZE; + residual_buf_len = logbuf.len - writed_buf_len; + while (residual_buf_len > 0) + { + logbuf_base = log_channel_write_buffer + log_channel_write_buffer_pos; + logbuf_len = LOGBUF_MIN_LEN(residual_buf_len, LOG_CHANNEL_WRITE_BUFFER_SIZE - PIPE_HEADER_SIZE - log_channel_write_buffer_pos); + memcpy(logbuf_base + PIPE_HEADER_SIZE, logbuf.data + writed_buf_len, logbuf_len); + // build pipechunk header + dest = polar_log_dest(edata); + polar_construct_pipechunk_header((PipeProtoChunk *)logbuf_base, logbuf_len, dest); + writed_buf_len += logbuf_len; + residual_buf_len = residual_buf_len - logbuf_len; + + logbuf_len = logbuf_len + PIPE_HEADER_SIZE; + log_channel_write_buffer_pos += logbuf_len; + polar_write_channel((PipeProtoChunk *)log_channel_write_buffer, + log_channel_write_buffer_pos); + log_channel_write_buffer_pos = 0; + polar_last_audit_log_flush_time = GetCurrentTimestamp(); + } + break; case LOG_DESTINATION_POLAR_SLOWLOG: default: diff --git a/src/backend/utils/misc/guc.c b/src/backend/utils/misc/guc.c index d5eb35bdd88..5c00d3c2099 100644 --- a/src/backend/utils/misc/guc.c +++ b/src/backend/utils/misc/guc.c @@ -1402,6 +1402,16 @@ static bool update_session_external_guc_index(struct config_generic *var); static struct config_bool ConfigureNamesBool[] = { + { + {"polar_auditlog_max_query_length_limit",PGC_SIGHUP,LOGGING, + gettext_noop("whether to limit polar_auditlog_max_query_length"), + NULL + }, + &polar_auditlog_max_query_length_limit, + true, + NULL,NULL,NULL + }, + { {"polar_enable_flashback_drop",PGC_SUSET,UNGROUPED, gettext_noop("whether to open flashback_drop"), diff --git a/src/include/commands/prepare.h b/src/include/commands/prepare.h index ffec029df40..a9f49c3e334 100644 --- a/src/include/commands/prepare.h +++ b/src/include/commands/prepare.h @@ -12,6 +12,7 @@ */ #ifndef PREPARE_H #define PREPARE_H +#define MAX_PREPARED_PARAMS_LEN 200 #include "commands/explain.h" #include "datatype/timestamp.h" @@ -56,5 +57,5 @@ extern TupleDesc FetchPreparedStatementResultDesc(PreparedStatement *stmt); extern List *FetchPreparedStatementTargetList(PreparedStatement *stmt); extern void DropAllPreparedStatements(void); - +extern char current_prepared_params_string[MAX_PREPARED_PARAMS_LEN]; #endif /* PREPARE_H */ diff --git a/src/include/utils/guc.h b/src/include/utils/guc.h index d53f0edc0a5..556f2c7dc96 100644 --- a/src/include/utils/guc.h +++ b/src/include/utils/guc.h @@ -396,6 +396,7 @@ extern bool polar_enable_pread; extern bool polar_enable_parallel_replay_standby_mode; extern bool polar_enable_fallocate_walfile; extern bool polar_skip_fill_walfile_zero_page; +extern bool polar_auditlog_max_query_length_limit; extern int polar_auditlog_max_query_length; extern int polar_audit_log_flush_timeout; extern int polar_clog_max_local_cache_segments;