preface
Redis is a NOSQL memory database, save the data in memory efficiency than save on disk database is much faster, single Redis QPS can basically reach 10W, but when the Redis delay, we need to how to check? This article mainly introduces the Redis command execution process and some performance test tool command analysis
1. Redis command execution process
1.1 Three Stages of Command Execution
A command can be executed in three phases
- In the link establishment stage, the socket was established and the client object was created.
- In the processing phase, data is read from the socket into the input buffer, the command is parsed and obtained, the command is executed and the return value is stored in the output buffer
- The data return phase writes the return value from the output buffer to the socket, returns it to the client, and finally closes the client.
1.2 Principle Analysis
1.2.1 Listening on sockets during startup
1.2.2 Establishing the Connection and Client
1.2.3 Reading Socket data into the input buffer
1.2.4 Parsing and Obtaining commands
1.2.5 Running Commands
2. Redis performance test
Redis-benchmark is an official Redis performance test tool that can effectively test the performance of Redis services. The Help tool also gives several test cases
[root@VM_0_14_centos bin]# redis-benchmark -h 127.0. 01. -p 6379 -c 1 -n 100000 -d 100
====== PING_INLINE ======
100000 requests completed in 2.30 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =6 milliseconds
43402.78 requests per second
====== PING_BULK ======
100000 requests completed in 2.22 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =1 milliseconds
45065.34 requests per second
====== SET ======
100000 requests completed in 2.25 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
44464.20 requests per second
====== GET ======
100000 requests completed in 2.20 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =6 milliseconds
45537.34 requests per second
====== INCR ======
100000 requests completed in 2.21 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
100.00< % =6 milliseconds
45310.38 requests per second
====== LPUSH ======
100000 requests completed in 2.26 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
44208.66 requests per second
====== RPUSH ======
100000 requests completed in 2.26 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =6 milliseconds
44189.13 requests per second
====== LPOP ======
100000 requests completed in 2.24 seconds
1 parallel clients
100 bytes payload
keep alive: 1
99.99< % =1 milliseconds
100.00< % =2 milliseconds
100.00< % =6 milliseconds
100.00< % =7 milliseconds
100.00< % =7 milliseconds
44722.72 requests per second
====== RPOP ======
100000 requests completed in 2.21 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =3 milliseconds
45187.53 requests per second
====== SADD ======
100000 requests completed in 2.26 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
44306.60 requests per second
====== HSET ======
100000 requests completed in 2.30 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =6 milliseconds
43440.48 requests per second
====== SPOP ======
100000 requests completed in 2.21 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
45207.96 requests per second
====== LPUSH (needed to benchmark LRANGE) ======
100000 requests completed in 2.28 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =0 milliseconds
43936.73 requests per second
====== LRANGE_100 (first 100 elements) ======
100000 requests completed in 2.25 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
100.00< % =6 milliseconds
44483.99 requests per second
====== LRANGE_300 (first 300 elements) ======
100000 requests completed in 2.25 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =5 milliseconds
44523.60 requests per second
====== LRANGE_500 (first 450 elements) ======
100000 requests completed in 2.23 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
44782.80 requests per second
====== LRANGE_600 (first 600 elements) ======
100000 requests completed in 2.26 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
100.00< % =6 milliseconds
100.00< % =6 milliseconds
44286.98 requests per second
====== MSET (10 keys) ======
100000 requests completed in 2.53 seconds
1 parallel clients
100 bytes payload
keep alive: 1
100.00< % =1 milliseconds
100.00< % =2 milliseconds
100.00< % =6 milliseconds
39510.08 requests per second
Copy the code
3. Other factors affecting performance
reference
Redis. IO/switchable viewer/newest…