For now, we don't know if device detection modules (51degrees, deviceatlas and
wurfl) are thread-safe or not. So HAproxy exits with an error when you try to
use one of them with nbthread greater than 1.
We will ask to maintainers of these modules to make them thread-safe or to give
us hints to do so.
if (!global_51degrees.data_file_path)
return 0;
+ if (global.nbthread > 1) {
+ Alert("51Degrees: multithreading is not supported for now.\n");
+ return (ERR_FATAL | ERR_ALERT);
+ }
+
if (!LIST_ISEMPTY(&global_51degrees.property_names)) {
i = 0;
list_for_each_entry(name, &global_51degrees.property_names, list)
size_t atlasimglen;
da_status_t status;
+ if (global.nbthread > 1) {
+ Alert("deviceatlas: multithreading is not supported for now.\n");
+ err_code |= ERR_ALERT | ERR_FATAL;
+ goto out;
+ }
+
jsonp = fopen(global_deviceatlas.jsonpath, "r");
if (jsonp == 0) {
Alert("deviceatlas : '%s' json file has invalid path or is not readable.\n",
return ERR_WARN;
}
+ if (global.nbthread > 1) {
+ Alert("WURFL: multithreading is not supported for now.\n");
+ return (ERR_FATAL | ERR_ALERT);
+ }
+
if (wurfl_set_root(global_wurfl.handle, global_wurfl.data_file) != WURFL_OK) {
Warning("WURFL: Engine setting root file failed - %s\n", wurfl_get_error_message(global_wurfl.handle));
send_log(NULL, LOG_WARNING, "WURFL: Engine setting root file failed - %s\n", wurfl_get_error_message(global_wurfl.handle));