-
Notifications
You must be signed in to change notification settings - Fork 538
Home
Mcrouter is a memcached protocol router for scaling memcached deployments. It's a core component of cache infrastructure at Facebook and Instagram where mcrouter handles almost 5 billion requests per second at peak. See FB engineering blog post about mcrouter.
Mcrouter is developed and maintained by Facebook.
Because the routing and feature logic are abstracted from the client in mcrouter deployments, the client may simply communicate with destination hosts through mcrouter over a TCP connection using standard memcached protocol. Typically, little or no client modification is needed to use mcrouter, which was designed to be a drop-in proxy between the client and memcached hosts.
Mcrouter supports typical memcache protocol commands like get
, set
, delete
, etc. and specific commands to access stats, version and so on.
- Memcached ASCII protocol
- Connection pooling
- Multiple hashing schemes
- Prefix routing
- Replicated pools
- Production traffic shadowing
- Online reconfiguration
- Flexible routing
- Destination health monitoring/automatic failover
- Cold cache warm up
- Broadcast operations
- Reliable delete stream
- Multi-cluster support
- Rich stats counters, Stats commands and debug commands
- Quality of service
- Large values
- IPv6 support
- SSL support
- Initial open source release (mcrouter 1.0) (September 15, 2014)
See installation for more detailed installation instructions.
Mcrouter depends on folly and FBThrift.
The installation is a standard autotools flow:
autoreconf --install
./configure
make
sudo make install
mcrouter --help
Assuming you have a memcached instance on the local host running on port 5001, the simplest mcrouter setup is
mcrouter \
--config-str='{"pools":{"A":{"servers":["127.0.0.1:5001"]}},"route":"PoolRoute|A"}' \
-p 5000
To test, send a request to port 5000. For example, using Netcat:
echo -ne "get key\r\n" | nc 0 5000
For a complete list of command line arguments, check mcrouter --help
.
Engineering discussions and support: https://www.facebook.com/groups/mcrouter
Copyright (c) 2014, Facebook, Inc. All rights reserved.
Licensed under a BSD license: https://github.com/facebook/mcrouter/blob/master/LICENSE
- Installation
- Common setups
- Concepts
- Features
- Configuration
- Monitoring
- Error Handling
- Announcements