mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 08:08:53 -05:00
deps/README.md: s/Redis/Redict/
Signed-off-by: Drew DeVault <sir@cmpwn.com>
This commit is contained in:
parent
2ab9de5307
commit
5cde2dd76b
30
deps/README.md
vendored
30
deps/README.md
vendored
@ -1,9 +1,9 @@
|
|||||||
This directory contains all Redis dependencies, except for the libc that
|
This directory contains all Redict dependencies, except for the libc that
|
||||||
should be provided by the operating system.
|
should be provided by the operating system.
|
||||||
|
|
||||||
* **Jemalloc** is our memory allocator, used as replacement for libc malloc on Linux by default. It has good performances and excellent fragmentation behavior. This component is upgraded from time to time.
|
* **Jemalloc** is our memory allocator, used as replacement for libc malloc on Linux by default. It has good performances and excellent fragmentation behavior. This component is upgraded from time to time.
|
||||||
* **hiredis** is the official C client library for Redis. It is used by redis-cli, redis-benchmark and Redis Sentinel. It is part of the Redis official ecosystem but is developed externally from the Redis repository, so we just upgrade it as needed.
|
* **hiredict** is the official C client library for Redict. It is used by redict-cli, redict-benchmark and Redict Sentinel.
|
||||||
* **linenoise** is a readline replacement. It is developed by the same authors of Redis but is managed as a separated project and updated as needed.
|
* **linenoise** is a readline replacement. It is developed by the same authors of Redict but is managed as a separated project and updated as needed.
|
||||||
* **lua** is Lua 5.1 with minor changes for security and additional libraries.
|
* **lua** is Lua 5.1 with minor changes for security and additional libraries.
|
||||||
* **hdr_histogram** Used for per-command latency tracking histograms.
|
* **hdr_histogram** Used for per-command latency tracking histograms.
|
||||||
|
|
||||||
@ -13,10 +13,10 @@ How to upgrade the above dependencies
|
|||||||
Jemalloc
|
Jemalloc
|
||||||
---
|
---
|
||||||
|
|
||||||
Jemalloc is modified with changes that allow us to implement the Redis
|
Jemalloc is modified with changes that allow us to implement the Redict
|
||||||
active defragmentation logic. However this feature of Redis is not mandatory
|
active defragmentation logic. However this feature of Redict is not mandatory
|
||||||
and Redis is able to understand if the Jemalloc version it is compiled
|
and Redict is able to understand if the Jemalloc version it is compiled
|
||||||
against supports such Redis-specific modifications. So in theory, if you
|
against supports such Redict-specific modifications. So in theory, if you
|
||||||
are not interested in the active defragmentation, you can replace Jemalloc
|
are not interested in the active defragmentation, you can replace Jemalloc
|
||||||
just following these steps:
|
just following these steps:
|
||||||
|
|
||||||
@ -28,7 +28,7 @@ just following these steps:
|
|||||||
Jemalloc configuration script is broken and will not work nested in another
|
Jemalloc configuration script is broken and will not work nested in another
|
||||||
git repository.
|
git repository.
|
||||||
|
|
||||||
However note that we change Jemalloc settings via the `configure` script of Jemalloc using the `--with-lg-quantum` option, setting it to the value of 3 instead of 4. This provides us with more size classes that better suit the Redis data structures, in order to gain memory efficiency.
|
However note that we change Jemalloc settings via the `configure` script of Jemalloc using the `--with-lg-quantum` option, setting it to the value of 3 instead of 4. This provides us with more size classes that better suit the Redict data structures, in order to gain memory efficiency.
|
||||||
|
|
||||||
If you want to upgrade Jemalloc while also providing support for
|
If you want to upgrade Jemalloc while also providing support for
|
||||||
active defragmentation, in addition to the above steps you need to perform
|
active defragmentation, in addition to the above steps you need to perform
|
||||||
@ -38,7 +38,7 @@ the following additional steps:
|
|||||||
to add `#define JEMALLOC_FRAG_HINT`.
|
to add `#define JEMALLOC_FRAG_HINT`.
|
||||||
6. Implement the function `je_get_defrag_hint()` inside `src/jemalloc.c`. You
|
6. Implement the function `je_get_defrag_hint()` inside `src/jemalloc.c`. You
|
||||||
can see how it is implemented in the current Jemalloc source tree shipped
|
can see how it is implemented in the current Jemalloc source tree shipped
|
||||||
with Redis, and rewrite it according to the new Jemalloc internals, if they
|
with Redict, and rewrite it according to the new Jemalloc internals, if they
|
||||||
changed, otherwise you could just copy the old implementation if you are
|
changed, otherwise you could just copy the old implementation if you are
|
||||||
upgrading just to a similar version of Jemalloc.
|
upgrading just to a similar version of Jemalloc.
|
||||||
|
|
||||||
@ -58,12 +58,12 @@ cd deps/jemalloc
|
|||||||
4. Update jemalloc's version in `deps/Makefile`: search for "`--with-version=<old-version-tag>-0-g0`" and update it accordingly.
|
4. Update jemalloc's version in `deps/Makefile`: search for "`--with-version=<old-version-tag>-0-g0`" and update it accordingly.
|
||||||
5. Commit the changes (VERSION,configure,Makefile).
|
5. Commit the changes (VERSION,configure,Makefile).
|
||||||
|
|
||||||
Hiredis
|
Hiredict
|
||||||
---
|
---
|
||||||
|
|
||||||
Hiredis is used by Sentinel, `redis-cli` and `redis-benchmark`. Like Redis, uses the SDS string library, but not necessarily the same version. In order to avoid conflicts, this version has all SDS identifiers prefixed by `hi`.
|
Hiredict is used by Sentinel, `redict-cli` and `redict-benchmark`. Like Redict, uses the SDS string library, but not necessarily the same version. In order to avoid conflicts, this version has all SDS identifiers prefixed by `hi`.
|
||||||
|
|
||||||
1. `git subtree pull --prefix deps/hiredis https://github.com/redis/hiredis.git <version-tag> --squash`<br>
|
1. `git subtree pull --prefix deps/hiredict https://codeberg.org/redict/hiredict <version-tag> --squash`<br>
|
||||||
This should hopefully merge the local changes into the new version.
|
This should hopefully merge the local changes into the new version.
|
||||||
2. Conflicts will arise (due to our changes) you'll need to resolve them and commit.
|
2. Conflicts will arise (due to our changes) you'll need to resolve them and commit.
|
||||||
|
|
||||||
@ -71,7 +71,7 @@ Linenoise
|
|||||||
---
|
---
|
||||||
|
|
||||||
Linenoise is rarely upgraded as needed. The upgrade process is trivial since
|
Linenoise is rarely upgraded as needed. The upgrade process is trivial since
|
||||||
Redis uses a non modified version of linenoise, so to upgrade just do the
|
Redict uses a non modified version of linenoise, so to upgrade just do the
|
||||||
following:
|
following:
|
||||||
|
|
||||||
1. Remove the linenoise directory.
|
1. Remove the linenoise directory.
|
||||||
@ -81,11 +81,11 @@ Lua
|
|||||||
---
|
---
|
||||||
|
|
||||||
We use Lua 5.1 and no upgrade is planned currently, since we don't want to break
|
We use Lua 5.1 and no upgrade is planned currently, since we don't want to break
|
||||||
Lua scripts for new Lua features: in the context of Redis Lua scripts the
|
Lua scripts for new Lua features: in the context of Redict Lua scripts the
|
||||||
capabilities of 5.1 are usually more than enough, the release is rock solid,
|
capabilities of 5.1 are usually more than enough, the release is rock solid,
|
||||||
and we definitely don't want to break old scripts.
|
and we definitely don't want to break old scripts.
|
||||||
|
|
||||||
So upgrading of Lua is up to the Redis project maintainers and should be a
|
So upgrading of Lua is up to the Redict project maintainers and should be a
|
||||||
manual procedure performed by taking a diff between the different versions.
|
manual procedure performed by taking a diff between the different versions.
|
||||||
|
|
||||||
Currently we have at least the following differences between official Lua 5.1
|
Currently we have at least the following differences between official Lua 5.1
|
||||||
|
Loading…
Reference in New Issue
Block a user