• Stars
    star
    2,541
  • Rank 18,052 (Top 0.4 %)
  • Language
    Python
  • License
    BSD 3-Clause "New...
  • Created almost 6 years ago
  • Updated 7 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Interactive Redis: A Terminal Client for Redis with AutoCompletion and Syntax Highlighting.

Interactive Redis: A Cli for Redis with AutoCompletion and Syntax Highlighting.

Github Action PyPI version Python version Download stats

demo

IRedis is a terminal client for redis with auto-completion and syntax highlighting. IRedis lets you type Redis commands smoothly, and displays results in a user-friendly format.

IRedis is an alternative for redis-cli. In most cases, IRedis behaves exactly the same as redis-cli. Besides, it is safer to use IRedis on production servers than redis-cli: IRedis will prevent accidentally running dangerous commands, like KEYS * (see Redis docs / Latency generated by slow commands).

Features

  • Advanced code completion. If you run command KEYS then run DEL, IRedis will auto-complete your command based on KEYS result.
  • Command validation. IRedis will validate command while you are typing, and highlight errors. E.g. try CLUSTER MEET IP PORT, IRedis will validate IP and PORT for you.
  • Command highlighting, fully based on redis grammar. Any valid command in IRedis shell is a valid redis command.
  • Human-friendly result display.
  • pipeline feature, you can use your favorite shell tools to parse redis' response, like get json | jq ..
  • Support pager for long output.
  • Support connection via URL, iredis --url redis://example.com:6379/1.
  • Support cluster, IRedis will auto reissue command for MOVED response in cluster mode.
  • Store server configuration: iredis -d prod-redis (see dsn for more).
  • peek command to check the key's type then automatically call get/lrange/sscan, etc, depending on types. You don't need to call the type command then type another command to get the value. peek will also display the key's length and memory usage.
  • Ctrl + C to cancel the current typed command, this won't exit IRedis, exactly like bash behaviour. Use Ctrl + D to send a EOF to exit IRedis.
  • Ctrl + R to open reverse-i-search to search through your command history.
  • Auto suggestions. (Like fish shell.)
  • Support --encode=utf-8, to decode Redis' bytes responses.
  • Command hint on bottom, include command syntax, supported redis version, and time complexity.
  • Official docs with built-in HELP command, try HELP SET!
  • Written in pure Python, but IRedis was packaged into a single binary with PyOxidizer, you can use cURL to download and run, it just works, even you don't have a Python interpreter.
  • You can change the cli prompt using --prompt option or set via ~/.iredisrc config file.
  • Hide password for AUTH command.
  • Says "Goodbye!" to you when you exit!
  • For full features, please see: iredis.xbin.io

Install

Pip

Install via pip:

pip install iredis

pipx is recommended:

pipx install iredis

Brew

For Mac users, you can install iredis via brew 🍻

brew install iredis

Linux

You can also use your Linux package manager to install IRedis, like apt in Ubuntu (Only available on Ubuntu 21.04+).

apt install iredis

Packaging status

Download Binary

Or you can download the executable binary with cURL(or wget), untar, then run. It is especially useful when you don't have a python interpreter(E.g. the official Redis docker image which doesn't have Python installed.):

wget  https://github.com/laixintao/iredis/releases/latest/download/iredis.tar.gz \
 && tar -xzf iredis.tar.gz \
 && ./iredis

(Check the release page if you want to download an old version of IRedis.)

Usage

Once you install IRedis, you will know how to use it. Just remember, IRedis supports similar options like redis-cli, like -h for redis-server's host and -p for port.

$ iredis --help

Usage: iredis [OPTIONS] [CMD]...

  IRedis: Interactive Redis

  When no command is given, IRedis starts in interactive mode.

  Examples:
    - iredis
    - iredis -d dsn
    - iredis -h 127.0.0.1 -p 6379
    - iredis -h 127.0.0.1 -p 6379 -a <password>
    - iredis --url redis://localhost:7890/3

  Type "help" in interactive mode for information on available commands and
  settings.

Options:
  -h TEXT                         Server hostname (default: 127.0.0.1).
  -p TEXT                         Server port (default: 6379).
  -s, --socket TEXT               Server socket (overrides hostname and port).
  -n INTEGER                      Database number.(overwrites dsn/url's db
                                  number)

  -u, --username TEXT             User name used to auth, will be ignore for
                                  redis version < 6.

  -a, --password TEXT             Password to use when connecting to the
                                  server.

  --url TEXT                      Use Redis URL to indicate connection(Can set
                                  with env `IREDIS_URL`), Example:     redis:/
                                  /[[username]:[password]]@localhost:6379/0
                                  rediss://[[username]:[password]]@localhost:6
                                  379/0     unix://[[username]:[password]]@/pa
                                  th/to/socket.sock?db=0

  -d, --dsn TEXT                  Use DSN configured into the [alias_dsn]
                                  section of iredisrc file. (Can set with env
                                  `IREDIS_DSN`)

  --newbie / --no-newbie          Show command hints and useful helps.
  --iredisrc TEXT                 Config file for iredis, default is
                                  ~/.iredisrc.

  --decode TEXT                   decode response, default is No decode, which
                                  will output all bytes literals.

  --client_name TEXT              Assign a name to the current connection.
  --raw / --no-raw                Use raw formatting for replies (default when
                                  STDOUT is not a tty). However, you can use
                                  --no-raw to force formatted output even when
                                  STDOUT is not a tty.

  --rainbow / --no-rainbow        Display colorful prompt.
  --shell / --no-shell            Allow to run shell commands, default to
                                  True.

  --pager / --no-pager            Using pager when output is too tall for your
                                  window, default to True.

  --verify-ssl [none|optional|required]
                                  Set the TLS certificate verification
                                  strategy

  --prompt TEXT                   Prompt format (supported interpolations:
                                  {client_name}, {db}, {host}, {path}, {port},
                                  {username}, {client_addr}, {client_id}).

  --version                       Show the version and exit.
  --help                          Show this message and exit.

Using DSN

IRedis support storing server configuration in config file. Here is a DSN config:

[alias_dsn]
dev=redis://localhost:6379/4
staging=redis://username:[email protected]:6379/1

Put this in your iredisrc then connect via iredis -d staging or iredis -d dev.

Change The Default Prompt

You can change the prompt str, the default prompt is:

127.0.0.1:6379>

Which is rendered by {host}:{port}[{db}]> , you can change this via --prompt option or change iredisrc config file. The prompwt string uses python string format engine, supported interpolations:

  • {client_name}
  • {db}
  • {host}
  • {path}
  • {port}
  • {username}
  • {client_addr}
  • {client_id}

The --prompt utilize Python String format engine, so as long as it is a valid string formatter, it will work( anything that "<your prompt>".format(...) accepts). For example, you can limit your Redis server host name's length to 5 by setting --prompt to iredis --prompt '{host:.5s}'.

Configuration

IRedis supports config files. Command-line options will always take precedence over config. Configuration resolution from highest to lowest precedence is:

  • Options from command line
  • $PWD/.iredisrc
  • ~/.iredisrc (this path can be changed with iredis --iredisrc $YOUR_PATH)
  • /etc/iredisrc
  • default config in IRedis package.

You can copy the self-explained default config here:

https://raw.githubusercontent.com/laixintao/iredis/master/iredis/data/iredisrc

And then make your own changes.

(If you are using an old versions of IRedis, please use the config file below, and change the version in URL):

https://raw.githubusercontent.com/laixintao/iredis/v1.0.4/iredis/data/iredisrc

Keys

IRedis support unix/readline-style REPL keyboard shortcuts, which means keys like Ctrl + F to forward work.

Also:

  • Ctrl + D (i.e. EOF) to exit; you can also use the exit command.
  • Ctrl + L to clear screen; you can also use the clear command.
  • Ctrl + X Ctrl + E to open an editor to edit command, or V in vi-mode.

Development

Release Strategy

IRedis is built and released by GitHub Actions. Whenever a tag is pushed to the master branch, a new release is built and uploaded to pypi.org, it's very convenient.

Thus, we release as often as possible, so that users can always enjoy the new features and bugfixes quickly. Any bugfix or new feature will get at least a patch release, whereas big features will get a minor release.

Setup Environment

IRedis favors poetry as package management tool. To setup a develop environment on your computer:

First, install poetry (you can do it in a python's virtualenv):

pip install poetry

Then run (which is similar to pip install -e .):

poetry install

Be careful running testcases locally, it may flush you db!!!

Development Logs

This is a command-line tool, so we don't write logs to stdout.

You can tail -f ~/.iredis.log to see logs, the log is pretty clear, you can see what actually happens from log files.

Catch Up with Latest Redis-doc

IRedis use a git submodule to track current-up-to-date redis-doc version. To catch up with latest:

  1. Git pull in redis-doc
  2. Copy doc files to /data: cp -r redis-doc/commands* iredis/data
  3. Prettier markdownprettier --prose-wrap always iredis/data/commands/*.md --write
  4. Check the diff, update IRedis' code if needed.

Related Projects

If you like iredis, you may also like other cli tools by dbcli:

  • pgcli - Postgres Client with Auto-completion and Syntax Highlighting
  • mycli - MySQL/MariaDB/Percona Client with Auto-completion and Syntax Highlighting
  • litecli - SQLite Client with Auto-completion and Syntax Highlighting
  • mssql-cli - Microsoft SQL Server Client with Auto-completion and Syntax Highlighting
  • athenacli - AWS Athena Client with Auto-completion and Syntax Highlighting
  • vcli - VerticaDB client
  • iredis - Client for Redis with AutoCompletion and Syntax Highlighting

IRedis is build on the top of prompt_toolkit, a Python library (by Jonathan Slenders) for building rich commandline applications.

More Repositories

1

python-parallel-programming-cookbook-cn

📖《Python Parallel Programming Cookbook》中文版
Python
1,469
star
2

flameshow

A terminal Flamegraph viewer.
Python
1,012
star
3

pingtop

🏓Ping multiple servers and show results in a top-like terminal UI.
Python
499
star
4

slic-python-implementation

🖼The python implementation to make superpixels by slic.
Python
203
star
5

tokei-pie

Render tokei's output to interactive sunburst chart.
Python
178
star
6

myrc

⚙️ My Linux Config files.
Vim Script
158
star
7

mactop

Python
136
star
8

jupyter-dot-kernel

📝Dot language kernel for jupyter.
Python
86
star
9

prometheus-http-sd

Prometheus HTTP SD framework.
Python
43
star
10

Report-IP-hourly

📬 Report Linux IP by email hourly.
Python
42
star
11

promqlpy

Python
32
star
12

vcron

Interactive TUI crontab editor
Python
28
star
13

HoldemCalculator

计算德州扑克胜率的一个webapp
HTML
26
star
14

git-ext

🛠 A git extension that allows you submit pullrequests from command line.
Python
21
star
15

feed

Some feeds output from feedly.
Python
19
star
16

learn-dot

graphviz/dot语言 教程。
Jupyter Notebook
18
star
17

ISAAC-Atlas-online

👹以撒的结合,中文在线图鉴。
HTML
17
star
18

patrolify

Do some checks every day, so that you can read the "news" in the morning while drinking coffee.
Python
17
star
19

mepe

Cli Prometheus metrics viewer.
Python
15
star
20

blackemail

Dirty email address.
Python
13
star
21

django-migrations-under-the-hood

My slide for PyCon China 2019.
Python
13
star
22

vagrant-wordpress

Bootstrap LEMP WrodPress on virtual machine use VagrantFile.
Shell
12
star
23

iredis-website

Source code of iredis.io, the site for iredis project.
JavaScript
11
star
24

asyncomplete-gitcommit

Provides common words of git commit message autocomplete for asyncomplete.vim
Vim Script
11
star
25

laixintao

Python
9
star
26

vain-git

虚荣的git,填满 Github 日历。
Python
8
star
27

mydumper2s3

Upload mydumper files to S3 bucket in real time.
Python
8
star
28

myslides

Python
7
star
29

Princess-Diaries

👸 A jekyll theme.
CSS
6
star
30

metrics-render

HTTP service that rendering promql into image, support alerting rules expression
Python
6
star
31

side-project-slide

My slides for PyCon2019 Hangzhou.
5
star
32

douban-movie

抓取自己豆瓣上标记的电影和评论。
Python
5
star
33

pytest-mock-helper

Help you mock HTTP call and generate mock code.
Python
4
star
34

go-systemd-readiness-example

A simple example of systemd's readiness protocol.
Go
4
star
35

tmux-auto-select

Perl
4
star
36

iredis-bin

Python
3
star
37

tmux-demo

3
star
38

alerting-with-confidence

alerting-with-confidence talk slides. https://promcon.io/2022-munich/talks/alerting-with-confidence/
HTML
3
star
39

promql-metricsql-prettify

Make your PromQL or MetricsQL beautiful.
HTML
3
star
40

resp3-py

(WIP) A python implementation of RESP3.
Python
3
star
41

RaspberryPI.python

Python code for Raspberry Pi.
Python
3
star
42

leetcode

Python
3
star
43

JOANNA

An Operating System.
C
2
star
44

atomic_or_channel

Go
2
star
45

pycon-en

Pycon-China English site.
2
star
46

page-watcher

Python
2
star
47

yqt

YuQue Tools, now you can edit your markdown with your favorite editor and use yqt to upload them to yuque.com.
Python
2
star
48

blue-nginx

Dockerfile
1
star
49

hack-google-arts

1
star
50

adventofcode

Python
1
star
51

git-check

CI for git repo.
1
star
52

learn-jdbc

Learn jdbc for postgres by example.
Java
1
star
53

workdays-bot

中国大陆法定工作日日推机器人。
Python
1
star
54

maggr

1
star
55

gogogo

My go scripts.
Go
1
star
56

tlpi-code

source code of tlpi and my notes.
C
1
star
57

python3.9-import-test

Python
1
star
58

omnigraffle-automation

My Omnigraffle Automation Scripts
1
star