Todis [ 中文 ]
Now(2021-11-14) users can build todis by himself, such build is community version which is full fledged but lacks performance sideplugins(topling SST & MemTab & Distributed Compaction), even lacks such components, todis works well and performance outperforms competitors.
Open Source Community Version is disallowed to be used by bytedance, see LICENSE.
Todis is a massive, persistent Redis server developed by Topling Inc.
Currently(2021-10-11), there are many massive, persistent Redis server based on RocksDB, and many big company developed their private or open sourced alternatives(massive, persistent Redis).
These alternative Redis servers are low performance and high cost, and lack of scalability, operationality, monitoring, ....
Todis are aimed on all such pain points, and accomplished these goals, users can experiencing Managed Todis based on aliyun in 10 minutes.
- Computing and Storage are seperated for elastic scaling
- Auto scaling, no need for sharding/partitioning
- Plenty monitoring metrics
- Web view for DB internal stats
- With elastic distributed compaction, kicked off write stalls, achieved sustained write speed over 100MB/s on a 2C16G cloud server
- With searchable in memory compression technology(topling-zip), achieved very high read performance(saturate network bandwitdh)
- With shared storage and engine level leader-follwer mechanics
- Sync latency is lower to milliseconds
- New follower(read only node) can be started and available in 10 seconds
Redis layer is forked from pika with many improvements:
- Strorage engine is replaced from RocksDB to ToplingDB
- Rewrite performance critical code of pika
- Add many monitoring metrics(server side latency histogram for all commands and data len histogram...)
- Adapt for ToplingDB SidePlugin, and Web view for config and server stats
- Adapt for ToplingDB distributed compaction
4.2. Storage Engine layer (ToplingDB)
ToplingDB is a storage engine developed by Topling Inc., which forked from RocksDB with many improvments:
- SidePlugin, Engine WebView, Monitoring Metrics...
- Distributed Compaction which offload compaction to a dedicated cluster
- In Managed Todis, this cluster is shared by all users and all Todis instances
- Topling SST and MemTab which based on topling-zip(forked from terark-zip)
- Rockeet is the founder of Terark Inc. and the author of terark-zip
- Terark Inc. which was acquired by bytedance at 2019
- Bytedance open sourced terark-zip at the end of 2020
- As the author of terark-zip, rockeet added many enhancements to topling-zip(his fork of terark-zip) since then
sudo yum install epel-release -y
sudo yum config-manager --set-enabled powertools
sudo yum install git gcc-c++ glog-devel protobuf-devel libaio-devel -y
git clone https://github.com/topling/todis
cd todis
git submodule update --init --recursive
make -j`nproc`
If your protobuf-devel
is too old, compilation maybe fail, you should update protobuf-devel
, such as compile new protobuf from github source, or from vcpkg...
Compiling generated dir output
which included all files required at runtime, users need change config files(especially path
items), there are two config files:
todis-community.conf
and todis-community.json
, the former is compatible for pika, the later is ToplingDB's SidePlugin conf for todis, sideplugin-conf
of todis-community.conf
is the path of todis-community.json
.
The most simple way is to change all conf items prefixed with /path/to/
.
Introduction中文
Pika is a persistent huge storage service , compatible with the vast majority of redis interfaces (details), including string, hash, list, zset, set and management interfaces. With the huge amount of data stored, redis may suffer for a capacity bottleneck, and pika was born for solving it. Except huge storage capacity, pika also support master-slave mode by slaveof command, including full and partial synchronization. You can also use pika together with twemproxy or codis(pika has supported data migration in codis,thanks left2right and fancy-rabbit) for distributed Redis solution
- huge storage capacity
- compatible with redis interface, you can migrate to pika easily
- support master-slave mode (slaveof)
- various management interfaces
The User can download the binary release from releases or compile the source release.
- snappy - a library for fast data compression
- glog - google log library
Upgrade your gcc to version at least 4.8 to get C++11 support.
-
linux - CentOS 5&6
-
linux - Ubuntu
If it comes to some missing libs, install them according to the prompts and retry it.
Upgrade your gcc to version at least 4.8 to get C++11 support.
Get the source code
git clone https://github.com/Qihoo360/pika.git
Then compile pika, all submodules will be updated automatically.
make
./output/bin/pika -c ./conf/pika.conf
More details on Performance.
Users Mail Group: join in pika_users@groups.163.com
Developers Mail Group: join in pika_developers@groups.163.com
QQ group: 294254078
For more information about Pika, Atlas and some other technology please pay attention to our Hulk platform official account