-
Notifications
You must be signed in to change notification settings - Fork 539
List of Route Handles
###AllAsyncRoute Immediately sends the same request to all child route handles. Does not wait for response. Returns the default reply for the request right away as returned by NullRoute.
Properties:
-
children
: list of child route handles.
###AllFastestRoute Immediately sends the same request to all child route handles. Returns the first non-error reply to come back. Other requests complete in the background and their replies are silently ignored.
Properties:
-
children
: list of child route handles.
###AllInitialRoute
Immediately sends the same request to all child route handles. Waits for the reply from first route handle in the children
list and returns it. Other requests are completed asynchronously in the background.
Properties:
-
children
: list of child route handles.
###AllMajorityRoute Immediately sends the same request to all child route handles. Waits for replies until a non-error result appears (half + 1) times (or all replies if that never happens), and then returns the latest reply that it sees (the effect is that typically the reply with the most common result is returned).
Properties:
-
children
: list of child route handles.
###AllSyncRoute Immediately sends the same request to all child route handles. Collects all replies and responds with the "worst" reply (i.e., the error reply, if any).
Properties:
-
children
: list of child route handles.
###DevNullRoute Same as NullRoute, but with mcrouter stats reporting. See Stats list.
###ErrorRoute
Immediately returns the error reply for each request. You can specify the error value to return: "ErrorRoute|MyErrorValueHere"
###FailoverRoute Sends the request to the first child in the list and waits for the reply. If the reply is a non-error, returns it immediately. Otherwise, sends the request to the second child, and so on. If all children respond with errors, returns the last error reply. Note: miss (key not found) doesn't count for an error. See MissFailoverRoute to failover misses.
Properties:
-
children
: list of child route handles
###FailoverWithExptimeRoute
FailoverRoute with additional settings. Sends request to normal
route handle.
If it responds with an error, checks settings
and failovers to failover
if necessary.
Properties:
-
normal
All requests sent here first. -
failover
List of route handles to which to route in case of error reply fromnormal
. -
failover_exptime
(int, optional, default 60) TTL (in seconds) for update requests sent to failover. Useful when failing over "sets" to a special pool with a small TTL to protect against temporary outages. -
settings
(object, optional)
This object allows tweaking failover logic, such as specifying which errors fromnormal
route handle are returned immediately, without sending tofailover
hosts.
{
"tko": {
"gets": boolean (optional, default true)
"updates": boolean (optional, default true)
"deletes": boolean (optional, default false)
},
"connectTimeout": { /* same as tko */ },
"dataTimeout": { /* same as tko */ }
}
tko
, connectTimeout
and dataTimeout
correspond to reply errors;
gets
, updates
, deletes
correspond to operations. true
configures
mcrouter to failover the request, false
to return the
error immediately. To find out more about errors and operations, see Routing.
###HashRoute Routes to the destination based on key hash.
Properties:
-
children
List of child route handles. -
salt
(string, optional, default empty)
Specifies salt to be added to key before hashing -
hash_func
(string, optional, defaultCh3
)
Which hashing function to use:Ch3
,Crc32
orWeightedCh3
. More about hash functions see here -
weights
(list of doubles, valid only whenhash_func
isWeightedCh3
)
Weight for each destination. Ifweights
has more elements thanchildren
, extra values are ignored. Ifweights
has fewer elements than number of children, missing values are assumed to be0.5
.
###HostIdRoute Routes to one destination chosen based on client host ID.
Properties:
-
children
: list of child route handles.
###LatestRoute
Attempts to "behave well" in how many new targets it connects to.
Creates a FailoverRoute with at-most failover_count
child handles chosen
pseudo-randomly based on client host ID.
Properties:
-
children
List of child route handles. -
failover_count
(int, optional, default 5)
Number of route handles to route to.
###MigrateRoute This route handle changes behavior based on Migration mode.
- Before migration starts, sends all requests to
from
route handle. - Between start_time and (start_time + interval), sends all requests except
deletes to
from
route handle, sends all delete requests to bothfrom
andto
route handle. For delete requests, returns reply from worst of two replies (i.e., any error reply). - Between (start_time + interval) and (start_time + 2*interval), sends all
requests except deletes to
to
route handle and sends all delete requests to bothfrom
andto
route handle. For delete requests, returns reply from worst among two replies. - After (start_time + 2*interval), sends all requests to
to
route handle.
Properties:
-
from
Route handle that routes to destination from which we are migrating. -
to
Route handle that routes to destination to which we are migrating. -
start_time
(int)
Time in seconds from epoch when migration starts. -
interval
(int, options, default 3600)
Duration of migration (in seconds)
###MissFailoverRoute For get-like requests, sends the same request sequentially to each route handle in the list, in order, until the first hit reply. If all replies result in errors/misses, returns the reply from the last destination in the list.
Properties:
-
children
: list of child route handles.
###NullRoute Returns the default reply for each request right away. Default replies are:
-
delete
- not found -
get
- not found -
set
- not stored
No properties.
###PrefixSelectorRoute Sends to different targets based on specified key prefixes.
Properties:
-
wildcard
Default route handle if the key prefix does not match any other specified policies. -
operation_policies
Object, with operation name as key and route handle for specified operation as value. Example:
"route": {
"type": "PrefixSelectorRoute",
"policies": {
"shr": "PoolRoute|shared_pool"
},
"wildcard": "PoolRoute|local_pool_in_second_cluster"
}
See Prefix routing setup for a more detailed example.
###PoolRoute Route handle that routes to a pool. With different settings, it provides the same functionality as HashRoute, but also allows rate limiting, shadowing, et cetera.
Properties:
-
pool
(string or object)
If it is a string, routes to the pool with the specified name. If it is an object, creates a pool on the fly. This object has the same format as item of thepools
property described earlier, but with additionalname
property. Example:
{
"type": "PoolRoute",
"pool": {
"name": "MyPool",
"servers": [ /* pool hosts here */ ]
}
}
-
shadows
(optional, default empty)
List of objects that define additional route handles to which mcrouter should duplicate routed data (shadow). Each object inshadows
has following properties:-
target
Route handle for shadow requests. -
index_range
(array of two integers, both in [0, number of servers in pool - 1])
Only requests sent to servers fromindex_range
will be sent totarget
, -
key_fraction_range
(array of two doubles, both in [0, 1])
Only requests with key hash fromkey_fraction_range
will be sent totarget
. The hash used for this purpose is SpookyHashV2.
-
-
hash
(optional, defaultCh3
)
String or object that defines hash function, same as in HashRoute. -
rates
(optional, default no rate limiting)
If set, enables rate limiting requests to prevent server overload. The object that defines rate and burst are parameters of a token bucket algorithm:
{
"type": "PoolRoute",
"pool": "MyPool",
"rates": {
"gets_rate": double (optional)
"gets_burst": double (optional)
"sets_rate": double (optional)
"sets_burst": double (optional)
"deletes_rate": double (optional)
"deletes_burst": double (optional)
}
}
###OperationSelectorRoute (previously: PrefixPolicyRoute) Sends to different targets based on specified operations.
Properties:
-
default_policy
Default route handle. -
operation_policies
Object, with operation name as key and route handle for specified operation as value. Example:
{
"default_policy": "PoolRoute|A",
"operation_policies": {
"delete": {
"type": "AllSyncRoute",
"children": [ "PoolRoute|A", "PoolRoute|B" ]
}
}
}
Sends gets and sets to pool A, sends deletes to pool A and pool B.
Valid operations are 'get', 'set', 'delete', 'incr', 'decr'.
Route handles for operation_policies
are parsed in alphabetical order (delete, get, set).
###RandomRoute Routes to one random destination from list of children.
Properties:
-
children
: list of child route handles.
###WarmUpRoute Intended for use as the destination route in a Migrate route. Allows for substantial changes to the number of boxes in a pool without increasing the miss rate and, consequently, to the load on the underlying storage or service.
All sets and deletes go to the target ("cold") route handle. Gets are attempted on the "cold" route handle and, in case of a miss, data is fetched from the "warm" route handle (where the request is likely to result in a cache hit). If "warm" returns a hit, the response is forwarded to the client and an asynchronous request, with the configured expiration time, updates the value in the "cold" route handle.
Properties:
-
cold
Route handle that routes to "cold" destination (with empty cache). -
warm
Route handle that routes to "warm" destination (with filled cache). -
exptime
(int, optional, in seconds)
Expiration time for warm up requests.
- Installation
- Common setups
- Concepts
- Features
- Configuration
- Monitoring
- Error Handling
- Announcements