Skip to content
/ moxi Public

a memcached proxy with energy and pep

License

BSD-3-Clause, BSD-3-Clause licenses found

Licenses found

BSD-3-Clause
LICENSE
BSD-3-Clause
COPYING
Notifications You must be signed in to change notification settings

steveyen/moxi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

135282d · Sep 16, 2010
Jun 8, 2010
Sep 29, 2009
Feb 22, 2008
Sep 14, 2010
Aug 4, 2010
Sep 29, 2009
Aug 6, 2010
Aug 4, 2010
Sep 10, 2010
Oct 4, 2009
Dec 6, 2007
Jun 14, 2003
Aug 6, 2004
Apr 12, 2009
Apr 17, 2009
Sep 29, 2009
Jun 15, 2003
Sep 7, 2010
Jun 14, 2003
Jul 8, 2010
Sep 3, 2006
Jun 9, 2009
Sep 7, 2010
Sep 16, 2010
Sep 8, 2010
Sep 14, 2010
Aug 6, 2010
Mar 2, 2009
Jul 28, 2010
Jul 28, 2010
Aug 6, 2010
Aug 4, 2010
Sep 29, 2009
Jul 7, 2010
Sep 29, 2009
Jul 7, 2010
Sep 15, 2010
Sep 15, 2010
Sep 14, 2010
Sep 14, 2010
Sep 15, 2010
Aug 6, 2010
Sep 8, 2010
Sep 15, 2010
Sep 8, 2010
Sep 15, 2010
Aug 12, 2010
Sep 15, 2010
Sep 14, 2010
Aug 4, 2010
Aug 12, 2010
Sep 2, 2009
Sep 2, 2009
Mar 19, 2009
Aug 6, 2010
Mar 2, 2009
Sep 7, 2010
Sep 7, 2010
Sep 7, 2010
Aug 12, 2010
Apr 2, 2009
Aug 11, 2010
Jul 28, 2010
Aug 4, 2010
Jun 12, 2009
Sep 9, 2010
Sep 13, 2010
Sep 16, 2010
Sep 15, 2010
Sep 10, 2009
Jun 8, 2010
Jun 17, 2010
Jul 7, 2010
Sep 29, 2009
Aug 6, 2010
Aug 10, 2010
Apr 2, 2009
Aug 4, 2010
Jul 7, 2010
Jan 3, 2009
Aug 6, 2010
Jun 10, 2010
Aug 10, 2010
Sep 8, 2010
Sep 10, 2009
Mar 2, 2009
Aug 4, 2010
Aug 6, 2010
Sep 29, 2009
Aug 12, 2010
Aug 4, 2010
moxi - a memcached/membase proxy with energy and pep

Dependencies:

   -- libevent, http://www.monkey.org/~provos/libevent/ (libevent-dev)

   -- libconflate, http://github.com/northscale/libconflate

   -- libvbucket, http://github.com/northscale/libvbucket

As a backwards-compatible (ketama/consistent-hashing) alternative to
libvbucket, you may instead use libmemcached instead of libvbucket...

   -- libmemcached, http://tangent.org/552/libmemcached.html

To use moxi against membase, however, you'll want libvbucket.

----------

To compile moxi (assuming you want libvbucket), after you got the
dependencies built and installed:

  ./config/autorun.sh
  ./configure
  make

For example, if libevent is installed in /opt/local, you'd do...

  ./config/autorun.sh
  ./configure --with-libevent=/opt/local
  make

----------

Using moxi:

To have moxi load a "vBucket" json configuration from a REST/HTTP
server, try...

  moxi http://host:port/url/of/vBucketServerMapJSON

Against a NorthScale server, for example, this would look like...

  moxi http://host:8080/pools/default/bucketsStreamingConfig/default

The above, also, is just shorthand (assuming you have no other flags
specified), for the following explicit command-line...

  moxi -z url=http://host:8080/url/of/vBucketServerMap.json

To get more command line usage info:

  moxi -h

----------

File-based configuration:

You may also provide a configuration file to moxi that holds a static
vBucket server map.  The file (such as vbucket1.cfg) would look
like...

  11211 = {
    "hashAlgorithm": "CRC",
    "numReplicas": 0,
    "serverList": ["memcached_svr1:11311"],
    "vBucketMap":
      [
        [0],
        [0]
      ]
  }

The above configuration would tell moxi to listen on port 11211, and
proxy to memcached_svr1:11311.  To use a static configuration file,
you would start moxi like...

  moxi -z ./vbucket1.cfg

The "./" path prefix is required so that moxi knows you're passing in
a config file.

----------

Tests:

  # To test that moxi still behaves like memcached
  # and passes all the tests that memcached passes...
  #
  make test

  # To test moxi in a simple proxy topology of...
  #  client <-> moxi <-> memcached
  #
  ./t/moxi.pl

  # To test moxi in a chained proxy topology of...
  #   client <-> moxi <-> moxi <-> moxi <-> memcached
  #
  ./t/moxi.pl chain

  # To test moxi in a fanout topology of...
  #   client <---> moxi <---> memcached
  #                       |-> memcached
  #                       |-> memcached
  #                       |-> memcached
  #
  ./t/moxi.pl fanout

  # To test moxi in a fanout and back in again topology of...
  #   client <---> moxi <---> moxi <-> memcached
  #            |-> moxi <-|
  #            |-> moxi <-|
  #            |-> moxi <-|
  #
  ./t/moxi.pl fanoutin

  # To test moxi proxy cases...
  #
  ./moxi -z 11333=localhost:11311 -t 1
  python t/moxi_mock.py

----------

For vbucket development, start the following...

  ruby ./t/rest_mock.rb

Then start a "pretend" memcached server...

  ./moxi -vvv -p 11311

Then...

  ./moxi -vvv -z url=http://localhost:4567/pools/default/bucketsStreaming/default -Z port_listen=11211

Then...

  telnet localhost 11211

----------

More notes:

If using Linux, you need a kernel with epoll (it's better than select()).

epoll isn't in Linux 2.4 yet, but there's a backport at:

    http://www.xmailserver.org/linux-patches/nio-improve.html

You want the epoll-lt patch (level-triggered).

If you're using MacOS, you'll want libevent 1.1 or higher to deal with
a kqueue bug.

Also, be warned that the -k (mlockall) option to memcached might be
dangerous when using a large cache.  Just make sure the memcached machines
don't swap.  memcached does non-blocking network I/O, but not disk.  (it
should never go to disk, or you've lost the whole point of it)

The memcached website is at:

    http://www.danga.com/memcached/

----------

Using moxi with libmemcached (instead of libvbucket)...

If you want to use moxi explicitly using ketama / consistent-hashing,
you'll need to compile moxi with libmemcached.

First, you would configure moxi differently at build-time...

  ./configure --enable-moxi-vbucket=no \
     CFLAGS=<libmemcached/include> \
     LDFLAGS=<libmemcahed/lib>

After building, moxi understands the following kind of command-line...

  moxi -z <port=<more-config>>

  moxi -z <port=<memcached_host:memcached_port(,*)>>

moxi will listen on the given port and accept connections from
upstream memcached clients.  It will forward requests to downstream
memcached servers running on memcached_host:memcached_port.  For
example...

  moxi -z 11211=my_memcached_server:11222

Above, moxi will listen on port 11211 and forward requests
to the memcached running on my_memcached_server that's listening
on port 11222.

You can list more than one memcached_host:memcached_port,
separated by commas.  For example...

  moxi -z 11211=memcached_1:11211,memcached_2:11211

The default downstream port is 11211, so you can also
just use...

  moxi -z 11211=memcached_1,memcached_2

If you have some memcached servers running on the same server,
but on different ports, you can put moxi in front of them
with something like...

  moxi -z 11211=server:11222,server:11233

About

a memcached proxy with energy and pep

Resources

License

BSD-3-Clause, BSD-3-Clause licenses found

Licenses found

BSD-3-Clause
LICENSE
BSD-3-Clause
COPYING

Stars

Watchers

Forks

Packages

No packages published