You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

114 lines
3.0 KiB
Markdown

# About
14 years ago
14 years ago
A very simple prototype providing an HTTP interface to Redis. It uses [hiredis](https://github.com/antirez/hiredis) and [jansson](https://github.com/akheron/jansson).
14 years ago
<pre>
make clean all
14 years ago
./dishy &
14 years ago
curl http://127.0.0.1:7379/SET/hello/world
14 years ago
→ {"SET":[true,"OK"]}
14 years ago
curl http://127.0.0.1:7379/GET/hello
14 years ago
→ {"GET":"world"}
14 years ago
14 years ago
curl -d "GET/hello" http://127.0.0.1:7379/
14 years ago
→ {"GET":"world"}
14 years ago
</pre>
14 years ago
# Features
* GET and POST are supported.
* JSON output by default, optional JSONP parameter.
14 years ago
* Raw Redis 2.0 protocol output with `?format=raw`
* HTTP 1.1 pipelining (50,000 http requests per second on a desktop Linux machine.)
14 years ago
* Connects to Redis using a TCP or UNIX socket.
* Restricted commands by IP range (CIDR subnet + mask), returning 403 errors.
* Possible Redis authentication in the config file.
14 years ago
# Ideas, TODO...
14 years ago
* Add meta-data info per key (MIME type in a second key, for instance).
* Support PUT, DELETE, HEAD, OPTIONS? How? For which commands?
* Support pub/sub (waiting for HiRedis ticket \#17 in order to add this.)
* MULTI/EXEC/DISCARD/WATCH are disabled at the moment; find a way to use them.
14 years ago
* Drop privileges.
14 years ago
* Add logging.
* Enrich config file:
* Provide timeout (this needs to be added to hiredis first.)
* Multi-server support, using consistent hashing.
14 years ago
* Send your ideas using the github tracker or on twitter [@yowgi](http://twitter.com/yowgi).
14 years ago
# HTTP error codes
* Unknown HTTP verb: 405 Method Not Allowed
* Redis is unreachable: 503 Service Unavailable
14 years ago
* Could also be used:
* Timeout on the redis side: 503 Service Unavailable
* Missing key: 404 Not Found
* Unauthorized command (disabled in config file): 403 Forbidden
# Command format
The URI `/COMMAND/arg0/arg1/.../argN` executes the command on Redis and returns the response to the client. GET and POST are supported:
14 years ago
* `GET /COMMAND/arg0/.../argN`
14 years ago
* `POST /` with `COMMAND/arg0/.../argN` in the HTTP body.
# JSON output
JSON is the default output format. Each command returns a JSON object with the command as a key and the result as a value.
14 years ago
**Examples:**
<pre>
// string
14 years ago
$ curl http://127.0.0.1:7379/GET/y
14 years ago
{"GET":"41"}
14 years ago
// number
14 years ago
$ curl http://127.0.0.1:7379/INCR/y
14 years ago
{"INCR":42}
// list
14 years ago
$ curl http://127.0.0.1:7379/LRANGE/x/0/1
14 years ago
{"LRANGE":["abc","def"]}
14 years ago
// status
14 years ago
$ curl http://127.0.0.1:7379/TYPE/y
14 years ago
{"TYPE":[true,"string"]}
// error, which is basically a status
14 years ago
$ curl http://127.0.0.1:7379/MAKE-ME-COFFEE
14 years ago
{"MAKE-ME-COFFEE":[false,"ERR unknown command 'MAKE-ME-COFFEE'"]}
14 years ago
// JSONP callback:
$ curl "http://127.0.0.1:7379/TYPE/y?jsonp=myCustomFunction"
myCustomFunction({"TYPE":[true,"string"]})
14 years ago
</pre>
# RAW output
This is the raw output of Redis; enable it with `?format=raw`.
14 years ago
<pre>
// string
$ curl http://127.0.0.1:7379/GET/z?format=raw
$5
14 years ago
hello
// number
curl http://127.0.0.1:7379/INCR/a?format=raw
:2
// list
$ curl http://127.0.0.1:7379/LRANGE/x/0/-1?format=raw
*2
$3
abc
$3
def
// status
$ curl http://127.0.0.1:7379/TYPE/y?format=raw
+zset
// error, which is basically a status
$ curl http://127.0.0.1:7379/MAKE-ME-COFFEE?format=raw
14 years ago
-ERR unknown command 'MAKE-ME-COFFEE'
14 years ago
14 years ago
</pre>