Added example code to router.c ModuleInit and to its Makefile. Put example codes behind SS_DEBUG macros. SS_DEBUG compile flag is defined in Makefile if DEBUG is set in build_makefile.inc, or in command line - 'make DEBUG=Y ', for example.
This commit is contained in:
		| @ -28,7 +28,9 @@ | |||||||
| # 28/06/13      Vilho Raatikka          Added query classifier-related libs and | # 28/06/13      Vilho Raatikka          Added query classifier-related libs and | ||||||
| #                                       commented out mysql client headers and  | #                                       commented out mysql client headers and  | ||||||
| #                                       lib to avoid conflicts. MARIADB_SRC_PATH | #                                       lib to avoid conflicts. MARIADB_SRC_PATH | ||||||
| #                                       is set in build_gateway.inc | #                                       is set in build_gateway.inc. Examples | ||||||
|  | #                                       are behind SS_DEBUG macros. | ||||||
|  |  | ||||||
| include ../../build_gateway.inc | include ../../build_gateway.inc | ||||||
|  |  | ||||||
| LOGPATH := $(ROOT_PATH)/log_manager | LOGPATH := $(ROOT_PATH)/log_manager | ||||||
| @ -44,6 +46,10 @@ CFLAGS=-c -I/usr/include -I../include -I../inih \ | |||||||
| 	-I$(MARIADB_SRC_PATH)/include \ | 	-I$(MARIADB_SRC_PATH)/include \ | ||||||
| 	-Wall -g | 	-Wall -g | ||||||
|  |  | ||||||
|  | ifdef DEBUG | ||||||
|  | 	CFLAGS := $(CFLAGS) -DSS_DEBUG | ||||||
|  | endif | ||||||
|  |  | ||||||
| LDFLAGS=-rdynamic -L$(LOGPATH) -L$(QCLASSPATH) -L$(MARIADB_SRC_PATH)/libmysqld \ | LDFLAGS=-rdynamic -L$(LOGPATH) -L$(QCLASSPATH) -L$(MARIADB_SRC_PATH)/libmysqld \ | ||||||
| 	-Wl,-rpath,$(LOGPATH) -Wl,-rpath,$(UTILSPATH) -Wl,-rpath,$(QCLASSPATH) \ | 	-Wl,-rpath,$(LOGPATH) -Wl,-rpath,$(UTILSPATH) -Wl,-rpath,$(QCLASSPATH) \ | ||||||
| 	-Wl,-rpath,$(MARIADB_SRC_PATH)/libmysqld | 	-Wl,-rpath,$(MARIADB_SRC_PATH)/libmysqld | ||||||
|  | |||||||
| @ -30,9 +30,10 @@ | |||||||
|  *					and bind addr is 0.0.0.0 |  *					and bind addr is 0.0.0.0 | ||||||
|  * 19/06/13	Mark Riddoch		Extract the epoll functionality  |  * 19/06/13	Mark Riddoch		Extract the epoll functionality  | ||||||
|  * 21/06/13	Mark Riddoch		Added initial config support |  * 21/06/13	Mark Riddoch		Added initial config support | ||||||
|  * 26/06/13 |  * 27/06/13 | ||||||
|  * 27/06/13 Vilho Raatikka      Added necessary headers, example functions and |  * 28/06/13 Vilho Raatikka      Added necessary headers, example functions and | ||||||
|  *                              calls to log manager and to query classifier. |  *                              calls to log manager and to query classifier. | ||||||
|  |  *                              Put example code behind SS_DEBUG macros. | ||||||
|  * |  * | ||||||
|  * @endverbatim |  * @endverbatim | ||||||
|  */ |  */ | ||||||
| @ -49,9 +50,12 @@ | |||||||
|  |  | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <mysql.h> | #include <mysql.h> | ||||||
|  |  | ||||||
|  | #if defined(SS_DEBUG) | ||||||
| # include <skygw_utils.h> | # include <skygw_utils.h> | ||||||
| # include <log_manager.h> | # include <log_manager.h> | ||||||
| # include <query_classifier.h> | # include <query_classifier.h> | ||||||
|  | #endif /* SS_DEBUG */ | ||||||
|  |  | ||||||
| /* basic signal handling */ | /* basic signal handling */ | ||||||
| static void sighup_handler (int i) { | static void sighup_handler (int i) { | ||||||
| @ -173,7 +177,7 @@ int handle_event_errors_backend(DCB *dcb) { | |||||||
|  |  | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
|  | #if defined(SS_DEBUG) | ||||||
| static char* server_options[] = { | static char* server_options[] = { | ||||||
|     "raatikka", |     "raatikka", | ||||||
|     "--datadir=/home/raatikka/data/skygw_parse/", |     "--datadir=/home/raatikka/data/skygw_parse/", | ||||||
| @ -238,6 +242,7 @@ return_without_server: | |||||||
|         ss_dfprintf(stderr, "\n<< testmain\n"); |         ss_dfprintf(stderr, "\n<< testmain\n"); | ||||||
|         fflush(stderr); |         fflush(stderr); | ||||||
| } | } | ||||||
|  | #endif /* SS_DEBUG */ | ||||||
|  |  | ||||||
| // main function | // main function | ||||||
| int | int | ||||||
| @ -250,14 +255,14 @@ void		**threads; | |||||||
|     char		buf[1024], *home, *cnf_file = NULL; |     char		buf[1024], *home, *cnf_file = NULL; | ||||||
|     int         i; |     int         i; | ||||||
|  |  | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|     i = atexit(skygw_logmanager_exit); |     i = atexit(skygw_logmanager_exit); | ||||||
|  |  | ||||||
|     if (i != 0) { |     if (i != 0) { | ||||||
|         fprintf(stderr, "Couldn't register exit function.\n"); |         fprintf(stderr, "Couldn't register exit function.\n"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     vilhos_test_for_query_classifier(); |     vilhos_test_for_query_classifier(); | ||||||
|      | #endif | ||||||
| 	if ((home = getenv("GATEWAY_HOME")) != NULL) | 	if ((home = getenv("GATEWAY_HOME")) != NULL) | ||||||
| 	{ | 	{ | ||||||
| 		sprintf(buf, "%s/etc/gateway.cnf", home); | 		sprintf(buf, "%s/etc/gateway.cnf", home); | ||||||
| @ -284,6 +289,7 @@ int i; | |||||||
|  |  | ||||||
| 	if (cnf_file == NULL) | 	if (cnf_file == NULL) | ||||||
| 	{ | 	{ | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|         skygw_log_write( |         skygw_log_write( | ||||||
|                 NULL,  |                 NULL,  | ||||||
|                 LOGFILE_ERROR, |                 LOGFILE_ERROR, | ||||||
| @ -291,7 +297,7 @@ int i; | |||||||
|                        "install one in /etc/gateway.cnf, " |                        "install one in /etc/gateway.cnf, " | ||||||
|                        "$GATEWAY_HOME/etc/gateway.cnf or use the -c " |                        "$GATEWAY_HOME/etc/gateway.cnf or use the -c " | ||||||
|                        "option.\n")); |                        "option.\n")); | ||||||
|  | #endif | ||||||
| 		fprintf(stderr, "Unable to find a gateway configuration file, either install one in\n"); | 		fprintf(stderr, "Unable to find a gateway configuration file, either install one in\n"); | ||||||
| 		fprintf(stderr, "/etc/gateway.cnf, $GATEWAY_HOME/etc/gateway.cnf or use the -c option.\n"); | 		fprintf(stderr, "/etc/gateway.cnf, $GATEWAY_HOME/etc/gateway.cnf or use the -c option.\n"); | ||||||
| 		exit(1); | 		exit(1); | ||||||
| @ -299,9 +305,11 @@ int i; | |||||||
|  |  | ||||||
| 	if (!config_load(cnf_file)) | 	if (!config_load(cnf_file)) | ||||||
| 	{ | 	{ | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|         skygw_log_write(NULL, |         skygw_log_write(NULL, | ||||||
|                         LOGFILE_ERROR, |                         LOGFILE_ERROR, | ||||||
|                         "Failed to load gateway configuration file %s\n"); |                         "Failed to load gateway configuration file %s\n"); | ||||||
|  | #endif | ||||||
| 		fprintf(stderr, "Failed to load gateway configuration file %s\n", cnf_file); | 		fprintf(stderr, "Failed to load gateway configuration file %s\n", cnf_file); | ||||||
| 		exit(1); | 		exit(1); | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -18,18 +18,32 @@ | |||||||
| # Date		Who			Description | # Date		Who			Description | ||||||
| # 27/06/13	Mark Riddoch		Initial framework put in place | # 27/06/13	Mark Riddoch		Initial framework put in place | ||||||
|  |  | ||||||
|  | include ../../../../build_gateway.inc | ||||||
|  |  | ||||||
|  | LOGPATH := $(ROOT_PATH)/log_manager | ||||||
|  | UTILSPATH := $(ROOT_PATH)/utils | ||||||
|  | QCLASSPATH := $(ROOT_PATH)/query_classifier | ||||||
|  |  | ||||||
| CC=cc | CC=cc | ||||||
| CFLAGS=-c -fPIC -I/usr/include -I../../include -I../../../include -Wall -g | CFLAGS=-c -fPIC -I/usr/include -I../../include -I../../../include \ | ||||||
| LDFLAGS=-shared | 	-I$(LOGPATH) -I$(UTILSPATH) -I$(QCLASSPATH) \ | ||||||
|  | 	-I$(MARIADB_SRC_PATH)/include -Wall -g | ||||||
|  | ifdef DEBUG | ||||||
|  | 	CFLAGS := $(CFLAGS) -DSS_DEBUG | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | LDFLAGS=-shared -L$(LOGPATH) -L$(QCLASSPATH) -L$(MARIADB_SRC_PATH)/libmysqld \ | ||||||
|  | 	-Wl,-rpath,$(LOGPATH) -Wl,-rpath,$(UTILSPATH) -Wl,-rpath,$(QCLASSPATH) \ | ||||||
|  | 	-Wl,-rpath,$(MARIADB_SRC_PATH)/libmysqld | ||||||
| SRCS=router.c | SRCS=router.c | ||||||
| OBJ=$(SRCS:.c=.o) | OBJ=$(SRCS:.c=.o) | ||||||
| LIBS=-lssl | LIBS=-lssl -pthread -llog_manager -lquery_classifier -lmysqld | ||||||
| MODULES=libreadwritesplit.so | MODULES=libreadwritesplit.so | ||||||
|  |  | ||||||
| all:	$(MODULES) | all:	$(MODULES) | ||||||
|  |  | ||||||
| libreadwritesplit.so: $(OBJ) | libreadwritesplit.so: $(OBJ) | ||||||
| 	$(CC) $(LDFLAGS) $(OBJ) $(LIBS) -o $@ | 	$(CC) $(LDFLAGS) $(OBJ) $(UTILSPATH)/skygw_utils.o $(LIBS) -o $@ | ||||||
|  |  | ||||||
| .c.o: | .c.o: | ||||||
| 	$(CC) $(CFLAGS) $< -o $@ | 	$(CC) $(CFLAGS) $< -o $@ | ||||||
|  | |||||||
| @ -17,6 +17,13 @@ | |||||||
|  */ |  */ | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <router.h> | #include <router.h> | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|  | # include <stdlib.h> | ||||||
|  | # include <mysql.h> | ||||||
|  | # include <skygw_utils.h> | ||||||
|  | # include <log_manager.h> | ||||||
|  | # include <query_classifier.h> | ||||||
|  | #endif /* SS_DEBUG */ | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @file router.c	The entry points for the read/write query splitting |  * @file router.c	The entry points for the read/write query splitting | ||||||
| @ -36,6 +43,72 @@ static	void	diagnostic(ROUTER *instance, DCB *dcb); | |||||||
|  |  | ||||||
| static ROUTER_OBJECT MyObject = { createInstance, newSession, closeSession, routeQuery, diagnostic }; | static ROUTER_OBJECT MyObject = { createInstance, newSession, closeSession, routeQuery, diagnostic }; | ||||||
|  |  | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|  | static char* server_options[] = { | ||||||
|  |     "raatikka", | ||||||
|  |     "--datadir=/home/raatikka/data/skygw_parse/", | ||||||
|  |     "--skip-innodb", | ||||||
|  |     "--default-storage-engine=myisam", | ||||||
|  |     NULL | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | const int num_elements = (sizeof(server_options) / sizeof(char *)) - 1; | ||||||
|  |  | ||||||
|  | static char* server_groups[] = { | ||||||
|  |     "embedded", | ||||||
|  |     "server", | ||||||
|  |     "server", | ||||||
|  |     "server", | ||||||
|  |     NULL | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | static void vilhos_test_for_query_classifier(void) | ||||||
|  | { | ||||||
|  |         bool failp; | ||||||
|  |         MYSQL* mysql = NULL; | ||||||
|  |          | ||||||
|  |          /** | ||||||
|  |          * Init libmysqld. | ||||||
|  |          */ | ||||||
|  |         failp = mysql_library_init(num_elements, server_options, server_groups); | ||||||
|  |          | ||||||
|  |         if (failp) { | ||||||
|  |             MYSQL* mysql = mysql_init(NULL); | ||||||
|  |             ss_dassert(mysql != NULL); | ||||||
|  |             fprintf(stderr, | ||||||
|  |                     "mysql_init failed, %d : %s\n", | ||||||
|  |                     mysql_errno(mysql), | ||||||
|  |                     mysql_error(mysql)); | ||||||
|  |             goto return_without_server; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         char* str = (char *)calloc(1, | ||||||
|  |                                    sizeof("Query type is ")+ | ||||||
|  |                                    sizeof("QUERY_TYPE_SESSION_WRITE")); | ||||||
|  |         /** | ||||||
|  |          * Call query classifier. | ||||||
|  |          */ | ||||||
|  |         sprintf(str, | ||||||
|  |                 "Query type is %s\n", | ||||||
|  |                 STRQTYPE( | ||||||
|  |                         skygw_query_classifier_get_type( | ||||||
|  |                                 "SELECT user from mysql.user", 0))); | ||||||
|  |         /** | ||||||
|  |          * generate some log | ||||||
|  |          */ | ||||||
|  |         skygw_log_write(NULL, LOGFILE_MESSAGE,str); | ||||||
|  |          | ||||||
|  |         mysql_close(mysql); | ||||||
|  |         mysql_thread_end(); | ||||||
|  |         mysql_library_end(); | ||||||
|  |          | ||||||
|  | return_without_server: | ||||||
|  |         ss_dfprintf(stderr, "\n<< testmain\n"); | ||||||
|  |         fflush(stderr); | ||||||
|  | } | ||||||
|  | #endif /* SS_DEBUG */ | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Implementation of the mandatory version entry point |  * Implementation of the mandatory version entry point | ||||||
|  * |  * | ||||||
| @ -54,6 +127,9 @@ version() | |||||||
| void | void | ||||||
| ModuleInit() | ModuleInit() | ||||||
| { | { | ||||||
|  | #if defined(SS_DEBUG) | ||||||
|  |     vilhos_test_for_query_classifier(); | ||||||
|  | #endif | ||||||
| 	fprintf(stderr, "Initialse read/writer splitting query router module.\n"); | 	fprintf(stderr, "Initialse read/writer splitting query router module.\n"); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 vraatikka
					vraatikka