 02ec7e9b17
			
		
	
	02ec7e9b17
	
	
	
		
			
			When calling hkshutdown(), only a shutdown flag will be set. In main() we will then actually wait for the housekeeper thread to finish before exiting.
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 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/bsl.
 | |
|  *
 | |
|  * 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 <time.h>
 | |
| #include <maxscale/dcb.h>
 | |
| #include <maxscale/hk_heartbeat.h>
 | |
| 
 | |
| MXS_BEGIN_DECLS
 | |
| 
 | |
| /**
 | |
|  * @file housekeeper.h A mechanism to have task run periodically
 | |
|  *
 | |
|  * @verbatim
 | |
|  * Revision History
 | |
|  *
 | |
|  * Date         Who             Description
 | |
|  * 29/08/14     Mark Riddoch    Initial implementation
 | |
|  *
 | |
|  * @endverbatim
 | |
|  */
 | |
| 
 | |
| typedef enum
 | |
| {
 | |
|     HK_REPEATED = 1,
 | |
|     HK_ONESHOT
 | |
| } HKTASK_TYPE;
 | |
| 
 | |
| /**
 | |
|  * The housekeeper task list
 | |
|  */
 | |
| typedef struct hktask
 | |
| {
 | |
|     char *name;               /*< A simple task name */
 | |
|     void (*task)(void *data); /*< The task to call */
 | |
|     void *data;               /*< Data to pass the task */
 | |
|     int frequency;            /*< How often to call the tasks (seconds) */
 | |
|     time_t nextdue;           /*< When the task should be next run */
 | |
|     HKTASK_TYPE type;         /*< The task type */
 | |
|     struct hktask *next;      /*< Next task in the list */
 | |
| } HKTASK;
 | |
| 
 | |
| /**
 | |
|  * Initialises the housekeeper mechanism.
 | |
|  *
 | |
|  * A call to any of the other housekeeper functions can be made only if
 | |
|  * this function returns successfully.
 | |
|  *
 | |
|  * @return True if the housekeeper mechanism was initialized, false otherwise.
 | |
|  */
 | |
| extern bool hkinit();
 | |
| 
 | |
| /**
 | |
|  * Shuts down the housekeeper mechanism.
 | |
|  *
 | |
|  * Should be called @b only if @c hkinit() returned successfully.
 | |
|  *
 | |
|  * @see hkinit hkfinish
 | |
|  */
 | |
| extern void hkshutdown();
 | |
| 
 | |
| /**
 | |
|  * Waits for the housekeeper thread to finish. Should be called only after
 | |
|  * hkshutdown() has been called.
 | |
|  */
 | |
| extern void hkfinish();
 | |
| 
 | |
| extern int  hktask_add(const char *name, void (*task)(void *), void *data, int frequency);
 | |
| extern int  hktask_oneshot(const char *name, void (*task)(void *), void *data, int when);
 | |
| extern int  hktask_remove(const char *name);
 | |
| extern void hkshow_tasks(DCB *pdcb);
 | |
| 
 | |
| MXS_END_DECLS
 |