summaryrefslogtreecommitdiff
path: root/sql/threadpool.h
diff options
context:
space:
mode:
authorVladislav Vaintroub <wlad@mariadb.com>2016-09-21 14:28:42 +0000
committerVladislav Vaintroub <wlad@mariadb.com>2016-09-22 17:01:28 +0000
commitf7a7c0c2fec3dcca331bb529f8314273360c72ae (patch)
tree2e04f4036bd7def676d85690e67e393ec0c41a8e /sql/threadpool.h
parentf32a5115584c9b33a2163df57830ad335cd2b3ab (diff)
downloadmariadb-git-f7a7c0c2fec3dcca331bb529f8314273360c72ae.tar.gz
MDEV-10297 Add priorization to threadpool
Also MDEV-10385 Threadpool refactoring
Diffstat (limited to 'sql/threadpool.h')
-rw-r--r--sql/threadpool.h121
1 files changed, 103 insertions, 18 deletions
diff --git a/sql/threadpool.h b/sql/threadpool.h
index 7ddc661565f..17c8b6ea4ea 100644
--- a/sql/threadpool.h
+++ b/sql/threadpool.h
@@ -23,28 +23,19 @@ extern uint threadpool_max_size;
extern uint threadpool_stall_limit; /* time interval in 10 ms units for stall checks*/
extern uint threadpool_max_threads; /* Maximum threads in pool */
extern uint threadpool_oversubscribe; /* Maximum active threads in group */
+extern uint threadpool_prio_kickup_timer; /* Time before low prio item gets prio boost */
+#ifdef _WIN32
+extern uint threadpool_mode; /* Thread pool implementation , windows or generic */
+#define TP_MODE_WINDOWS 0
+#define TP_MODE_GENERIC 1
+#endif
+struct TP_connection;
+extern void tp_callback(TP_connection *c);
+extern void tp_timeout_handler(TP_connection *c);
-/* Common thread pool routines, suitable for different implementations */
-extern void threadpool_remove_connection(THD *thd);
-extern int threadpool_process_request(THD *thd);
-extern THD* threadpool_add_connection(CONNECT *connect, void *scheduled_data);
-/*
- Functions used by scheduler.
- OS-specific implementations are in
- threadpool_unix.cc or threadpool_win.cc
-*/
-extern bool tp_init();
-extern void tp_add_connection(CONNECT *);
-extern void tp_wait_begin(THD *, int);
-extern void tp_wait_end(THD*);
-extern void tp_post_kill_notification(THD *thd);
-extern void tp_end(void);
-
-/* Used in SHOW for threadpool_idle_thread_count */
-extern int tp_get_idle_thread_count();
/*
Threadpool statistics
@@ -63,9 +54,103 @@ extern void tp_set_min_threads(uint val);
extern void tp_set_max_threads(uint val);
extern void tp_set_threadpool_size(uint val);
extern void tp_set_threadpool_stall_limit(uint val);
+extern int tp_get_idle_thread_count();
+extern int tp_get_thread_count();
/* Activate threadpool scheduler */
extern void tp_scheduler(void);
extern int show_threadpool_idle_threads(THD *thd, SHOW_VAR *var, char *buff,
enum enum_var_type scope);
+
+enum TP_PRIORITY {
+ TP_PRIORITY_HIGH,
+ TP_PRIORITY_LOW,
+ TP_PRIORITY_AUTO
+};
+
+
+enum TP_STATE
+{
+ TP_STATE_IDLE,
+ TP_STATE_RUNNING,
+};
+
+/*
+ Connection structure, encapsulates THD + structures for asynchronous
+ IO and pool.
+
+ Platform specific parts are specified in subclasses called connection_t,
+ inside threadpool_win.cc and threadpool_unix.cc
+*/
+
+struct TP_connection
+{
+ THD* thd;
+ CONNECT* connect;
+ TP_STATE state;
+ TP_PRIORITY priority;
+ TP_connection(CONNECT *c) :
+ thd(0),
+ connect(c),
+ state(TP_STATE_IDLE),
+ priority(TP_PRIORITY_HIGH)
+ {}
+
+ virtual ~TP_connection()
+ {};
+
+ /* Initialize io structures windows threadpool, epoll etc */
+ virtual int init() = 0;
+
+ virtual void set_io_timeout(int sec) = 0;
+
+ /* Read for the next client command (async) with specified timeout */
+ virtual int start_io() = 0;
+
+ virtual void wait_begin(int type)= 0;
+ virtual void wait_end() = 0;
+
+};
+
+
+struct TP_pool
+{
+ virtual ~TP_pool(){};
+ virtual int init()= 0;
+ virtual TP_connection *new_connection(CONNECT *)= 0;
+ virtual void add(TP_connection *c)= 0;
+ virtual int set_max_threads(uint){ return 0; }
+ virtual int set_min_threads(uint){ return 0; }
+ virtual int set_pool_size(uint){ return 0; }
+ virtual int set_idle_timeout(uint){ return 0; }
+ virtual int set_oversubscribe(uint){ return 0; }
+ virtual int set_stall_limit(uint){ return 0; }
+ virtual int get_thread_count() { return tp_stats.num_worker_threads; }
+ virtual int get_idle_thread_count(){ return 0; }
+};
+
+#ifdef _WIN32
+struct TP_pool_win:TP_pool
+{
+ TP_pool_win();
+ virtual int init();
+ virtual ~TP_pool_win();
+ virtual TP_connection *new_connection(CONNECT *c);
+ virtual void add(TP_connection *);
+ virtual int set_max_threads(uint);
+ virtual int set_min_threads(uint);
+};
+#endif
+
+struct TP_pool_generic :TP_pool
+{
+ TP_pool_generic();
+ ~TP_pool_generic();
+ virtual int init();
+ virtual TP_connection *new_connection(CONNECT *c);
+ virtual void add(TP_connection *);
+ virtual int set_pool_size(uint);
+ virtual int set_stall_limit(uint);
+ virtual int get_idle_thread_count();
+};