Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/makenowjust/bashcached

memcached server built on bash + socat
https://github.com/makenowjust/bashcached

bash bash-hacks bash-script memcached shell-script socat

Last synced: 7 days ago
JSON representation

memcached server built on bash + socat

Awesome Lists containing this project

README

        

# bashcached

> memcached server built on [bash] + [socat]

[bash]: https://www.gnu.org/software/bash/
[socat]: http://www.dest-unreach.org/socat/

![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/makenowjust/bashcached/test.yml)

## Feature

It is one file script (small, `(($(< bashcached wc -l) < 100))`!), and it requires only:

- `bash`
- `socat`

So, you can use it as soon as you download it.

It supports multiple connections and implements almost all memcached commands:

- `set`, `add`, `replace`, `append` and `prepend`
- `get`, `delete` and `touch`
- `incr` and `decr`
- `gets` and `cas`
- `flush_all`
- `version` and `quit`

And, it supports to serve over `tcp` and `unix` domain socket.

## Install

You could install `base64`, `bash` and `socat` via `brew` if you use macOS:

```console
$ brew install base64 bash socat
```

(In fact, `bash` is installed in the default on macOS, however it is *too old* to run `bashcached`.)

Or, you could install `socat` via `apt` if you use Ubuntu:

```console
$ sudo apt install socat
```

then, download and chmod.

```console
$ curl -LO https://git.io/bashcached
$ chmod +x bashcached
```

Or, you could use [`bpkg`](https://github.com/bpkg/bpkg) instaed of downloading script:

```console
$ bpkg install makenowjust/bashcached -g
```

## Usage

```console
$ ./bashcached --help
bashcached - memcached built on bash + socat
(C) TSUYUSATO "MakeNowJust" Kitsune 2016-2024

USAGE: bashcached [--help] [--version] [--license] [--protocol=tcp|unix] [--port=PORT] [--check=CHECK]

OPTIONS:
--protocol=tcp|unix protocol name to bind and listen (default: tcp)
--port=PORT port (or filename) to bind and listen (default: 25252)
--check=CHECK interval to check each cache's expire (default: 60)
--help show this help
--version show bashcached's version
--license show bashcached's license
$ ./bashcached &
$ telnet localhost 25252
version
VERSION 5.2.0-bashcached
set hello 0 0 11
hello world
STORED
get hello
VALUE hello 0 11
hello world
END
quit
```

## License and Copyright

MIT and [:sushi:](https://github.com/MakeNowJust/sushi-ware)
© TSUYUSATO "[MakeNowJust](https://quine.codes)" Kitsune <> 2016-2024