Configuration Flags and Runtime Settings

MapD has minimal configuration requirements with a number of additional configuration options. This topic describes the required and optional configuration changes you can use in your MapD instance.

Data Directory

Before starting the MapD server, you must initialize the persistent data directory. To do so, create an empty directory at the desired path, such as /var/lib/mapd. Create the environment variable $MAPD_STORAGE.

export MAPD_STORAGE=/var/lib/mapd

Change the owner of the directory to the user that the server will run as ($MAPD_USER):

sudo mkdir -p $MAPD_STORAGE
sudo chown -R $MAPD_USER $MAPD_STORAGE

Where $MAPD_USER is the system user account that the server runs as, such as mapd, and $MAPD_STORAGE is the path to the parent of the MapD server data directory.

Finally, run $MAPD_PATH/bin/initdb with the data directory path as the argument:

$MAPD_PATH/bin/initdb $MAPD_STORAGE

Configuration File

MapD supports storing options in a configuration file. This is useful if, for example, you need to run the MapD server and web server on ports different than the defaults.

If you store a copy of mapd.conf in the $MAPD_STORAGE directory, the configuration settings are picked up automatically by the sudo systemctl start mapd_server and sudo systemctl start mapd_web_server commands.

Set the flags in the configuration file using the format <flag> = <value>. Strings must be enclosed in quotes. The following is a sample configuration file. The entry for data path is a string and must be in quotes. The entry for the optional read-only flag is the Boolean value true and is not in quotes.

port = 9091
http-port = 9090
data = "/var/lib/mapd/data"
read-only = true


[web]
port = 9092
frontend =
 "/home/osboxes/installs/mapd-3.0.0-20170502-9e5ba95-Linux-x86_64-render/frontend"

Configuration Flags for MapD Server

Configuration Flags for MapD Server
Flag Description Implied Value Default Value Why Change It?
calcite-port arg Calcite port number9093Change to avoid collisions with ports already in use.
cluster argPath to data leaves list JSON file. Indicates that the MapD server instance is an aggregator node, and where to find the rest of its cluster. Enterprise only.$MAPD_STORAGEChange for testing and debugging.
config argPath to mapd.conf$MAPD_STORAGEChange for testing and debugging.
cpuRun on CPU onlyFALSEOne use case for disabling GPUs would be during database conversion. That requires moving a large amount of data with minimal processing.
cpu-buffer-mem-bytes arg Size of memory reserved for CPU buffers [bytes]0
data argDirectory path to MapD catalogs$MAPD_STORAGEChange for testing and debugging.
enable-watchdog [arg]Enable watchdogTRUE[1]TRUE[1]
flush-log [arg]Immediately flush logs to disk.TRUE[1]TRUE[1]Set to FALSE if this is a performance bottleneck.
from-table-reordering [=arg(=1)] (=1)Enable automatic table reordering in FROM clauseTRUE[1]TRUE[1]
gpuRun on GPUs (Default)TRUEOne use case for disabling GPUs would be during database conversion. That requires moving a large amount of data with minimal processing.
gpu-buffer-mem-bytes argSize of memory reserved for GPU buffers [bytes] (per GPU)0Restricts the amount of memory a single process uses, so that when running multitenancy in the cloud several processes can all use the same gpus.
ha-shared-data argDirectory path to shared MapD.directory. Enterprise only.
http-port argHTTP port number9090Change to avoid collisions with ports already in use.
ldap-dn argldap DN Distinguished Name. Enterprise only.(=uid=%s, cn=users, cn=accounts, dc=mapd, dc=com)
ldap-role-query-regex argRegEx to use to extract role from role query result. Enterprise only.
ldap-role-query-url argldap query role URL. Enterprise only.
ldap-superuser-role argThe role name to identify a superuser. Enterprise only.
ldap-uri arg ldap server uri. Enterprise only.
left-deep-join-optimization [=arg]Enable left-deep join optimizationTRUE[1]TRUE[1]
license argPath to file containing license key
null-div-by-zero [=arg]Allows processing to complete when when the dataset would cause a div/0 error.0
num-gpus argNumber of gpus to use-1In a shared environment, you can assign the number of GPUs to a particular application. The default, -1, means use all available GPUs.
read-only [=arg]Enable read-only modeTRUE[1]FALSE[0]Prevents inadvertent (or purposeful) changes to the dataset.
render-mem-bytes argSize of memory reserved for rendering [bytes]500000000 If there is not enough memory available, you might receive the error message Not enough OpenGL memory to render the query results. You can increase the render-mem-bytes allocation, if there's room to do so, and restart the server. You can also try adjusting the query (for example, employ filters or remove unnecessary columns) to get it under the render-mem-bytes limit.
render-poly-cache-bytes argSize of memory reserved for polygon rendering [bytes]300000000
rendering [=arg]Enable/disable backend renderingTRUE[1]TRUE[1]
start-gpu argFirst gpu to useFALSE[0]
string-servers argPath to string servers list JSON file. Enterprise only.

Advanced Configuration Flags for MapD Server

Advanced Configuration Flags for MapD Server
Flag Description Implied Value Default Value Why Change It?
allow-cpu-retry [=arg]Allow the queries which failed on GPU to retry on CPU, even when watchdog is enabled.TRUE[1]FALSE [0]
allow-loop-joins [=arg]Enable loop joinsTRUE[1]FALSE [0]Loop joins can be effective when you compare a large inner dataset to a small outer dataset. When working with two large datasets, performance is predictably slower.
auth-rest-token argToken for REST-based authentication. Enterprise only.
auth-rest-url argURL for REST-based authentication. Enterprise only.
bigint-count [=arg]Use 64-bit countFALSE[0]FALSE[0]
calcite-max-mem argMax memory available to calcite JVM1024
cuda-block-size argSize of block to use on GPU0
cuda-grid-size argSize of grid to use on GPU0
db-convert argDirectory path to MapD DB to convert from
db-query-list argPath to file containing mapd queriesN/AN/AUse a query list to autoload data to GPU memory on startup to speed performance.
disable-legacy-syntax [=arg(=0)] (=1)Legacy syntax is disabled by default. Set this value to 0 to enable legacy syntax.FALSE[0] (i.e., enable legacy syntax)TRUE[1]
disable-multifrag [=arg(=0)] (=1)Disable execution over multiple fragments in a single round-trip to GPUFALSE[0] (i.e., enable multifrag)TRUE[1]A fragment, in this context, is a subset of a data table comprising up to 32MM rows. When disabled, only one fragment is processed at a time.
disable-rendering [=arg(=0)] (=1)Deprecated, use --rendering=falseFALSE[0] (i.e., enable rendering)TRUE[1]
disable-shared-mem-group-byEnable/disable using GPU shared memory for GROUP BY.FALSE[0] (i.e., enable shared memory for GROUP BY)TRUE[1]
dynamic-watchdog-time-limit [=arg]Dynamic watchdog time limit, in milliseconds10000100000
enable-access-priv-check [=arg]Check user access privileges to database objectsTRUE[1]TRUE[1]
enable-debug-timer [=arg]Enable debug timer.TRUE[1]FALSE [0]
enable-dynamic-watchdog [=arg]Enable dynamic watchdogTRUE[1]FALSE [0]
fast-strcmp [=arg]Enable fast string comparisonFALSE[0] (i.e., disable fast string comparison)TRUE[1]
ha-brokers argLocation of the HA brokers. Enterprise only.
ha-group-id argId of the HA group this server is in. Enterprise only.
ha-unique-server-id argUnique id to identify this server in the HA group. Enterprise only.
hll-precision-bits [=arg]Number of bits used from the hash value used to specify the bucket number.1111
inner-join-fragment-skipping [=arg(=1)] (=0)Enable/disable inner join fragment skipping.
jit-debug [=arg]Enable debugger support for the JIT. The generated code can be found at /tmp/mapdquery.TRUE[1]FALSE[0]Increasing might adversely affect render performance and stability.
leaf-conn-timeout [=arg]Leaf connect timeout, in milliseconds. Enterprise only.2000020000
leaf-recv-timeout [=arg]Leaf receive timeout, in milliseconds. Enterprise only.300000300000
leaf-send-timeout [=arg]Leaf send timeout, in milliseconds. Enterprise only.300000300000
num-reader-threads argNumber of reader threads to use0
res-gpu-mem =argReserved memory for GPU, not use MapD allocator.134217728MapD is very greedy. We take all the memory on the GPU except for (Render-Mem-Bytes + Res-Gpu_Mem). We allocate for all of render-mem-bytes at startup. The res-gpu-mem allows you to reserve some extra memory for your system (for example, if your GPU is also driving your display, like on a laptop or single card desktop). This is also a useful flag if you have other processes sharing the GPU with MapD, such as a machine learning pipeline. In advanced rendering scenarios or distributed setups, increasing `res-gpu-mem` allows the system to grab additional memory for the renderer, or for aggregating results for the renderer from multiple leaf nodes.
trivial-loop-join-threshold [=arg]The maximum number of rows in the inner table of a loop join considered to be trivially small10001000
use-result-set [=arg]Use the new result set11

Configuration Flags for MapD Web Server

Configuration Flags for MapD Web Server
Flag Description Default Why Change It?
backend-url URL to http-port on mapd_server http://localhost:9090 Change to avoid collisions with other services.
cert Certificate file for HTTPS cert.pem Change for testing and debugging.
config Path to MapD configuration file   Change for testing and debugging.
data Path to MapD data directory data Change for testing and debugging.
docs string Path to documentation directory docs  
enable-https Enable HTTPS support   Change to enable secure HTTP.
frontend string Path to frontend directory frontend  
key string Key file for HTTPS key.pem Change for testing and debugging.
port int Frontend server port 9092 Change to avoid collisions with other services.
read-only Enable read-only mode   Prevent inadvertent (or nefarious) changes to the data.
servers-json string Path to servers.json   Change for testing and debugging.
timeout Maximum request duration in #h#m#s format 1h0m0s The --timeout option controls the maximum duration of individual HTTP requests. This is used to manage resource exhaustion caused by improperly closed connections. One side effect is that it limits the execution time of queries made over the Thrift HTTP transport. This timeout duration must be increased if queries are expected to take longer than the default duration of one hour; for example, if you perform a COPY FROM on a large file when using mapdql with the HTTP transport.
tmpdir string Path for temporary file storage /tmp The temporary directory is used as a staging location for file uploads. You might want to locate this directory on the same file system as the MapD data directory. If not specified on the command line, mapd_web_server also respects the standard TMPDIR environment variable as well as a specific MAPD_TMPDIR environment variable, the latter of which takes precedence. If you use neither the command-line argument nor one of the environment variables, the default, /tmp/, is used.
verbose Print all log messages to stdout   Change for testing and debugging.

Using Configuration Flags on the Command Line

To use options provided in a configuration file, set the --config flag to the path of the configuration file for mapd_server and mapd_web_server. For example:

$MAPD_PATH/bin/mapd_server --config $MAPD_STORAGE/mapd.conf

You can also specify configuration settings at the command line. MapD recommends that you use the systemctl command to start and stop the servers, but you can use the mapd_server and mapd_web_server commands with configuration flags for testing and debugging.

Command Line Configuration Flags for MapD Server

Command Line Configuration Flags for MapD Server
Flag Description Implied Value Default Value Why Change It?
--calcite-port arg Calcite port number9093Change to avoid collisions with ports already in use.
--cluster argPath to data leaves list JSON file. Indicates that the MapD server instance is an aggregator node, and where to find the rest of its cluster. Enterprise only.$MAPD_STORAGEChange for testing and debugging.
--config argPath to mapd.conf$MAPD_STORAGEChange for testing and debugging.
--cpuRun on CPU onlyFALSEOne use case for disabling GPUs would be during database conversion. That requires moving a large amount of data with minimal processing.
--cpu-buffer-mem-bytes arg Size of memory reserved for CPU buffers [bytes]0
--data argDirectory path to MapD catalogs$MAPD_STORAGEChange for testing and debugging.
--enable-watchdog [arg]Enable watchdogTRUE[1]TRUE[1]
--flush-log [arg]Immediately flush logs to disk.TRUE[1]TRUE[1]Set to FALSE if this is a performance bottleneck.
--from-table-reordering [=arg(=1)] (=1)Enable automatic table reordering in FROM clauseTRUE[1]TRUE[1]
--gpuRun on GPUs (Default)TRUEOne use case for disabling GPUs would be during database conversion. That requires moving a large amount of data with minimal processing.
--gpu-buffer-mem-bytes argSize of memory reserved for GPU buffers [bytes] (per GPU)0 Restricts the amount of memory a single process uses, so that when running multitenancy in the cloud several processes can all use the same GPUs.
--ha-shared-data argDirectory path to shared MapD.directory. Enterprise only.
--help-advancedPrint advanced and experimental options. These options should not normally be used in production.
--http-port argHTTP port number9090Change to avoid collisions with ports already in use.
--ldap-dn argldap DN Distinguished Name. Enterprise only.(=uid=%s, cn=users, cn=accounts, dc=mapd, dc=com)
--ldap-role-query-regex argRegEx to use to extract role from role query result. Enterprise only.
--ldap-role-query-url argldap query role URL. Enterprise only.
--ldap-superuser-role argThe role name to identify a superuser. Enterprise only.
--ldap-uri arg ldap server uri. Enterprise only.
--left-deep-join-optimization [=arg]Enable left-deep join optimizationTRUE[1]TRUE[1]
--license argPath to file containing license key
--null-div-by-zero [=arg]Allows processing to complete when when the dataset would cause a div/0 error.0
--num-gpus argNumber of gpus to use-1In a shared environment, you can assign the number of GPUs to a particular application. The default, -1, means use all available GPUs.
--read-only [=arg]Enable read-only modeTRUE[1]FALSE[0]Prevents inadvertent (or purposeful) changes to the dataset.
--render-mem-bytes argSize of memory reserved for rendering [bytes]500000000 If there is not enough memory available, you might receive the error message Not enough OpenGL memory to render the query results. You can increase the render-mem-bytes allocation, if there's room to do so, and restart the server. You can also try adjusting the query (for example, employ filters or remove unnecessary columns) to get it under the render-mem-bytes limit.
--render-poly-cache-bytes argSize of memory reserved for polygon rendering [bytes]300000000
--rendering [=arg]Enable/disable backend renderingTRUE[1]TRUE[1]
--start-gpu argFirst gpu to useFALSE[0]
--string-servers argPath to string servers list JSON file. Enterprise only.
-h [ --help ] Print help messages
-p [ --port ] argPort number9091Change for testing and debugging.
-v [ --version ]Print the MapD version in use.

Command Line Configuration Flags for MapD Web Server

Command Line Configuration Flags for MapD Web Server
Flag Description Default Why Change It?
-b | backend-url string URL to http-port on mapd_server http://localhost:9090 Change to avoid collisions with other services.
--cert string Certificate file for HTTPS cert.pem Change for testing and debugging.
-c | --config string Path to MapD configuration file   Change for testing and debugging.
-d | --data string Path to MapD data directory data Change for testing and debugging.
--docs string Path to documentation directory docs  
--enable-https Enable HTTPS support   Change to enable secure HTTP.
-f | --frontend string Path to frontend directory frontend  
--key string Key file for HTTPS key.pem Change for testing and debugging.
-p | --port int Frontend server port 9092 Change to avoid collisions with other services.
-r | --read-only Enable read-only mode   Prevent inadvertent (or nefarious) changes to the data.
--servers-json string Path to servers.json   Change for testing and debugging.
--timeout duration Maximum request duration in #h#m#s format. For example 0h30m0s represents a duration of 30 minutes. 1h0m0s The --timeout option controls the maximum duration of individual HTTP requests. This is used to manage resource exhaustion caused by improperly closed connections. One side effect is that it limits the execution time of queries made over the Thrift HTTP transport. This timeout duration must be increased if queries are expected to take longer than the default duration of one hour; for example, if you perform a COPY FROM on a large file when using mapdql with the HTTP transport.
--tmpdir string Path for temporary file storage /tmp The temporary directory is used as a staging location for file uploads. You might want to place this directory on the same file system as the MapD data directory. If not specified on the command line, mapd_web_server also respects the standard TMPDIR environment variable as well as a specific MAPD_TMPDIR environment variable, the latter of which takes precedence. If you use neither the command-line argument nor one of the environment variables, the default, /tmp/ is used.
-v | --verbose Print all log messages to stdout   Change for testing and debugging.
--version Return version    
--db-query-list <path-to-query-list-file> Pre-load data to memory based on SQL queries stored in a list file. n/a Automatically run queries that load the most frequently used data to enhance performance. See Pre-loading Data.