Added fix in CHANGE MASTER TO when MASTER_LOG_FILE is not set
Added fix in CHANGE MASTER TO when MASTER_LOG_FILE is not set
This commit is contained in:
		| @ -2467,23 +2467,27 @@ int blr_handle_change_master(ROUTER_INSTANCE* router, char *command, char *error | |||||||
| 	blr_set_master_port(router, command); | 	blr_set_master_port(router, command); | ||||||
|  |  | ||||||
| 	/** | 	/** | ||||||
| 	 * Change the binlog filename to request from master | 	 * Check for binlog filename in command | ||||||
| 	 * New binlog file could be the next one or current one | 	 * New binlog file could be the next one or current one | ||||||
| 	 */ | 	 */ | ||||||
| 	master_logfile = blr_set_master_logfile(router, command, error); | 	master_logfile = blr_set_master_logfile(router, command, error); | ||||||
|  |  | ||||||
| 	if (!master_logfile) { | 	if (master_logfile == NULL) { | ||||||
|  | 		/* if error return */ | ||||||
|  | 		if (strlen(error)) { | ||||||
|  |  | ||||||
| 			LOGIF(LE, (skygw_log_write_flush(LOGFILE_ERROR, "%s: %s", router->service->name, error))); | 			LOGIF(LE, (skygw_log_write_flush(LOGFILE_ERROR, "%s: %s", router->service->name, error))); | ||||||
|  |  | ||||||
| 		free(master_logfile); |  | ||||||
|  |  | ||||||
| 			/* restore previous master_host and master_port */ | 			/* restore previous master_host and master_port */ | ||||||
| 			blr_master_restore_config(router, current_master); | 			blr_master_restore_config(router, current_master); | ||||||
|  |  | ||||||
| 			spinlock_release(&router->lock); | 			spinlock_release(&router->lock); | ||||||
|  |  | ||||||
| 			return -1; | 			return -1; | ||||||
|  | 		} else { | ||||||
|  | 			/* binlog file not set by CHANGE MASTER, use current binlog */ | ||||||
|  | 			master_logfile = strdup(router->binlog_name); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* Change the position in the current or new binlog filename */ | 	/* Change the position in the current or new binlog filename */ | ||||||
| @ -2527,6 +2531,7 @@ int blr_handle_change_master(ROUTER_INSTANCE* router, char *command, char *error | |||||||
|  |  | ||||||
| 			if (master_log_pos) | 			if (master_log_pos) | ||||||
| 				free(master_log_pos); | 				free(master_log_pos); | ||||||
|  | 			if (master_logfile) | ||||||
| 				free(master_logfile); | 				free(master_logfile); | ||||||
|  |  | ||||||
| 			/* restore previous master_host and master_port */ | 			/* restore previous master_host and master_port */ | ||||||
| @ -2545,6 +2550,7 @@ int blr_handle_change_master(ROUTER_INSTANCE* router, char *command, char *error | |||||||
|  |  | ||||||
| 			if (master_log_pos) | 			if (master_log_pos) | ||||||
| 				free(master_log_pos); | 				free(master_log_pos); | ||||||
|  | 			if (master_logfile) | ||||||
| 				free(master_logfile); | 				free(master_logfile); | ||||||
|  |  | ||||||
| 			LOGIF(LT, (skygw_log_write(LOGFILE_TRACE, "%s: New MASTER_LOG_FILE is [%s]", | 			LOGIF(LT, (skygw_log_write(LOGFILE_TRACE, "%s: New MASTER_LOG_FILE is [%s]", | ||||||
| @ -2566,6 +2572,7 @@ int blr_handle_change_master(ROUTER_INSTANCE* router, char *command, char *error | |||||||
|  |  | ||||||
| 			if (master_log_pos) | 			if (master_log_pos) | ||||||
| 				free(master_log_pos); | 				free(master_log_pos); | ||||||
|  | 			if (master_logfile) | ||||||
| 				free(master_logfile); | 				free(master_logfile); | ||||||
|  |  | ||||||
| 			/* restore previous master_host and master_port */ | 			/* restore previous master_host and master_port */ | ||||||
| @ -2575,8 +2582,10 @@ int blr_handle_change_master(ROUTER_INSTANCE* router, char *command, char *error | |||||||
|  |  | ||||||
| 			return -1; | 			return -1; | ||||||
| 		} else { | 		} else { | ||||||
|  | 			/* pos unchanged, binlogfile unchanged */ | ||||||
| 			if (master_log_pos) | 			if (master_log_pos) | ||||||
| 				free(master_log_pos); | 				free(master_log_pos); | ||||||
|  | 			if (master_logfile) | ||||||
| 				free(master_logfile); | 				free(master_logfile); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 MassimilianoPinto
					MassimilianoPinto