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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
cf9b52e4
Commit
cf9b52e4
authored
Feb 03, 2020
by
Nick Thomas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add a tiny bit of Redis documentation
Focus on key naming for now
parent
f23a07e3
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
44 additions
and
0 deletions
+44
-0
doc/development/README.md
doc/development/README.md
+1
-0
doc/development/redis.md
doc/development/redis.md
+43
-0
No files found.
doc/development/README.md
View file @
cf9b52e4
...
...
@@ -83,6 +83,7 @@ Complementary reads:
-
[
Cycle Analytics development guide
](
cycle_analytics.md
)
-
[
Issue types vs first-class types
](
issue_types.md
)
-
[
Application limits
](
application_limits.md
)
-
[
Redis guidelines
](
redis.md
)
## Performance guides
...
...
doc/development/redis.md
0 → 100644
View file @
cf9b52e4
# Redis guidelines
GitLab uses
[
Redis
](
https://redis.io
)
for three distinct purposes:
-
Caching via
`Rails.cache`
.
-
As a job processing queue with
[
Sidekiq
](
sidekiq_style_guide.md
)
.
-
To manage the shared application state.
Every application process is configured to use the same Redis servers, so they
can be used for inter-process communication in cases where
[
PostgreSQL
](
sql.md
)
is less appropriate, for example, transient state or data that is written much
more often than it is read.
If
[
Geo
](
geo.md
)
is enabled, each Geo node gets its own, independent Redis
database.
## Key naming
Redis is a flat namespace with no hierarchy, which means we must pay attention
to key names to avoid collisions. Typically we use colon-separated elements to
provide a semblence of structure at application level. An example might be
`projects:1:somekey`
.
Although we split our Redis usage into three separate purposes, and those may
map to separate Redis servers in a
[
Highly Available
](
../administration/high_availability/redis.md
)
configuration, the default Omnibus and GDK setups share a single Redis server.
This means that keys should
**always**
be globally unique across the three
purposes.
It is usually better to use immutable identifiers - project ID rather than
full path, for instance - in Redis key names. If full path is used, the key will
stop being consulted if the project is renamed. If the contents of the key are
invalidated by a name change, it is better to include a hook that will expire
the entry, instead of relying on the key changing.
We don't use
[
Redis Cluster
](
https://redis.io/topics/cluster-tutorial
)
at the
moment, but may wish to in the future:
[
#118820
](
https://gitlab.com/gitlab-org/gitlab/issues/118820
)
.
This imposes an additional constraint on naming: where GitLab is performing
operations that require several keys to be held on the same Redis server - for
instance, diffing two sets held in Redis - the keys should ensure that by
enclosing the changeable parts in curly braces, such as,
`project:{1}:set_a`
and
`project:{1}:set_b`
.
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