An open source, memory-based, single-thread, persistent NoSql database written by C.

Environment and Version

Linux environment for Tencent cloud core CentOS7.2.1511. Redis version 5.0.9. Redis official download address.

Why not install the Redis6 version?

CentOS7, original GCC version 4.8.5. To install redis6, you need to upgrade GCC version. Currently, the latest GCC version is GCC10. Latiao tried to install GCC9 version, but found that the compilation did not finish for more than 2 hours. You can use make-j4 when compiling, you can enable multi-process compilation, but the server is single-core, so give up upgrading GCC, and install redis5. Redis5 came out at the end of 2018, and the basic features are pretty strong.

The installation

You can use the wget command to download the Redis installation package, or download the installation package from the official website and copy it to your environment.

# download
cd /usr/local/
wget http://download.redis.io/releases/redis-5.09..tar.gz 
# decompression
tar -zxvf redis-5.09..tar.gz 
Copy the code

compile

cd /redis-5.09.
make
make install PREFIX=/usr/local/redis
Copy the code

Check the /usr/local/redis/bin directory to find the redis executable. Place commonly used executables into environment variables.

cd ..
cd redis/bin/
Sudo can remove the superpermission
sudo cp redis-cli redis-server redis-sentinel /usr/local/bin
Copy the code

At this point, your Redis is ready to use, to facilitate the management of the file, let’s put the configuration file in the appropriate location, and modify the configuration file.

cd /usr/local/redis-5.09./
/usr/local/redis.conf
cp redis.conf /usr/local/
cd..
Use vim to view and modify redis.conf
vim redis.conf
Copy the code

Modifying a Configuration File

Let’s use Vim to modify some parameters and leave the rest as default.

Change the host address from 127.0.0.1 to 0.0.0.0
bind 0.0. 0. 0
The default port is good
port 6379
# enable daemons. Default is no
daemonize yes
Redis process PID file location rename file
pidfile /var/run/redis_6379.pid
Rename the file where the log is stored
logfile /var/log/redis_6379.log
# RDB persistent snapshot, default is good
dbfilename dump.rdb
The persistence file is stored in the default location
dir. /# redis connection password
requirepass 123456
Copy the code

Above, some configuration files can be well understood and modified based on the comments. Explain the following parameters:

Bind is set to 0.0.0.0 to ensure that clients other than this server can access the redis service.

Set daemonize to yes to make the Redis service a daemon. In this mode, Redis runs in the background and writes the process PID number to the file set by the redis. Conf option pidfile. Redis will run until the process is killed manually. If daemonize is set to No, the redis cli is displayed. Exit Forcibly exits or closes the connection tool (such as putty and Xshell), causing the Redis process to exit.

Requirepass: If you’re a cloud service, this password must be set! Otherwise, the server is very easy to be taken by some people as a mining machine, that is, all services to you shut down, only mining procedures, then you really become a worker. Don’t ask latiao how he knows.

Startup and Use

So easy, one line.

redis-server /usr/local/redis.conf
Check to see if it is started
ps -ef | grep redis
The discovery process description is OK
root     11890     1  0 Nov04 ?        0002:39 redis-server 0.0. 0. 0:6379
Copy the code

Our use, divided into three cases: this server use, other machines (your PERSONAL computer) visual client use, other machines (your personal computer) CLI client use.

  1. First look at the use of this server
redis-cli -h 127.0. 01. -p 6379 -a 123456
# then the terminal prefix will become
127.0. 01.:6379>
# Use it
127.0. 01.:6379> set name pjjlt
OK
127.0. 01.:6379> get name
"pjjlt"
Copy the code
  1. Other machine (your PC) visual client to use

To put it bluntly, you can connect and maintain data using Redis Desktop Manager.

  1. Other machines (your PC) use CLI clients

On your PC, open CMD, use redis- CLI to connect redis service and find gg. In this case, we need to open the firewall on our Linux server and use iptables.

Instead of a real firewall, Iptables is a client proxy that implements user security Settings into a “security framework” called NetFilter.

Install and use iptables

# disable firewall
systemctl stop firewalld 
# installation
yum install iptables-services
# start
systemctl enable iptables
# open
systemctl start iptables
Expose port configuration
iptables -I INPUT -p tcp -m tcp --dport 6379 -j ACCEPT
# save configuration
service iptables save
Restart the iptables service
service iptables restart
Check iptable configuration
iptables -L -n -v
Port 6379 is exposed
21169 1657K ACCEPT     tcp  --  *      *       0.0. 0. 0/0            0.0. 0. 0/0            tcp dpt:6379
Copy the code

Ok, now cli on other machines can access our Redis service.