MXS-2002 Make Worker excecution mode explicit
This is the first step in some cleanup of the Worker interface. The execution mode must now be explicitly specified, but that is just a temporary step. Further down the road, _posting_ will *always* mean via the message loop while _executing_ will optionally and by default mean direct execution if the calling thread is that of the worker.
This commit is contained in:
@ -604,7 +604,7 @@ size_t RoutingWorker::broadcast(Task* pTask, Semaphore* pSem)
|
||||
Worker* pWorker = this_unit.ppWorkers[i];
|
||||
ss_dassert(pWorker);
|
||||
|
||||
if (pWorker->post(pTask, pSem))
|
||||
if (pWorker->post(pTask, pSem, EXECUTE_AUTO))
|
||||
{
|
||||
++n;
|
||||
}
|
||||
@ -627,7 +627,7 @@ size_t RoutingWorker::broadcast(std::auto_ptr<DisposableTask> sTask)
|
||||
RoutingWorker* pWorker = this_unit.ppWorkers[i];
|
||||
ss_dassert(pWorker);
|
||||
|
||||
if (pWorker->post_disposable(pTask))
|
||||
if (pWorker->post_disposable(pTask, EXECUTE_AUTO))
|
||||
{
|
||||
++n;
|
||||
}
|
||||
@ -650,7 +650,7 @@ size_t RoutingWorker::execute_serially(Task& task)
|
||||
RoutingWorker* pWorker = this_unit.ppWorkers[i];
|
||||
ss_dassert(pWorker);
|
||||
|
||||
if (pWorker->post(&task, &sem))
|
||||
if (pWorker->post(&task, &sem, EXECUTE_AUTO))
|
||||
{
|
||||
sem.wait();
|
||||
++n;
|
||||
@ -894,7 +894,7 @@ bool RoutingWorker::get_qc_stats(int id, QC_CACHE_STATS* pStats)
|
||||
{
|
||||
Semaphore sem;
|
||||
Task task(pStats);
|
||||
pWorker->post(&task, &sem);
|
||||
pWorker->post(&task, &sem, EXECUTE_AUTO);
|
||||
sem.wait();
|
||||
}
|
||||
|
||||
@ -1000,6 +1000,14 @@ std::unique_ptr<json_t> RoutingWorker::get_qc_stats_as_json(const char* zHost)
|
||||
return std::unique_ptr<json_t>(mxs_json_resource(zHost, MXS_JSON_API_QC_STATS, sAll_stats.release()));
|
||||
}
|
||||
|
||||
// static
|
||||
RoutingWorker* RoutingWorker::pick_worker()
|
||||
{
|
||||
static int id_generator = 0;
|
||||
int id = this_unit.id_min_worker + (atomic_add(&id_generator, 1) % this_unit.nWorkers);
|
||||
return get(id);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
size_t mxs_rworker_broadcast_message(uint32_t msg_id, intptr_t arg1, intptr_t arg2)
|
||||
@ -1197,7 +1205,7 @@ json_t* mxs_rworker_to_json(const char* zHost, int id)
|
||||
WorkerInfoTask task(zHost, id + 1);
|
||||
mxs::Semaphore sem;
|
||||
|
||||
target->post(&task, &sem);
|
||||
target->post(&task, &sem, mxs::Worker::EXECUTE_AUTO);
|
||||
sem.wait();
|
||||
|
||||
return task.resource(id);
|
||||
@ -1209,11 +1217,3 @@ json_t* mxs_rworker_list_to_json(const char* host)
|
||||
RoutingWorker::execute_concurrently(task);
|
||||
return task.resource();
|
||||
}
|
||||
|
||||
// static
|
||||
RoutingWorker* RoutingWorker::pick_worker()
|
||||
{
|
||||
static int id_generator = 0;
|
||||
int id = this_unit.id_min_worker + (atomic_add(&id_generator, 1) % this_unit.nWorkers);
|
||||
return get(id);
|
||||
}
|
||||
|
Reference in New Issue
Block a user