Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Jérome Perrin
gitlab-ce
Commits
c76ff8cf
Commit
c76ff8cf
authored
Sep 22, 2016
by
Gabriel Mazetto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improved redis sentinel documentation for CE
parent
a6b49757
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
36 deletions
+26
-36
doc/administration/high_availability/redis.md
doc/administration/high_availability/redis.md
+26
-36
No files found.
doc/administration/high_availability/redis.md
View file @
c76ff8cf
...
@@ -143,6 +143,7 @@ the master, and `masterauth` in slaves.
...
@@ -143,6 +143,7 @@ the master, and `masterauth` in slaves.
redis['port'] = 6379
redis['port'] = 6379
## Slave redis instance
## Slave redis instance
redis['master'] = false
redis['master_ip'] = '10.10.10.10' # IP of master Redis server
redis['master_ip'] = '10.10.10.10' # IP of master Redis server
redis['master_port'] = 6379 # Port of master Redis server
redis['master_port'] = 6379 # Port of master Redis server
redis['master_password'] = "<huge password string here>"
redis['master_password'] = "<huge password string here>"
...
@@ -157,31 +158,19 @@ servers.
...
@@ -157,31 +158,19 @@ servers.
### Sentinel setup
### Sentinel setup
We don't provide yet an automated way to setup and run the Sentinel daemon
We provide an automated way to setup and run the Sentinel daemon
from Omnibus installation method. You must follow the instructions below and
with GitLab EE.
run it by yourself.
The support for Sentinel in Ruby has some
[
caveats
](
https://github.com/redis/redis-rb/issues/531
)
.
See the instructions below how to setup it by yourself.
While you can give any name for the
`master-group-name`
part of the
configuration, as in this example:
```
conf
sentinel
monitor
<
master
-
group
-
name
> <
ip
> <
port
> <
quorum
>
```
,for it to work in Ruby, you have to use the "hostname" of the master Redis
server, otherwise you will get an error message like:
`Redis::CannotConnectError: No sentinels available.`
. Read
[
Sentinel troubleshooting
](
#sentinel-troubleshooting
)
for more information.
Here is an example configuration file (
`sentinel.conf`
) for a Sentinel node:
Here is an example configuration file (
`sentinel.conf`
) for a Sentinel node:
```
conf
```
conf
port
26379
port
26379
sentinel
monitor
master
-
redis
.
example
.
com
10
.
10
.
10
.
10
6379
1
sentinel
monitor
gitlab
-
redis
10
.
0
.
0
.
1
6379
1
sentinel
down
-
after
-
milliseconds
master
-
redis
.
example
.
com
10000
sentinel
down
-
after
-
milliseconds
gitlab
-
redis
10000
sentinel
config
-
epoch
master
-
redis
.
example
.
com
0
sentinel
config
-
epoch
gitlab
-
redis
0
sentinel
leader
-
epoch
master
-
redis
.
example
.
com
0
sentinel
leader
-
epoch
gitlab
-
redis
0
```
```
---
---
...
@@ -213,10 +202,11 @@ The following steps should be performed in the [GitLab application server](gitla
...
@@ -213,10 +202,11 @@ The following steps should be performed in the [GitLab application server](gitla
1.
Edit
`/etc/gitlab/gitlab.rb`
and add/change the following lines:
1.
Edit
`/etc/gitlab/gitlab.rb`
and add/change the following lines:
```ruby
```ruby
gitlab-rails['redis_host'] = "master-redis.example.com"
redis['master_name'] = "gitlab-redis"
gitlab-rails['redis_port'] = 6379
redis['master_ip'] = "10.0.0.1"
gitlab-rails['redis_password'] = '<huge password string here>'
redis['master_port'] = 6379
gitlab-rails['redis_sentinels'] = [
redis['master_password'] = '<huge password string here>'
gitlab_rails['redis_sentinels'] = [
{'host' => '10.10.10.1', 'port' => 26379},
{'host' => '10.10.10.1', 'port' => 26379},
{'host' => '10.10.10.2', 'port' => 26379},
{'host' => '10.10.10.2', 'port' => 26379},
{'host' => '10.10.10.3', 'port' => 26379}
{'host' => '10.10.10.3', 'port' => 26379}
...
@@ -229,33 +219,33 @@ The following steps should be performed in the [GitLab application server](gitla
...
@@ -229,33 +219,33 @@ The following steps should be performed in the [GitLab application server](gitla
If you get an error like:
`Redis::CannotConnectError: No sentinels available.`
,
If you get an error like:
`Redis::CannotConnectError: No sentinels available.`
,
there may be something wrong with your configuration files or it can be related
there may be something wrong with your configuration files or it can be related
to
[
this issue
][
gh-531
]
(
[
pull request
][
gh-534
]
that should make things better)
.
to
[
this issue
][
gh-531
]
.
It's a bit
rigid the way you have to config
`resque.yml`
and
`sentinel.conf`
,
It's a bit
non-intuitive the way you have to config
`resque.yml`
and
otherwise
`redis-rb`
will not work properly.
`sentinel.conf`
,
otherwise
`redis-rb`
will not work properly.
The
hostname ('my-primary-redis') of the primary Redis server
(
`sentinel.conf`
)
The
`master-group-name`
('gitlab-redis') defined in
(
`sentinel.conf`
)
**must**
match the one configured
in GitLab (
`resque.yml`
for source installations
**must**
be used as the hostname
in GitLab (
`resque.yml`
for source installations
or
`gitlab-rails['redis_*']`
in Omnibus)
and it must be valid ex
:
or
`gitlab-rails['redis_*']`
in Omnibus):
```
conf
```
conf
# sentinel.conf:
# sentinel.conf:
sentinel
monitor
my
-
primary
-
redis
10
.
10
.
10
.
10
6379
1
sentinel
monitor
gitlab
-
redis
10
.
10
.
10
.
10
6379
1
sentinel
down
-
after
-
milliseconds
my
-
primary
-
redis
10000
sentinel
down
-
after
-
milliseconds
gitlab
-
redis
10000
sentinel
config
-
epoch
my
-
primary
-
redis
0
sentinel
config
-
epoch
gitlab
-
redis
0
sentinel
leader
-
epoch
my
-
primary
-
redis
0
sentinel
leader
-
epoch
gitlab
-
redis
0
```
```
```
yaml
```
yaml
# resque.yaml
# resque.yaml
production
:
production
:
url
:
redis://
my-primary-redis:6378
url
:
redis://
:myredispassword@gitlab-redis/
sentinels
:
sentinels
:
-
-
host
:
slave1
host
:
slave1
.example.com
# or use ip
port
:
26380
# point to sentinel, not to redis port
port
:
26380
# point to sentinel, not to redis port
-
-
host
:
slave2
host
:
slave2
.exampl.com
# or use ip
port
:
26381
# point to sentinel, not to redis port
port
:
26381
# point to sentinel, not to redis port
```
```
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment