Skip to content

Commit

Permalink
log long running sqls executed from a stored procedure
Browse files Browse the repository at this point in the history
Signed-off-by: Aakash Arayambeth <[email protected]>
  • Loading branch information
Aakash Arayambeth committed Oct 11, 2024
1 parent 52a2268 commit e554cb0
Show file tree
Hide file tree
Showing 8 changed files with 102 additions and 3 deletions.
25 changes: 22 additions & 3 deletions lua/sp.c
Original file line number Diff line number Diff line change
Expand Up @@ -1241,6 +1241,7 @@ static int create_temp_table(Lua lua, pthread_mutex_t **lk, const char **name)
*lk = NULL;
luabb_error(lua, sp, sqlite3ErrStr(rc));
}
reqlog_end_request(sp->thd->logger, rc, __func__, __LINE__);
out:
if (sql) strbuf_free(sql);
return -1;
Expand Down Expand Up @@ -2199,6 +2200,16 @@ static int dbstmt_bind_int(Lua lua, dbstmt_t *dbstmt)
return stmt_bind(lua, dbstmt->stmt);
}

static void lua_set_clnt_sql(struct sqlclntstate *clnt, char *sql) {
if (!clnt || !sql) return;
clnt->sql = sql;
}

static void lua_set_clnt_origin(struct sqlclntstate *clnt, char *origin) {
if (!clnt || !origin) return;
clnt->origin = origin;
}

static int lua_prepare_sql_int(SP sp, const char *sql, sqlite3_stmt **stmt,
struct sql_state *rec, int flags)
{
Expand All @@ -2213,7 +2224,8 @@ static int lua_prepare_sql_int(SP sp, const char *sql, sqlite3_stmt **stmt,
/* Reset logger. This clears table names (see reqlog_add_table) and
print events (see reqlog_logv_int) in the logger. */
reqlog_reset_logger(sp->thd->logger);

reqlog_set_origin(sp->thd->logger, "%s", sp->clnt->origin);
lua_set_clnt_sql(sp->clnt, (char *)sql);
retry:
memset(&err, 0, sizeof(struct errstat));
if (sp->initial) {
Expand Down Expand Up @@ -2311,6 +2323,7 @@ static void lua_end_step(struct sqlclntstate *clnt, SP sp,
}
}


static void lua_end_all_step(struct sqlclntstate *clnt, SP sp)
{
if (sp != NULL) {
Expand Down Expand Up @@ -2484,6 +2497,7 @@ static int dbtable_insert(Lua lua)
}
lua_end_step(sp->clnt, sp, stmt);
if (rc == SQLITE_DONE) rc = 0;
reqlog_end_request(sp->thd->logger, rc, __func__, __LINE__);
out:if (rc) {
const char *errstr = NULL;
sqlite3 *sqldb = getdb(sp);
Expand Down Expand Up @@ -2545,6 +2559,7 @@ static int dbtable_copyfrom(Lua lua)
}
lua_end_step(sp->clnt, sp, stmt);

reqlog_end_request(sp->thd->logger, rc, __func__, __LINE__);
sqlite3_finalize(stmt);

lua_pushinteger(lua, 0); /* Success return code. */
Expand Down Expand Up @@ -3087,6 +3102,7 @@ static void drop_temp_tables(SP sp)
expire = 1;
logmsg(LOGMSG_FATAL, "sqlite3_step rc:%d sql:%s\n", rc, drop_sql);
}
reqlog_end_request(sp->thd->logger, rc, __func__, __LINE__);
}
clnt->skip_peer_chk = 0;
if (expire) {
Expand Down Expand Up @@ -3763,13 +3779,13 @@ static int db_exec(Lua lua)
sp->rc = lua_check_errors(sp->clnt, sqldb, stmt, &err);
sp->error = strdup(err);
}

if (sp->rc) {
lua_pushnil(lua);
lua_pushinteger(lua, sp->rc);
} else {
lua_pushinteger(lua, 0); /* Success return code */
}
reqlog_end_request(sp->thd->logger, rc, __func__, __LINE__);
return 2;
}

Expand Down Expand Up @@ -6766,6 +6782,7 @@ static void clone_temp_tables(SP sp)
sqlite3_stmt *stmt;
lua_prepare_sql_with_temp_ddl(sp, strbuf_buf(sql), &stmt);
clone_temp_table(stmt, &tmp->tbl);
reqlog_end_request(sp->thd->logger, 0, __func__, __LINE__);
sqlite3_finalize(stmt);
sp->clnt->skip_peer_chk = 0;
strbuf_free(sql);
Expand Down Expand Up @@ -7320,13 +7337,15 @@ void *exec_trigger(char *spname)
char sql[128];
snprintf(sql, sizeof(sql), "exec procedure %s()", spname);

char origin[128];
snprintf(origin, sizeof(origin), "trigger->%s", spname);
struct sqlclntstate clnt;
start_internal_sql_clnt(&clnt);
clnt.dbtran.mode = TRANLEVEL_SOSQL;
clnt.sql = sql;
clnt.origin = origin;
clnt.dbtran.trans_has_sp = 1;
clnt.current_user.bypass_auth = 1;

thread_memcreate(128 * 1024);
struct sqlthdstate thd = {0};
sqlengine_thd_start(NULL, &thd, THRTYPE_TRIGGER);
Expand Down
8 changes: 8 additions & 0 deletions tests/longreq_sp_queries.test/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
ifeq ($(TESTSROOTDIR),)
include ../testcase.mk
else
include $(TESTSROOTDIR)/testcase.mk
endif
ifeq ($(TEST_TIMEOUT),)
export TEST_TIMEOUT=3m
endif
2 changes: 2 additions & 0 deletions tests/longreq_sp_queries.test/dropsptrigger.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
DROP PROCEDURE dormant '1'
DROP LUA TRIGGER dormant
3 changes: 3 additions & 0 deletions tests/longreq_sp_queries.test/lrl.options
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
setattr REP_WORKERS 0
setattr REP_PROCESSORS 0
decoupled_logputs off
55 changes: 55 additions & 0 deletions tests/longreq_sp_queries.test/runit
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
#!/usr/bin/env bash
bash -n "$0" | exit 1
set -x
. ${TESTSROOTDIR}/tools/cluster_utils.sh
. ${TESTSROOTDIR}/tools/runit_common.sh

function setup_longreq
{
for node in $CLUSTER ; do
cdb2sql ${CDB2_OPTIONS} --host $node $DBNAME "EXEC PROCEDURE sys.cmd.send('reql longreqfile <stdout>')"
cdb2sql ${CDB2_OPTIONS} --host $node $DBNAME "EXEC PROCEDURE sys.cmd.send('reql longrequest 0')"
cdb2sql ${CDB2_OPTIONS} --host $node $DBNAME "EXEC PROCEDURE sys.cmd.send('reql longsqlrequest 0')"
done
}

function test_logic
{
$CDB2SQL_EXE $CDB2_OPTIONS $DBNAME default "insert into t values(1)"
}

function check_logs
{
logfile=
found=0
sleep 20 # give time for .db file to flush
for node in $CLUSTER ; do
logfile="$TESTDIR/logs/$DBNAME.$node.db"
grep 'trigger->dormant' $logfile
if [[ $? == 0 ]]; then
found=1
break
fi
done
[[ "$found" -ne "1" ]] && failexit "longrequest log not found"
}

function create_tables_sp_trigger
{
cdb2sql ${CDB2_OPTIONS} $DBNAME default -f ./tables.sql
cdb2sql ${CDB2_OPTIONS} $DBNAME default -f ./dropsptrigger.sql
cdb2sql ${CDB2_OPTIONS} $DBNAME default -f ./sp.sql
cdb2sql ${CDB2_OPTIONS} $DBNAME default -f ./trigger.sql
}

function run_test
{
create_tables_sp_trigger
setup_longreq
test_logic
check_logs
}

run_test
echo "Success"
exit 0
7 changes: 7 additions & 0 deletions tests/longreq_sp_queries.test/sp.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
CREATE PROCEDURE dormant version '1'{
local function main(event)
db:sleep(2)
db:exec("INSERT INTO triggered select * from generate_series(1,49999)")
return 0
end
}
4 changes: 4 additions & 0 deletions tests/longreq_sp_queries.test/tables.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
DROP TABLE IF EXISTS t;
DROP TABLE IF EXISTS triggered;
CREATE TABLE t(a int primary key)$$
CREATE TABLE triggered(b int)$$
1 change: 1 addition & 0 deletions tests/longreq_sp_queries.test/trigger.sql
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
CREATE LUA TRIGGER dormant on (TABLE t for INSERT);

0 comments on commit e554cb0

Please sign in to comment.