oio-sds
allows you to alter a lot of configuration at compile-time as well at runtime. We use a minimal generation tool for a set of variables that can be modified at runtime, and whose default value can be changed at the compile-time. Those variabes are described here
Some variables, though, are not configurable yet, and still require a value to be fixed once for all when compiling the code. Please find below the list of the cmake
directives to control such variables.
Macro | Default | Description |
---|---|---|
OIOSDS_RELEASE | "master" | Global release name |
OIOSDS_PROJECT_VERSION_SHORT | "1.0" | Minor version number |
Used by gcc
Macro | Default | Description |
---|---|---|
DAEMON_DEFAULT_TIMEOUT_READ | 1000 | How long a gridd will block on a recv() (in milliseconds) |
DAEMON_DEFAULT_TIMEOUT_ACCEPT | 1000 | How long a gridd will block on a accept() (in milliseconds) |
Macro | Default | Description |
---|---|---|
OIO_EVT_BEANSTALKD_DEFAULT_TUBE | "oio" |
Macro | Default | Description |
---|---|---|
GCLUSTER_RUN_DIR | "/var/run" | Prefix to spool. |
GCLUSTER_CONFIG_FILE_PATH | "/etc/oio/sds.conf" | System-wide configuration file |
GCLUSTER_CONFIG_DIR_PATH | "/etc/oio/sds.conf.d" | System-wide configuration directory for additional files. |
GCLUSTER_CONFIG_LOCAL_PATH | ".oio/sds.conf" | Local configuration directory. |
GCLUSTER_AGENT_SOCK_PATH | "/var/run/oio-sds-agent.sock" | Default path for agent's socket. |
Macro | Default | Description |
---|---|---|
PROXYD_PREFIX | "v3.0" | Prefix applied to proxyd's URL, second version (with accounts) |
PROXYD_HEADER_PREFIX | "X-oio-" | Prefix for all the headers sent to the proxy |
PROXYD_HEADER_REQID | PROXYD_HEADER_PREFIX "req-id" | Header whose value is printed in access log, destined to agregate several requests belonging to the same session. |
PROXYD_HEADER_NOEMPTY | PROXYD_HEADER_PREFIX "no-empty-list" | Flag sent to the proxy to turn empty list (results) into 404 not found. |
Macro | Default | Description |
---|---|---|
OIO_STAT_PREFIX_REQ | "counter req.hits" | |
OIO_STAT_PREFIX_TIME | "counter req.time" |
Macro | Default | Description |
---|---|---|
SQLX_DIR_SCHEMAS | NULL | Default directory used to gather applicative schema of SQLX bases. NULL by default, meaning that no directory is set, so that there is no attempt to load a schema. |
SQLX_ADMIN_PREFIX_SYS | "sys." | Prefix used for keys used in admin table of sqlite bases |
SQLX_ADMIN_PREFIX_USER | "user." | Prefix used for keys used in admin table of sqlite bases |
SQLX_ADMIN_INITFLAG | SQLX_ADMIN_PREFIX_SYS "sqlx.init" | Key used in admin table of sqlite bases |
SQLX_ADMIN_STATUS | SQLX_ADMIN_PREFIX_SYS "sqlx.flags" | Key used in admin table of sqlite bases |
SQLX_ADMIN_REFERENCE | SQLX_ADMIN_PREFIX_SYS "sqlx.reference" | Key used in admin table of sqlite bases |
SQLX_ADMIN_BASENAME | SQLX_ADMIN_PREFIX_SYS "sqlx.name" | Key used in admin table of sqlite bases |
SQLX_ADMIN_BASETYPE | SQLX_ADMIN_PREFIX_SYS "sqlx.type" | Key used in admin table of sqlite bases |
SQLX_ADMIN_NAMESPACE | SQLX_ADMIN_PREFIX_SYS "sqlx.ns" | Key used in admin table of sqlite bases |
Macro | Default | Description |
---|---|---|
M2V2_ADMIN_PREFIX_SYS | SQLX_ADMIN_PREFIX_SYS "m2." | |
M2V2_ADMIN_PREFIX_USER | SQLX_ADMIN_PREFIX_USER "m2." | |
M2V2_ADMIN_VERSION | M2V2_ADMIN_PREFIX_SYS "version" | |
M2V2_ADMIN_QUOTA | M2V2_ADMIN_PREFIX_SYS "quota" | |
M2V2_ADMIN_SIZE | M2V2_ADMIN_PREFIX_SYS "usage" | |
M2V2_ADMIN_CTIME | M2V2_ADMIN_PREFIX_SYS "ctime" | |
M2V2_ADMIN_VERSIONING_POLICY | M2V2_ADMIN_PREFIX_SYS "policy.version" | |
M2V2_ADMIN_STORAGE_POLICY | M2V2_ADMIN_PREFIX_SYS "policy.storage" | |
M2V2_ADMIN_KEEP_DELETED_DELAY | M2V2_ADMIN_PREFIX_SYS "keep_deleted_delay" | |
META2_INIT_FLAG | M2V2_ADMIN_PREFIX_SYS "init" |
Macro | Default | Description |
---|---|---|
OIO_META1_DIGITS_KEY | "meta1_digits" | Variable name in the /etc/oio/sds.conf to configure the number of digits that name a meta1 base. |
OIO_META1_DIGITS_DEFAULT | 4 | Default number of digits to name a meta1 database |
Macro | Default | Description |
---|---|---|
RAWX_HEADER_PREFIX | "X-oio-chunk-meta-" | Prefix applied to proxyd's URL, second version (with accounts) |
Macro | Default | Description |
---|---|---|
OIO_USE_OLD_FMEMOPEN | undefined | Use the old implementation of glibc's fmemopen . Starting from glibc 2.22 the new implementation lacks the binary mode which made things work. |
Should the client feed a cache with the network errors it encounters, and should those errors be used to prevent RPC to be performed toward 'too-faulty' peers.
- default: FALSE
- type: gboolean
- cmake directive: OIO_CLIENT_ERRORS_CACHE_ENABLED
Sets the number of faults (on the period given by client.errors_cache.period) beyond which a peer is considered as too faulty to try a new RPC.
- default: 15
- type: guint64
- cmake directive: OIO_CLIENT_ERRORS_CACHE_MAX
- range: 1 -> 4294967296
Sets the size of the time window used to count the number of network errors.
- default: 15
- type: gint64
- cmake directive: OIO_CLIENT_ERRORS_CACHE_PERIOD
- range: 1 -> 3600
Tells how long the verbosity remains higher before being reset to the default, after a SIGUSR1 has been received.
- default: 5 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_COMMON_VERBOSITY_RESET_DELAY
- range: 1 * G_TIME_SPAN_SECOND -> 1 * G_TIME_SPAN_HOUR
HTTP User-Agent to be used between any C client and the proxy
- default: ****
- type: string
- cmake directive: OIO_CORE_HTTP_USER_AGENT
Sets the miniimal amount of time between two refreshed of the known CPU-idle counters for the current host. Keep this value small.
- default: 1 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_CORE_PERIOD_REFRESH_CPU_IDLE
- range: 100 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets the minimal amount of time between two refreshes of the known IO-idle counters for the current host. Keep this small.
- default: 1 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_CORE_PERIOD_REFRESH_IO_IDLE
- range: 100 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets the minimal amount of time between two refreshes of the list of the major/minor numbers of the known devices, currently mounted on the current host. If the set of mounted file systems doesn't change, keep this value high.
- default: 30 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_CORE_PERIOD_REFRESH_MAJOR_MINOR
- range: 100 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
TODO: to be documented
- default: TRUE
- type: gboolean
- cmake directive: OIO_CORE_RESOLVER_DIR_SHUFFLE
TODO: to be documented
- default: TRUE
- type: gboolean
- cmake directive: OIO_CORE_RESOLVER_SRV_SHUFFLE
In the current oio-sds client SDK, should the entities be autocreated while accessed for the first time. So, when pushing a content in a container, when this option is set to 'true', the USER and the CONTAINER will be created and configured to the namespace's defaults.
- default: FALSE
- type: gboolean
- cmake directive: OIO_CORE_SDS_AUTOCREATE
In the current oio-sds client SDK, should the rawx services be shuffled before accessed. This helps ensuring a little load-balancing on the client side.
- default: FALSE
- type: gboolean
- cmake directive: OIO_CORE_SDS_NOSHUFFLE
Sets the delay on each notification sent to the BEANSTALK endpoint
- default: 0
- type: gint64
- cmake directive: OIO_EVENTS_BEANSTALKD_DELAY
- range: 0 -> 86400
Sets the priority of each notification sent to the BEANSTALK endpoint
- default: 2147483648
- type: guint
- cmake directive: OIO_EVENTS_BEANSTALKD_PRIO
- range: 0 -> 2147483648
Sets the TTR (time to run) allow on the treatment of the notificatio sent to the beanstalkd
- default: 120
- type: gint64
- cmake directive: OIO_EVENTS_BEANSTALKD_TTR
- range: 0 -> 86400
Sets the buffering delay of the events emitted by the application
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_EVENTS_COMMON_PENDING_DELAY
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets the maximum number of pending events, not received yet by the endpoint
- default: 1000
- type: guint32
- cmake directive: OIO_EVENTS_COMMON_PENDING_MAX
- range: 1 -> 1048576
Sets the maximum number of ACK managed by the ZMQ notification client
- default: 32
- type: guint
- cmake directive: OIO_EVENTS_ZMQ_MAX_RECV
- range: 1 -> 1073741824
Sets the connection timeout, involved in any RPC to a 'meta' service.
- default: 2.0
- type: gdouble
- cmake directive: OIO_GRIDD_TIMEOUT_CONNECT_COMMON
- range: 0.01 -> 120.0
Sets the default timeout for unitary (request/response) RPC, without considering the possible redirection.
- default: 30.0
- type: gdouble
- cmake directive: OIO_GRIDD_TIMEOUT_SINGLE_COMMON
- range: 0.01 -> 120.0
Sets the global timeout of a RPC to e 'meta' service, considering all the possible redirections.
- default: 30.0
- type: gdouble
- cmake directive: OIO_GRIDD_TIMEOUT_WHOLE_COMMON
- range: 0.01 -> 120.0
Anti-DDoS counter-mesure. In the current server, sets the maximum amount of time a queued TCP event may remain in the queue. If an event is polled and the thread sees the event stayed longer than that delay, A '503 Unavailabe' error is replied.
- default: 2 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_META_QUEUE_MAX_DELAY
- range: 10 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets the timeout to the set of (quick) RPC that query a meta0 service
- default: 10.0
- type: gdouble
- cmake directive: OIO_META0_OUTGOING_TIMEOUT_COMMON_REQ
- range: 0.01 -> 60.0
When listing a container, limits the number of items to that value.
- default: 1000
- type: guint
- cmake directive: OIO_META2_BATCH_MAXLEN
- range: 1 -> 100000
How many bytes may be stored in each container.
- default: 0
- type: gint64
- cmake directive: OIO_META2_CONTAINER_MAX_SIZE
- range: 0 -> G_MAXINT64
Should the meta2 check the container state (quota, etc) before generating chunks.
- default: TRUE
- type: gboolean
- cmake directive: OIO_META2_GENERATE_PRECHECK
How many versions for a single alias.
- default: 1
- type: gint64
- cmake directive: OIO_META2_MAX_VERSIONS
- range: -1 -> G_MAXINT64
Sets the period of the periodical reloading of the Load-balancing state, in the current meta2 service.
- default: 10
- type: gint64
- cmake directive: OIO_META2_RELOAD_LB_PERIOD
- range: 1 -> 3600
Sets the period of the periodical reloading of the namespace configuration, in the current meta2 service.
- default: 5
- type: gint64
- cmake directive: OIO_META2_RELOAD_NSINFO_PERIOD
- range: 1 -> 3600
How long should deleted content be kept.
- default: 604800
- type: gint64
- cmake directive: OIO_META2_RETENTION_PERIOD
- range: 1 -> 2592000
Default chunk size for the given namespace.
- default: 10485760
- type: gint64
- cmake directive: OIO_NS_CHUNK_SIZE
- range: 1 -> G_MAXINT64
Default number of bits with flat-NS computation.
- default: 17
- type: guint
- cmake directive: OIO_NS_FLAT_BITS
- range: 0 -> 64
TODO: to be documented
- default: TRUE
- type: gboolean
- cmake directive: OIO_NS_MASTER
TODO: to be documented
- default: meta2=KEEP|3|1;sqlx=KEEP|1|1|;rdir=KEEP|1|1|user_is_a_service=rawx
- type: string
- cmake directive: OIO_NS_SERVICE_UPDATE_POLICY
TODO: to be documented
- default: NONE
- type: string
- cmake directive: OIO_NS_STORAGE_POLICY
Is the NS in a WORM (for Write Once, Read Many --but never delete).
- default: FALSE
- type: gboolean
- cmake directive: OIO_NS_WORM
In a proxy, sets how many containers can be created at once.
- default: 100
- type: guint
- cmake directive: OIO_PROXY_BULK_MAX_CREATE_MANY
- range: 0 -> 10000
In a proxy, sets how many objects can be deleted at once.
- default: 100
- type: guint
- cmake directive: OIO_PROXY_BULK_MAX_DELETE_MANY
- range: 0 -> 10000
In a proxy, sets if any form of caching is allowed
- default: TRUE
- type: gboolean
- cmake directive: OIO_PROXY_CACHE_ENABLED
Should the proxy shuffle the meta1 addresses before contacting them, thus trying to perform a better fanout of the requests.
- default: TRUE
- type: gboolean
- cmake directive: OIO_PROXY_DIR_SHUFFLE
In a proxy, should the process ask the target service (with the help of an option in each RPC) to accept the RPC only if it is MASTER on that DB.
- default: FALSE
- type: gboolean
- cmake directive: OIO_PROXY_FORCE_MASTER
In a proxy, sets the global timeout for all the other RPC issued (not conscience, not stats-related)
- default: 30.0
- type: gdouble
- cmake directive: OIO_PROXY_OUTGOING_TIMEOUT_COMMON
- range: 0.01 -> 60.0
In a proxy, sets the global timeout for 'config' requests issued
- default: 5.0
- type: gdouble
- cmake directive: OIO_PROXY_OUTGOING_TIMEOUT_CONFIG
- range: 0.01 -> 60.0
In a proxy, sets the global timeout for the RPC to the central cosnience service.
- default: 2.0
- type: gdouble
- cmake directive: OIO_PROXY_OUTGOING_TIMEOUT_CONSCIENCE
- range: 0.01 -> 60.0
In a proxy, sets the global timeout for 'stat' requests issued (mostly forwarded for the event-agent)
- default: 5.0
- type: gdouble
- cmake directive: OIO_PROXY_OUTGOING_TIMEOUT_STAT
- range: 0.01 -> 60.0
In a proxy, sets the period between the refreshes of the load-balancing state from the central conscience.
- default: 5
- type: gint64
- cmake directive: OIO_PROXY_PERIOD_CS_DOWNSTREAM
- range: 0 -> 60
In a proxy, sets the period between two sendings of services states to the conscience.
- default: 1
- type: gint64
- cmake directive: OIO_PROXY_PERIOD_CS_UPSTREAM
- range: 1 -> 60
In the proxy, tells the period between the reloadings of the conscience URL, known from the local configuration
- default: 30
- type: gint64
- cmake directive: OIO_PROXY_PERIOD_REFRESH_CSURL
- range: 0 -> 86400
In the proxy, tells the period between two refreshes of the known service types, from the conscience
- default: 30
- type: gint64
- cmake directive: OIO_PROXY_PERIOD_REFRESH_SRVTYPES
- range: 1 -> 86400
In the proxy, tells the period between two refreshes of the namespace configuration, from the conscience
- default: 30
- type: gint64
- cmake directive: OIO_PROXY_PERIOD_RELOAD_NSINFO
- range: 1 -> 3600
In a proxy, upon a read request, should the proxy prefer a service known to host a MASTER copy of the DB. Supersedes proxy.prefer.slave_for_read
- default: FALSE
- type: gboolean
- cmake directive: OIO_PROXY_PREFER_MASTER_FOR_READ
In a proxy, upon a write request, should the proxy prefer services known to host the MASTER copy of the DB
- default: TRUE
- type: gboolean
- cmake directive: OIO_PROXY_PREFER_MASTER_FOR_WRITE
In a proxy, upon a read request, should the proxy prefer a service known to host a SLAVE copy of the DB.
- default: FALSE
- type: gboolean
- cmake directive: OIO_PROXY_PREFER_SLAVE_FOR_READ
In a proxy, tells if the (ugly-as-hell) quirk that sets the score known from the conscience on the corresponding entries in the cache of services 'known to be local'
- default: FALSE
- type: gboolean
- cmake directive: OIO_PROXY_QUIRK_LOCAL_SCORES
Should the proxy shuffle the meta2 addresses before the query, to do a better load-balancing of the requests.
- default: TRUE
- type: gboolean
- cmake directive: OIO_PROXY_SRV_SHUFFLE
In the proxy cache, sets the TTL of a service known to be down
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_PROXY_TTL_SERVICES_DOWN
- range: 0 -> 1 * G_TIME_SPAN_DAY
In a proxy, sets the TTL of each service already encountered
- default: 5 * G_TIME_SPAN_DAY
- type: gint64
- cmake directive: OIO_PROXY_TTL_SERVICES_KNOWN
- range: 0 -> 7 * G_TIME_SPAN_DAY
In the proxy cache, sets the TTL of a local service
- default: 30 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_PROXY_TTL_SERVICES_LOCAL
- range: 0 -> 1 * G_TIME_SPAN_DAY
In a proxy, sets the TTL on each 'known master' entry. That cache is filled each time a redirection to a MASTER occurs, so that we can immediately direct write operation to the service that owns the MASTER copy.
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_PROXY_TTL_SERVICES_MASTER
- range: 0 -> 7 * G_TIME_SPAN_DAY
In a proxy, sets the maximum length for the URL it receives. This options protects stack allocation for that URL.
- default: 2048
- type: guint
- cmake directive: OIO_PROXY_URL_PATH_MAXLEN
- range: 32 -> 65536
TODO: to be documented
- default: TRUE
- type: gboolean
- cmake directive: OIO_RAWX_EVENTS_ALLOWED
Only effective when
server.fd_max_passive
is set to 0 (autodetection). When deducing the maximum number of incoming connections, the rdir reserves that amount of file descritors to reach the database shards, and allocates what remains to the network.
- default: 128
- type: guint
- cmake directive: OIO_RDIR_FD_RESERVE
- range: 64 -> 1024
In any service resolver instanciated, sets the maximum number of entries related to meta0 (meta1 addresses) and conscience (meta0 address)
- default: 0
- type: guint
- cmake directive: OIO_RESOLVER_CACHE_CSM0_MAX_DEFAULT
- range: 0 -> 4194304
In any service resolver instanciated, sets the default TTL on the entries related meta0 (meta1 addresses) and conscience (meta0 address)
- default: 0
- type: gint64
- cmake directive: OIO_RESOLVER_CACHE_CSM0_TTL_DEFAULT
- range: 0 -> G_MAXINT64
In any service resolver instanciated, sets the maximum number of meta1 entries (data-bound services)
- default: 0
- type: guint
- cmake directive: OIO_RESOLVER_CACHE_SRV_MAX_DEFAULT
- range: 0 -> 1048576
In any service resolver instanciated, sets the default TTL on the meta1 entries (data-bound services)
- default: 0
- type: gint64
- cmake directive: OIO_RESOLVER_CACHE_SRV_TTL_DEFAULT
- range: 0 -> G_MAXINT64
In the network core, when the server socket wakes the call to epoll_wait(), that value sets the number of subsequent calls to accept(). Setting it to a low value allows to quickly switch to other events (established connection) and can lead to a strvation on the new connections. Setting to a high value might spend too much time in accepting and ease denials of service (with established but idle cnx).
- default: 64
- type: guint
- cmake directive: OIO_SERVER_BATCH_ACCEPT
- range: 1 -> 4096
In the network core of a server, how many events do you manage in each call to epoll_wait(). Set to a low value to quickly react on new connections, to an higher value to rather treat established connections. The value is bound to a stack-allocated buffer, keep it rather small.
- default: 128
- type: guint
- cmake directive: OIO_SERVER_BATCH_EVENTS
- range: 1 -> 4096
In the current server, sets the maximumu amount of time a connection may live without activity since the last activity (i.e. the last reply sent)
- default: 5 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_SERVER_CNX_TIMEOUT_IDLE
- range: 0 -> 1 * G_TIME_SPAN_DAY
In the current server, sets the maximum amount of time an established connection is allowed to live when it has no activity at all.
- default: 30 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SERVER_CNX_TIMEOUT_NEVER
- range: 0 -> 1 * G_TIME_SPAN_DAY
In the current server, sets the maximum amount of time a connection is allowed to live, since its creation by the accept() call, wheter it presents activity or not.
- default: 2 * G_TIME_SPAN_HOUR
- type: gint64
- cmake directive: OIO_SERVER_CNX_TIMEOUT_PERSIST
- range: 0 -> 1 * G_TIME_SPAN_DAY
Set to 0 for an automatic detection
- default: 0
- type: guint
- cmake directive: OIO_SERVER_FD_MAX_PASSIVE
- range: 0 -> 4096
TODO: to be documented
- default: FALSE
- type: gboolean
- cmake directive: OIO_SERVER_LOG_OUTGOING
Sets how many bytes bytes are released when the LEAN request is received by the current 'meta' service.
- default: 0
- type: guint
- cmake directive: OIO_SERVER_MALLOC_TRIM_SIZE_ONDEMAND
- range: 0 -> 2147483648
Sets how many bytes bytes are released when the LEAN request is received by the current 'meta' service.
- default: 0
- type: guint
- cmake directive: OIO_SERVER_MALLOC_TRIM_SIZE_PERIODIC
- range: 0 -> 2147483648
In the current server, sets how long a thread can remain unused before considered as idle (and thus to be stopped)
- default: 30 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SERVER_POOL_MAX_IDLE
- range: 1 -> 1 * G_TIME_SPAN_HOUR
In the current server, sets how many threads are allowed to the stats server. Keep this value really small, 1 should be enough for most usages, and consider increasing it if you have clues that the management of internal metrics is the bottleneck. Set to 0 for no limit.
- default: 1
- type: gint
- cmake directive: OIO_SERVER_POOL_MAX_STAT
- range: 0 -> 1073741824
In the current server, sets the maximum number of threads for the pool responsible for the TCP connections (threading model is one thread per request being managed, and one request at once per TCP connection). Set to 0 for no limit.
- default: 0
- type: gint
- cmake directive: OIO_SERVER_POOL_MAX_TCP
- range: 0 -> 1073741824
In the current server, sets the maximum number of threads for pool responsible for the UDP messages handling. UDP is only used for quick synchronisation messages during MASTER elections. Set ot 0 for no limit.
- default: 4
- type: gint
- cmake directive: OIO_SERVER_POOL_MAX_UDP
- range: 0 -> 1073741824
In the current server, sets how many threads may remain unused. This value is, in the GLib, common to all the threadpools.
- default: 20
- type: gint
- cmake directive: OIO_SERVER_POOL_MAX_UNUSED
- range: 0 -> 1073741824
Anti-DDoS counter-mesure. In the current server, sets the maximum amount of time a queued TCP event may remain in the queue. If an event is polled and the thread sees the event stayed longer than that delay, the connection is immediately closed. Keep this value rather high because the connection closing doesn't involve a reply that will help the client to retry with an exponential back-off.
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SERVER_QUEUE_MAX_DELAY
- range: 10 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
In the current server, set the time threshold after which a warning is sent when a file descriptor stays longer than that in the queue of the Thread Pool.
- default: 100 * G_TIME_SPAN_MILLISECOND
- type: gint64
- cmake directive: OIO_SERVER_QUEUE_WARN_DELAY
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
In the current server, sets the maximumu length of the queue for UDP messages. When that number has been reached and a new message arrives, the message will be dropped.
- default: 8192
- type: guint
- cmake directive: OIO_SERVER_UDP_QUEUE_MAX
- range: 0 -> 2147483648
In the current server, sets the maximum amount of time a queued UDP frame may remain in the queue. When unqueued, if the message was queued for too long, it will be dropped. The purpose of such a mechanism is to avoid clogging the queue and the whole election/cache mechanisms with old messages, thoses message having already been resent.
- default: 2 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SERVER_UDP_QUEUE_TTL
- range: 100 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_DAY
Should the socket to meta~ services use TCP_FASTOPEN flag.
- default: TRUE
- type: gboolean
- cmake directive: OIO_SOCKET_FASTOPEN_ENABLED
When socket.linger.enabled is set to TRUE, socket.linger.delat tells how the socket remains in the TIME_WAIT state after the close() has been called.
- default: 1
- type: gint64
- cmake directive: OIO_SOCKET_LINGER_DELAY
- range: 0 -> 60
Set to TRUE to allow the LINGER behavior of TCP sockets, as a default. The connections then end with a normal FIN packet, and go in the TIME_WAIT state for a given delay. Setting to FALSE causes connections to be closed with a RST packet, then avoiding a lot of TCP sockets in the TIME_WAIT state.
- default: FALSE
- type: gboolean
- cmake directive: OIO_SOCKET_LINGER_ENABLED
Should the socket to meta~ services receive the TCP_NODELAY flag. When TRUE, it disables the Naggle's algorithm.
- default: TRUE
- type: gboolean
- cmake directive: OIO_SOCKET_NODELAY_ENABLED
Should the sockets opened by the application receive the TCP_QUICKACK flag.
- default: TRUE
- type: gboolean
- cmake directive: OIO_SOCKET_QUICKACK_ENABLED
Sets the heat value below which a databse is considered hot
- default: 1
- type: guint32
- cmake directive: OIO_SQLITEREPO_CACHE_HEAT_THRESHOLD
- range: 1 -> 2147483648
Triggers an alert when a thread tries to wait for an overloaded database.
- default: TRUE
- type: gboolean
- cmake directive: OIO_SQLITEREPO_CACHE_HEAVYLOAD_ALERT
Triggers an error when a thread waits for an overloaded database.
- default: FALSE
- type: gboolean
- cmake directive: OIO_SQLITEREPO_CACHE_HEAVYLOAD_FAIL
Sets how long we (unit)wait on the lock around the databases. Keep it small.
- default: 1 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_CACHE_TIMEOUT_LOCK
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets how long a worker thread accepts for a DB to become available.
- default: 20 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_CACHE_TIMEOUT_OPEN
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_DAY
Sets the period after the return to the IDLE/COLD state, during which the recycling is forbidden
- default: 0
- type: gint64
- cmake directive: OIO_SQLITEREPO_CACHE_TTL_COOL
- range: 0 -> 1 * G_TIME_SPAN_HOUR
Sets the period after the return to the IDLE/HOT state, during which the recycling is forbidden
- default: 0
- type: gint64
- cmake directive: OIO_SQLITEREPO_CACHE_TTL_HOT
- range: 0 -> 1 * G_TIME_SPAN_HOUR
Sets how many threads can wait on a single database. All the additional waiters will be denied with any wait attempt.
- default: 16
- type: guint32
- cmake directive: OIO_SQLITEREPO_CACHE_WAITING_MAX
- range: 0 -> 2147483648
In the current sqliterepo repository, sets the maximum amount of time a periodical task may take, while checking for the timeouts on the outbound connections.
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_CLIENT_TIMEOUT_ALERT_IF_LONGER
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
In the current sqliterepo repository, sets the amount of time after which a MASTER election will drop its status and return to the NONE status. This helps recycling established-but-unused elections, and save Zookeeper nodes. Keep this value between sqliterepo.election.delay.expire_slave and sqliterepo.election.delay.expire_slave + sqliterepo.election.delay.ping_final.
- default: 25 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_DELAY_EXPIRE_MASTER
- range: 1 * G_TIME_SPAN_MILLISECOND -> 7 * G_TIME_SPAN_DAY
In the current sqliterepo repository, sets the amount of time an election without status will be forgotten
- default: 5 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_DELAY_EXPIRE_NONE
- range: 1 * G_TIME_SPAN_SECOND -> 1 * G_TIME_SPAN_DAY
In the current sqliterepo repository, sets the amount of time after which a SLAVE election will drop its status and return to the NONE status. This helps recycling established-but-unused elections, and save Zookeeper nodes.
- default: 15 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_DELAY_EXPIRE_SLAVE
- range: 1 * G_TIME_SPAN_SECOND -> 7 * G_TIME_SPAN_DAY
In the current sqliterepo repository, sets the average amount of time after which a PING will be sent for an established election. This is an average, in facts a jitter is introduced to avoid resonance effects on large-scale platforms.
- default: 15 * G_TIME_SPAN_MINUTE
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_DELAY_PING_FINAL
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_DAY
In the current sqliterepo repository, sets the amount of time after which a failed election leaves its FAILED status and returns to the NONE status.
- default: 2 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_DELAY_RETRY_FAILED
- range: 1 * G_TIME_SPAN_MILLISECOND -> 7 * G_TIME_SPAN_DAY
In the current sqliterepo repository, sets the amount of time spent in an election resolution that will make a worker thread won't wait at all an consider that election is stalled.
- default: 15 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_NOWAIT_AFTER
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets how many elections can be expired during the periodical expiration task.
- default: 100
- type: guint
- cmake directive: OIO_SQLITEREPO_ELECTION_TASK_EXPIRE_MAX_PER_ROUND
- range: 1 -> 2147483648
In the current sqliterepo repository, sets the maximum amount of time a worker thread is allowed to wait for an election to get its final status.
- default: 5 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_WAIT_DELAY
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
In the current sqliterepo repository, while loop-waiting for a final election status to be reached, this value sets the unit amount of time of eacch unit wait on the lock. Keep this value rather small to avoid waitin for too long, but not too small to avoid dumping CPU cycles in active waiting.
- default: 1 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_ELECTION_WAIT_QUANTUM
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
Sets the connection timeout when exchanging versions between databases replicas.
- default: 0.5
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_CNX_GETVERS
- range: 0.01 -> 30.0
Sets the connection timeout sending a replication request.
- default: 1.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_CNX_REPLICATE
- range: 0.01 -> 30.0
Set the connection timeout during RPC to ask for a SLAVE database to be resync on its MASTER
- default: 1.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_CNX_RESYNC
- range: 0.01 -> 30.0
Sets the connection timeout when ping'ing a peer database. Keep it small. Only used when UDP is disabled.
- default: 0.25
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_CNX_USE
- range: 0.01 -> 30.0
Sets the global timeout when performing a version exchange RPC. Keep it rather small, to let election quickly fail on network troubles. Only used when UDP is disabled.
- default: 2.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_REQ_GETVERS
- range: 0.01 -> 30.0
Sets the global timeout when sending a replication RPC, from the current MASTER to a SLAVE
- default: 10.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_REQ_REPLICATE
- range: 0.01 -> 30.0
Sets the global timeout of a RESYNC request sent to a 'meta' service. Sent to a SLAVE DB, the RESYNC operation involves a RPC from the SLAVE to the MASTER, then a DB dump on the MASTER and restoration on the SLAVE. Thus that operation might be rather long, due to the possibility of network/disk latency/bandwidth, etc.
- default: 30.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_REQ_RESYNC
- range: 0.01 -> 60.0
Sets the global timeout when ping'ing a peer database. Keep it small.
- default: 1.0
- type: gdouble
- cmake directive: OIO_SQLITEREPO_OUTGOING_TIMEOUT_REQ_USE
- range: 0.01 -> 30.0
In the current sqliterepo repository, sets the page size of all the databases used. This value only has effects on databases created with that value.
- default: 4096
- type: guint
- cmake directive: OIO_SQLITEREPO_PAGE_SIZE
- range: 512 -> 1048576
Sets how many bytes bytes are released when the LEAN request is received by the current 'meta' service.
- default: 67108864
- type: guint
- cmake directive: OIO_SQLITEREPO_RELEASE_SIZE
- range: 1 -> 2147483648
Set to 0 for an automatic detection
- default: 0
- type: guint
- cmake directive: OIO_SQLITEREPO_REPO_FD_MAX_ACTIVE
- range: 0 -> 4096
Sets how many versions exchanges are allowed during the journey in the election FSM.
- default: 2
- type: guint
- cmake directive: OIO_SQLITEREPO_REPO_GETVERS_MAX_RETRIES
- range: 1 -> 64
Sets how many databases can be kept simultaneously open in the current service.
- default: 32768
- type: guint
- cmake directive: OIO_SQLITEREPO_REPO_HARD_MAX
- range: 8 -> 131072
Sets how many databases can be kept simultaneously open in the current service.
- default: 0
- type: guint
- cmake directive: OIO_SQLITEREPO_REPO_SOFT_MAX
- range: 0 -> 131072
.
- default: 10 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_SERVICE_EXIT_TTL
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
For testing purposes. The value simulates ZK sharding on different connection to the same cluster.
- default: 1
- type: guint
- cmake directive: OIO_SQLITEREPO_ZK_MUX_FACTOR
- range: 1 -> 64
Sets the maximum number of reconnections to the ZK that remains acceptable. Beyond that limit, we consider the current service has been disconnected, and that it loast all its nodes.
- default: 5
- type: guint
- cmake directive: OIO_SQLITEREPO_ZK_RRD_THRESHOLD
- range: 1 -> 2147483648
Sets the time window to remember the reconnection events, on a ZK connection.
- default: 30
- type: guint
- cmake directive: OIO_SQLITEREPO_ZK_RRD_WINDOW
- range: 1 -> 4095
Should the synchronism mechanism shuffle the set of URL in the ZK connection string? Set to yes as an attempt to a better balancing of the connections to the nodes of the ZK cluster.
- default: TRUE
- type: gboolean
- cmake directive: OIO_SQLITEREPO_ZK_SHUFFLE
Sets the timeout of the zookeeper handle (in the meaning of the zookeeper client library)
- default: 10 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_SQLITEREPO_ZK_TIMEOUT
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_HOUR
In the current sqlx-based service, tells the period (in seconds) at which the service will refresh its load-balancing information.
- default: 1
- type: gint64
- cmake directive: OIO_SQLX_LB_REFRESH_PERIOD
- range: 1 -> 60
Sets the timeout for the requests issued to the SQLX services.
- default: 30.0
- type: gdouble
- cmake directive: OIO_SQLX_OUTGOING_TIMEOUT_REQ
- range: 0.01 -> 60.0
TODO: to be documented
- default: FALSE
- type: gboolean
- cmake directive: OIO_UDP_ALLOWED
These variables are only active when the ENBUG option has been specified on the cmake command line.
Set the probability of fake timeout failures, in any client RPC to a 'meta' service
- default: 10
- type: gint32
- cmake directive: OIO_ENBUG_CLIENT_FAKE_TIMEOUT_THRESHOLD
- range: 0 -> 0
In testing situations, sets the average ratio of requests failing for a fake reason (from the peer). This helps testing the retrial mechanisms.
- default: 10
- type: gint32
- cmake directive: OIO_ENBUG_SQLITEREPO_CLIENT_FAILURE_THRESHOLD
- range: 0 -> 100
In testing situations, sets the average ratio of requests failing for a fake reason (connection timeout). This helps testing the retrial mechanisms and the behavior under strong network split-brain.
- default: 1 * G_TIME_SPAN_SECOND
- type: gint64
- cmake directive: OIO_ENBUG_SQLITEREPO_CLIENT_TIMEOUT_PERIOD
- range: 1 * G_TIME_SPAN_MILLISECOND -> 1 * G_TIME_SPAN_DAY
Fake Error rate on synchronism RPC (a.k.a. ZK)
- default: 10
- type: gint32
- cmake directive: OIO_ENBUG_SQLITEREPO_SYNCHRO_FAILURE
- range: 0 -> 100