Merge branch '2.1' into 2.2
This commit is contained in:
@ -146,6 +146,7 @@ const char CN_TYPE[] = "type";
|
||||
const char CN_UNIX[] = "unix";
|
||||
const char CN_USER[] = "user";
|
||||
const char CN_USERS[] = "users";
|
||||
const char CN_USERS_REFRESH_TIME[] = "users_refresh_time";
|
||||
const char CN_VERSION_STRING[] = "version_string";
|
||||
const char CN_WEIGHTBY[] = "weightby";
|
||||
|
||||
@ -1660,6 +1661,44 @@ handle_global_item(const char *name, const char *value)
|
||||
{
|
||||
gateway.local_address = MXS_STRDUP_A(value);
|
||||
}
|
||||
else if (strcmp(name, CN_USERS_REFRESH_TIME) == 0)
|
||||
{
|
||||
char* endptr;
|
||||
long users_refresh_time = strtol(value, &endptr, 0);
|
||||
if (*endptr == '\0')
|
||||
{
|
||||
if (users_refresh_time < 0)
|
||||
{
|
||||
MXS_NOTICE("Value of '%s' is less than 0, users will "
|
||||
"not be automatically refreshed.", CN_USERS_REFRESH_TIME);
|
||||
// Strictly speaking they will be refreshed once every 68 years,
|
||||
// but I just don't beleave the uptime will be that long.
|
||||
users_refresh_time = INT32_MAX;
|
||||
}
|
||||
else if (users_refresh_time < USERS_REFRESH_TIME_MIN)
|
||||
{
|
||||
MXS_WARNING("%s is less than the allowed minimum value of %d for the "
|
||||
"configuration option '%s', using the minimum value.",
|
||||
value, USERS_REFRESH_TIME_MIN, CN_USERS_REFRESH_TIME);
|
||||
users_refresh_time = USERS_REFRESH_TIME_MIN;
|
||||
}
|
||||
|
||||
if (users_refresh_time > INT32_MAX)
|
||||
{
|
||||
// To ensure that there will be no overflows when
|
||||
// we later do arithmetic.
|
||||
users_refresh_time = INT32_MAX;
|
||||
}
|
||||
|
||||
gateway.users_refresh_time = users_refresh_time;
|
||||
}
|
||||
else
|
||||
{
|
||||
MXS_ERROR("%s is an invalid value for '%s', using default %d instead.",
|
||||
value, CN_USERS_REFRESH_TIME, USERS_REFRESH_TIME_DEFAULT);
|
||||
gateway.users_refresh_time = USERS_REFRESH_TIME_DEFAULT;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (i = 0; lognames[i].name; i++)
|
||||
|
||||
@ -335,6 +335,34 @@ serviceStartPort(SERVICE *service, SERV_LISTENER *port)
|
||||
}
|
||||
}
|
||||
|
||||
MXS_CONFIG* config = config_get_global_options();
|
||||
time_t last;
|
||||
bool warned;
|
||||
|
||||
/**
|
||||
* At service start last update is set to config->users_refresh_time seconds earlier.
|
||||
* This way MaxScale could try reloading users just after startup. But only if user
|
||||
* refreshing has not been turned off.
|
||||
*/
|
||||
if (config->users_refresh_time == INT32_MAX)
|
||||
{
|
||||
last = time(NULL);
|
||||
warned = true; // So that there will not be a refresh rate warning.
|
||||
}
|
||||
else
|
||||
{
|
||||
last = time(NULL) - config->users_refresh_time;
|
||||
warned = false;
|
||||
}
|
||||
|
||||
int nthreads = config_threadcount();
|
||||
|
||||
for (int i = 0; i < nthreads; ++i)
|
||||
{
|
||||
service->rate_limits[i].last = last;
|
||||
service->rate_limits[i].warned = warned;
|
||||
}
|
||||
|
||||
if (port->listener->func.listen(port->listener, config_bind))
|
||||
{
|
||||
port->listener->session = session_alloc(service, port->listener);
|
||||
@ -1629,22 +1657,24 @@ int service_refresh_users(SERVICE *service)
|
||||
self = 0;
|
||||
}
|
||||
|
||||
MXS_CONFIG* config = config_get_global_options();
|
||||
|
||||
/* Check if refresh rate limit has been exceeded */
|
||||
if ((now < service->rate_limits[self].last + USERS_REFRESH_TIME) ||
|
||||
(service->rate_limits[self].nloads >= USERS_REFRESH_MAX_PER_TIME))
|
||||
if (now < service->rate_limits[self].last + config->users_refresh_time)
|
||||
{
|
||||
MXS_ERROR("[%s] Refresh rate limit exceeded for load of users' table.", service->name);
|
||||
if (!service->rate_limits[self].warned)
|
||||
{
|
||||
MXS_WARNING("[%s] Refresh rate limit (once every %ld seconds) exceeded for "
|
||||
"load of users' table.",
|
||||
service->name, config->users_refresh_time);
|
||||
service->rate_limits[self].warned = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
service->rate_limits[self].nloads++;
|
||||
service->rate_limits[self].last = now;
|
||||
service->rate_limits[self].warned = false;
|
||||
|
||||
/** If we have reached the limit on users refreshes, reset refresh time and count */
|
||||
if (service->rate_limits[self].nloads >= USERS_REFRESH_MAX_PER_TIME)
|
||||
{
|
||||
service->rate_limits[self].nloads = 0;
|
||||
service->rate_limits[self].last = now;
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
LISTENER_ITERATOR iter;
|
||||
|
||||
Reference in New Issue
Block a user