
MXS_WORKER is an abstraction of a worker aka worker thread. It has a pipe whose read descriptor is added to the worker/thread specific poll set and a write descriptor used for sending messages to the worker. The worker exposes a function mxs_worker_post_message using which messages can be sent to the worker. These messages can be sent from any thread but will be delivered on the thread dedicated for the worker. To illustrate how it works, maxadmin has been provided with a new command "ping workers" that sends a message to every worker, which then logs a message to the log. Additional refactoring are needed, since there currently are overlaps and undesirable interactions between the poll mechanism, the thread mechanism and the worker mechanism. This is visible currently, for instance, by it not being possible to shut down MaxScale. The reason is that the workers should be shut down first, then the poll mechanism and finally the threads. The shutdown need to be arranged so that a shutdown message is sent to the workers who then cause the polling loop to exit, which will cause the threads to exit. That can be arranged cleanly by making poll_waitevents() a "method" of the worker, which implies that the poll set becomes a "member variable" of the worker. To be continued.
75 lines
2.1 KiB
C
75 lines
2.1 KiB
C
#pragma once
|
|
/*
|
|
* Copyright (c) 2016 MariaDB Corporation Ab
|
|
*
|
|
* Use of this software is governed by the Business Source License included
|
|
* in the LICENSE.TXT file and at www.mariadb.com/bsl11.
|
|
*
|
|
* Change Date: 2019-07-01
|
|
*
|
|
* On the date above, in accordance with the Business Source License, use
|
|
* of this software will be governed by version 2 or later of the General
|
|
* Public License.
|
|
*/
|
|
|
|
#include <maxscale/cdefs.h>
|
|
#include <maxscale/poll.h>
|
|
|
|
MXS_BEGIN_DECLS
|
|
|
|
typedef struct mxs_worker
|
|
{
|
|
MXS_POLL_DATA poll; /*< The poll data used by the polling mechanism. */
|
|
int id; /*< The id of the worker. */
|
|
int read_fd; /*< The file descriptor the worked reads from. */
|
|
int write_fd; /*< The file descriptor used for sending data to the worker. */
|
|
} MXS_WORKER;
|
|
|
|
enum mxs_worker_msg_id
|
|
{
|
|
/**
|
|
* Ping message.
|
|
*
|
|
* arg1: 0
|
|
* arg2: NULL or pointer to dynamically allocated NULL-terminated string,
|
|
* to be freed by worker.
|
|
*/
|
|
MXS_WORKER_MSG_PING
|
|
};
|
|
|
|
/**
|
|
* Initialize the worker mechanism.
|
|
*
|
|
* To be called once at process startup. This will cause as many workers
|
|
* to be created as the number of threads defined.
|
|
*/
|
|
void mxs_worker_init();
|
|
|
|
/**
|
|
* Return the worker associated with the provided worker id.
|
|
*
|
|
* @param worker_id A worker id.
|
|
*
|
|
* @return The corresponding worker instance, or NULL if the id does
|
|
* not correspond to a worker.
|
|
*/
|
|
MXS_WORKER* mxs_worker_get(int worker_id);
|
|
|
|
/**
|
|
* Post a message to a worker.
|
|
*
|
|
* @param worker The worker to whom the message should be sent.
|
|
* @param msg_id The message id.
|
|
* @param arg1 Message specific first argument.
|
|
* @param arg2 Message specific second argument.
|
|
*
|
|
* @return True if the message could be sent, false otherwise. If the message
|
|
* posting fails, errno is set appropriately.
|
|
*
|
|
* @attention The return value tells *only* whether the message could be sent,
|
|
* *not* that it has reached the worker.
|
|
*/
|
|
bool mxs_worker_post_message(MXS_WORKER* worker, int msg_id, int64_t arg1, void* arg2);
|
|
|
|
MXS_END_DECLS
|