Control memcached from the command line

memcached is a general-purpose distributed memory caching system originally developed by Danga Interactive for LiveJournal but now used by many other sites. It is often used to speed up dynamic database-driven websites by caching data and objects in RAM to reduce the number of times an external data source (such as a database or API) must be read. Here we describe the options available from the command line to control a memcached instance via unix socket or IP:port.

method/1536/Screen Shot 2012-08-05 at 17.28.09.png

Memcached can be set up to either take control commands via an IP address and port or via a unix socket.

Starting up

When listening via IP:port by default memcached listens for connections on port 11211 and accepts connections from INADDR_ANY. To prevent possibly malicious access you may want to consider restricting connections to an internal or firewalled connection. Alternatively you can set memcached to only listen for connections on localhost - i.e. the server running the instance of memcached using

To start up an instance of memcached listening on localhost port 11211 only use the following:

memcached -d -m memory -l

memory is the maximum number of megabytes of memory you want memcached to use.

If you want to specify a different port to listen on use the -p PORT option.

Alternatively you can use unix sockets to communicate directly with the memcached instance. In this case commands can only be sent from a login shell that has access to the socket file - for example if you ssh into the server hosting it.

To start up memcached using unix sockets you would use the following command:

memcached -d -m memory -s ~/memcached.sock

This will create a file named memcached.sock in your home directory to communicate through.

Your data problems, solved

On-call analysis, machine learning and visualisation

Get useful information from your data, quickly and accurately with on-call data science consultation and analysis.

Together we'll build evidence-based solutions to your technical and business challenges.

Rapid solutions to your data problems, one-to-one consult and on-call analysis.

Available for consultation 8am-6pm CET/CEST Online

Boost your Python skills

with One-to-One Code Mentoring

Improve your coding skills with tailored one-to-one Python mentoring.

Get customised training and advice covering Python basics, data science, GUIs or Django/Flask web development.

Level up your skills fast with directed Python tutoring & coaching.

Available daily 8am-6pm CET/CEST Online

Ready to build your own apps?

Create Simple GUI Applications with Python and Qt

The complete beginners guide to building cross-platform GUI applications with Python. Step by step from displaying your first window, to fully functional and useable software.

Join 300+ readers already using this book to build awesome things.

77 page ebook, 2.5 hours of video tutorials

Learning Python?

Join the Academy for access to free tutorials, courses and books

Expand your Python knowledge, from absolute basics through application, development, web and data science. New resources added regularly.

Boost your Python skills with up to date resources.

Access 100s of tutorials, courses, videos and ebooks

Memcache management

Memcached comes with a number of useful management commands. Of these the most frequently useful are flush_all and the stats commands including stats, stats items and stats slabs.

To send a command to memcached you can use nc (netcat). The general form for all commands is:

echo "command" | nc 11211

Or for socket connections:

echo "command" | nc -U ~/memcached.sock

To flush the entire contents of your memcached instance you could issue the flush_all command with one of the following:

echo "flush_all" | nc 11211 echo "flush_all" | nc -U ~/memcached.sock

Results in:

[user@web37 ~]$ echo "flush_all" | nc -U ~/memcached.sock OK

[user@web37 ~]$

step/None/Screen Shot 2012-08-05 at 18.19.20.png

Statistics and state

You can use the stats commands to get information about the state of your memcached instance. For example:

echo "stats" | nc 11211 echo "stats" | nc -U ~/memcached.sock

Will output a list of stats for the current instance. Additional information can be found using stats items to give total stats about items stored in the cached and stats slabs which provides more information including performance hints.

step/None/Screen Shot 2012-08-05 at 17.28.09.png

Get regular Shell tips & tutorials direct to your Inbox.


Related posts