Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enhancements of the redis-rb-cluster #6

Open
wants to merge 73 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 70 commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
3f290d8
convert to 2 space indentation
Sep 11, 2015
60c8832
tests and local dev env build up
Sep 11, 2015
c12782f
skeleton code for a better cluster client
Sep 11, 2015
ae51180
custom exceptions for cluster
Sep 11, 2015
614e8da
lib for managing connections of nodes
Sep 11, 2015
5886a73
unit test for cmds
Sep 11, 2015
6045278
most of list commands. Cross keys operation will be implemented later
Sep 14, 2015
a40d69d
new exception: CrossSlotsError
Sep 15, 2015
1e250dc
str commands
Sep 15, 2015
5da60aa
test for str cmds
Sep 15, 2015
4ee6d00
refactor and improvement over list commands
Sep 15, 2015
f28479c
bug fix in bitop, it is a special command that the target key starts …
Sep 15, 2015
a7c962b
add test for bitop
Sep 15, 2015
c3bac21
remove useless code
Sep 15, 2015
08e0964
sets commands
Sep 15, 2015
1e0d57d
base test case. keep DRY
Sep 15, 2015
dc1a920
on_slot -> in_slot, better variable name
Sep 15, 2015
272e34c
use TestBase class in all test cases, remove usless utils.rb
Sep 15, 2015
571618e
sorted set commands
Sep 15, 2015
6d6e414
unit test for sorted set cmds
Sep 15, 2015
45334cf
hash commands
Sep 16, 2015
636e9ea
unit test for hash commands
Sep 16, 2015
0e108ae
keys commands
Sep 16, 2015
41f3280
unit test for keys commands
Sep 16, 2015
c03fbbe
raise NotImplementedError for not implemented commands
Sep 16, 2015
d044791
monitor command should raise NotImplementedError
Sep 16, 2015
9f8fdbf
fix unstable test
Sep 16, 2015
5e02f54
move local env built-up related to dev folder
Sep 16, 2015
acf98a4
fix local dev env
Sep 16, 2015
5632d6d
always use host instead of ip
Sep 16, 2015
d4367ce
put gems container into docker-compose
Sep 16, 2015
ca0ad20
do not access to the class attr directly, use a method to update it
Sep 17, 2015
d042b04
customised inpspect method, friendly debugging
Sep 17, 2015
86407e9
remove unused code
Sep 17, 2015
642b08e
clean startup nodes, ensure uniq works properly
Sep 17, 2015
05ea252
remove unused import
Sep 17, 2015
0bebeb6
add Rakefile for running all tests
Sep 17, 2015
30a70ac
ignore gem metadata
Sep 17, 2015
16f2d4f
install gemspec locally
Sep 17, 2015
e4f0fbc
cluster.rb -> rediscluster.rb
Sep 17, 2015
9561bec
remove unused import
Sep 17, 2015
e66d70d
update readme for building, installing
Sep 17, 2015
836f242
only support hostname atm
Sep 17, 2015
0af6ceb
make the initialise func readable a bit
Sep 17, 2015
c67c631
clean the code
Sep 17, 2015
9cef57e
switch to require_relative
Sep 17, 2015
9a5d473
make the init_slot_cache a bit faster
Sep 17, 2015
2f5aa66
moveout flushdb test from list command tests
Sep 18, 2015
0cd5963
unit tests for server commands
Sep 18, 2015
0612073
add config command log down the configuration change to each node
Sep 18, 2015
126f924
better info msg
Sep 18, 2015
d9ef68c
no log in keys command
Sep 18, 2015
144f8ca
fix unstable test
Sep 18, 2015
2d5ac82
more server cmds
Sep 18, 2015
122a232
improve the way of passing argments into execute_cmds_on_all_nodes me…
Sep 18, 2015
1efb077
connection commands
Sep 18, 2015
ddcea96
connection cmds unit test
Sep 18, 2015
025539f
enable reade from slave
Sep 24, 2015
a2c229e
remove unused code
Oct 1, 2015
a0c17a1
make inspect friendlier
Oct 1, 2015
e56a064
keep the options in redis-rb
Oct 1, 2015
8641e75
add comments to some key methods
Oct 2, 2015
41967b6
add mapped_hmget, mapped_hmset
Oct 13, 2015
456e980
slaves needs to be covered too
Oct 15, 2015
27c251f
clean the uesless comments
Oct 19, 2015
b240585
add mget mset series commands
Oct 19, 2015
8e3147a
clean the local dev setup
Oct 19, 2015
c73646d
clean local dev and remove unused files
Oct 21, 2015
c8b3fcc
switch back to 4 indentation spaces
Oct 30, 2015
9d3308c
add missing deps for the client
Oct 30, 2015
37448b7
add SSH to local dev container
iandyh May 19, 2016
f02d7bb
customise retry interval and retry when there is a temporary cluster …
iandyh May 19, 2016
44abe03
should be put outside of loop
iandyh May 19, 2016
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
*.gem
Gemfile
21 changes: 21 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
FROM ruby

WORKDIR /
RUN wget https://raw.githubusercontent.com/antirez/redis/3.0/src/redis-trib.rb
RUN chmod o+x redis-trib.rb

RUN apt-get update
RUN apt-get install -y openssh-server
RUN mkdir /var/run/sshd
RUN echo 'root:root' | chpasswd
RUN sed -i 's/PermitRootLogin without-password/PermitRootLogin yes/' /etc/ssh/sshd_config
RUN sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd
ENV NOTVISIBLE "in users profile"
RUN echo "export VISIBLE=now" >> /etc/profile

ENV GEM_HOME /gems
RUN echo "export GEM_PATH=/gems" >> /etc/profile
RUN gem install redis connection_pool
ADD . /code

CMD ["/usr/sbin/sshd", "-D"]
43 changes: 33 additions & 10 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,50 +1,73 @@
# Redis-rb-cluster

Redis Cluster client work in progress.

It wraps Redis-rb, and eventually should be part of it.

For now the goal is to write a simple (but not too simple) client that works

as a reference implementation, and can be used in order to further develop

and test Redis Cluster, that is a work in progress itself.

## Building the Gem locally

`$ gem build redis-rb-cluster.gemspec`

`$ gem install rediscluster-0.1.gem`

## Creating a new instance

In order to create a new Redis Cluster instance use:

startup_nodes = [
{:host => "127.0.0.1", :port => 6379},
{:host => "127.0.0.1", :port => 6380}
]
max_cached_connections = 2
rc = RedisCluster.new(startup_nodes,max_cached_connections)
```
require 'rediscluster'
startup_nodes = [
{:host => "localhost", :port => 6379},
{:host => "localhost", :port => 6380}
]
max_cached_connections = 2
rc = RedisCluster.new(startup_nodes,max_cached_connections)
```

The startup nodes are a list of addresses of Cluster Nodes, for the client to

work it is important that at least one address works. Startup nodes are used

in order to:

* Initialize the hash slot -> node cache, using the `CLUSTER NODES` command.
* To contact a random node every time we are not able to talk with the right node currently cached for the specified hash slot we are interested in, in the context of the current request.
- Initialize the hash slot -> node cache, using the `CLUSTER NODES` command.
- To contact a random node every time we are not able to talk with the right node currently cached for the specified hash slot we are interested in, in the context of the current request.

The list of nodes provided by the user will be extended once the client

will be able to retrieve the cluster configuration.

The second parameter in the object initialization is the maximum number of

connections that the client is allowed to cache. Ideally this should be at

least equal to the number of nodes you have, in order to avoid closing and

reopening TCP sockets. However if you have very large cluster and want to

optimize for clients resource saving, it is possible to use a smaller value.

## Sending commands

Sending commands is very similar to redis-rb:

rc.get("foo")
```
rc.get("foo")
```

Currently only a subset of commands are implemented (and in general multi-keys

commands are not supported by Redis Cluster), because for every supported

command we need a function able to identify the key among the arguments.

## Disclaimer

Redis Cluster is released as stable.
Redis Cluster is released as stable.
This client is a work in progress that might not be suitable to be used in production environments.
7 changes: 7 additions & 0 deletions Rakefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
require 'rake/testtask'

Rake::TestTask.new do |t|
t.libs << "test"
t.test_files = FileList['tests/test*.rb']
t.verbose = true
end
278 changes: 0 additions & 278 deletions cluster.rb

This file was deleted.

Loading