fix shutdown race in queue managers
This commit is contained in:
parent
43e8fb6be4
commit
8523f22578
|
@ -1409,16 +1409,22 @@ SWITCH_DECLARE(int) switch_sql_queue_manager_size(switch_sql_queue_manager_t *qm
|
|||
SWITCH_DECLARE(switch_status_t) switch_sql_queue_manager_stop(switch_sql_queue_manager_t *qm)
|
||||
{
|
||||
switch_status_t status = SWITCH_STATUS_FALSE;
|
||||
uint32_t i;
|
||||
uint32_t i, sanity = 100;
|
||||
|
||||
if (qm->thread_running) {
|
||||
qm->thread_running = 0;
|
||||
if (qm->thread_running == 1) {
|
||||
qm->thread_running = -1;
|
||||
|
||||
while(--sanity && qm->thread_running == -1) {
|
||||
for(i = 0; i < qm->numq; i++) {
|
||||
switch_queue_push(qm->sql_queue[i], NULL);
|
||||
switch_queue_interrupt_all(qm->sql_queue[i]);
|
||||
}
|
||||
qm_wake(qm);
|
||||
|
||||
if (qm->thread_running == -1) {
|
||||
switch_yield(100000);
|
||||
}
|
||||
}
|
||||
status = SWITCH_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
|
@ -1498,13 +1504,14 @@ SWITCH_DECLARE(switch_status_t) switch_sql_queue_manager_destroy(switch_sql_queu
|
|||
SWITCH_DECLARE(switch_status_t) switch_sql_queue_manager_push(switch_sql_queue_manager_t *qm, const char *sql, uint32_t pos, switch_bool_t dup)
|
||||
{
|
||||
|
||||
if (sql_manager.paused) {
|
||||
if (sql_manager.paused || qm->thread_running != 1) {
|
||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "DROP [%s]\n", sql);
|
||||
if (!dup) free((char *)sql);
|
||||
qm_wake(qm);
|
||||
return SWITCH_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
if (!qm->thread_running) {
|
||||
if (qm->thread_running != 1) {
|
||||
if (!dup) free((char *)sql);
|
||||
return SWITCH_STATUS_FALSE;
|
||||
}
|
||||
|
@ -1529,6 +1536,13 @@ SWITCH_DECLARE(switch_status_t) switch_sql_queue_manager_push_confirm(switch_sql
|
|||
#ifdef EXEC_NOW
|
||||
switch_cache_db_handle_t *dbh;
|
||||
|
||||
if (sql_manager.paused || qm->thread_running != 1) {
|
||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "DROP [%s]\n", sql);
|
||||
if (!dup) free((char *)sql);
|
||||
qm_wake(qm);
|
||||
return SWITCH_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
if (switch_cache_db_get_db_handle_dsn(&dbh, qm->dsn) == SWITCH_STATUS_SUCCESS) {
|
||||
switch_cache_db_execute_sql(dbh, (char *)sql, NULL);
|
||||
switch_cache_db_release_db_handle(&dbh);
|
||||
|
@ -1547,7 +1561,7 @@ SWITCH_DECLARE(switch_status_t) switch_sql_queue_manager_push_confirm(switch_sql
|
|||
return SWITCH_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
if (!qm->thread_running) {
|
||||
if (qm->thread_running != 1) {
|
||||
if (!dup) free((char *)sql);
|
||||
return SWITCH_STATUS_FALSE;
|
||||
}
|
||||
|
@ -1889,10 +1903,10 @@ static void *SWITCH_THREAD_FUNC switch_user_sql_thread(switch_thread_t *thread,
|
|||
do_flush(qm, i, qm->event_db);
|
||||
}
|
||||
|
||||
qm->thread_running = 0;
|
||||
|
||||
switch_cache_db_release_db_handle(&qm->event_db);
|
||||
|
||||
qm->thread_running = 0;
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue