Redis 笔记(二)-Redis 安装及测试

一、什么是 Redis 中文网站

  • RedisRemote Dictionary Server ),即远程字典服务,是一个开源的使用 ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value,并提供多种语言的 API
  • Redis 开源,遵循 BSD 基于内存数据存储,被用于作为数据库、缓存、 消息中间件
  • 总结: redis 是一个内存型的数据库
  • Redis 能干什么?
    1、内存存储,持久化,内存存储是断电即失的,所以说持久化很重要( rdb , aof )
    2、效率高,用于高速缓存
    3、发布订阅系统
    4、地图信息分析
    5、计时器,浏览器,计数器

二、Redis 特点

  1. 多样数据类型
  2. 持久化
  3. 集群
  4. 事务

三、Redis 安装

  1. windows 安装
  • 下载安装包:地址
  • 将压缩包解压,打开文件夹,内容如下:
  • 开启 redis,双击运行服务: redis 默认服务端口:6379
  • 使用 redis 客户端连接 redisping 命令,显示 PONG ,表示连接成功
  • 测试:
    设置键值对:set myKey abc
    取出键值对:get myKey
127.0.0.1:6379> ping
PONG            # 连接成功
127.0.0.1:6379> set myKey abc        # 设置键值对
OK
127.0.0.1:6379> get myKey        # 取出键值对
"abc"

redis 推荐在 Linux 下进行开发

  1. Linux 安装
$ wget https://download.redis.io/releases/redis-6.2.5.tar.gz
$ tar xzf redis-6.2.5.tar.gz
$ cd redis-6.2.5
$ make
  • 下载安装包:redis-6.2.5.tar.gz
[root@VM-0-6-centos ~]# wget https://download.redis.io/releases/redis-6.2.5.tar.gz
  • 解压安装包:一般将下载程序放在 opt 目录下
[root@VM-0-6-centos ~]# mv redis-6.2.5.tar.gz /opt/
[root@VM-0-6-centos ~]# cd /opt
[root@VM-0-6-centos opt]# ls
containerd  redis-6.2.5.tar.gz
[root@VM-0-6-centos opt]# tar xzf redis-6.2.5.tar.gz
  • 查看 redis 文件
[root@VM-0-6-centos opt]# cd redis-6.2.5
[root@VM-0-6-centos redis-6.2.5]# ls
00-RELEASENOTES  CONDUCT       COPYING  INSTALL   MANIFESTO  redis.conf  runtest-cluster    runtest-sentinel  src    TLS.md
BUGS             CONTRIBUTING  deps     Makefile  README.md  runtest     runtest-moduleapi  sentinel.conf     tests  utils
  • 基本的环境安装 :yum install gcc-c++
[root@VM-0-6-centos redis-6.2.5]# yum install gcc-c++
  • 查看 gcc 版本号:gcc -v
[root@VM-0-6-centos redis-6.2.5]# gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/libexec/gcc/x86_64-redhat-linux/8/lto-wrapper
OFFLOAD_TARGET_NAMES=nvptx-none
OFFLOAD_TARGET_DEFAULT=1
Target: x86_64-redhat-linux
Configured with: ../configure --enable-bootstrap --enable-languages=c,c++,fortran,lto --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=http://bugzilla.redhat.com/bugzilla --enable-shared --enable-threads=posix --enable-checking=release --enable-multilib --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-linker-build-id --with-gcc-major-version-only --with-linker-hash-style=gnu --enable-plugin --enable-initfini-array --with-isl --disable-libmpx --enable-offload-targets=nvptx-none --without-cuda-driver --enable-gnu-indirect-function --enable-cet --with-tune=generic --with-arch_32=x86-64 --build=x86_64-redhat-linux
Thread model: posix
gcc version 8.4.1 20200928 (Red Hat 8.4.1-1) (GCC) 
  • 配置 redis 文件:make
[root@VM-0-6-centos redis-6.2.5]# make
  • 确认是否安装成功:make install
[root@VM-0-6-centos redis-6.2.5]# make install
cd src && make install
make[1]: Entering directory '/opt/redis-6.2.5/src'CC Makefile.depHint: It's a good idea to run 'make test' ;)INSTALL redis-serverINSTALL redis-benchmarkINSTALL redis-cli
make[1]: Leaving directory '/opt/redis-6.2.5/src'
  • redis 默认安装目录在 /usr/local/bin
[root@VM-0-6-centos bin]# ls
chardetect  cloud-init-per  easy_install      jsondiff   jsonpointer  redis-benchmark  redis-check-rdb  redis-sentinel
cloud-init  docker-compose  easy_install-3.6  jsonpatch  jsonschema   redis-check-aof  redis-cli        redis-server
  • 复制 redis 配置文件,到安装目录下 /usr/local/bin ,在这个目录下面,新建个配置目录,使用这个配置文件来启动 redis
[root@VM-0-6-centos redis-6.2.5]# cp redis.conf /usr/local/bin/config
[root@VM-0-6-centos redis-6.2.5]# cd /usr/local/bin/config
[root@VM-0-6-centos config]# ls
redis.conf
  • redis 默认不是后台启动的,需要修改配置文件 redis.conf
daemonize yes        # 将配置文件 daemonize no  改为 daemonize yes
  • 通过指定的配置文件,启动 redis 服务:redis-server config/redis.conf
[root@VM-0-6-centos bin]# pwd
/usr/local/bin
[root@VM-0-6-centos bin]# redis-server config/redis.conf        # 通过自定义的配置文件启动
  • 通过 redis 客户端去连接 redis 服务:redis-cli -p [端口号]
[root@VM-0-6-centos bin]# redis-cli -p 6379        # 默认端口为 6379
127.0.0.1:6379>
  • 测试
[root@VM-0-6-centos bin]# redis-cli -p 6379        # 使用 redis 客户端进行连接
127.0.0.1:6379> ping
PONG
127.0.0.1:6379> set key aa        # 设置键值对
OK
127.0.0.1:6379> get key        # 获取键值对
"aa"
127.0.0.1:6379> set name yy
OK
127.0.0.1:6379> get name
"yy"
127.0.0.1:6379> keys *        # 查看所有 key
1) "name"
2) "key"
127.0.0.1:6379> 
  • 查看 redis 的进程是否开启
[root@VM-0-6-centos ~]# ps -ef|grep redis      # grep redis 获取和 redis 相关的进程  
root     1334563       1  0 17:44 ?        00:00:00 redis-server 127.0.0.1:6379
root     1335138 1321154  0 17:47 pts/1    00:00:00 redis-cli -p 6379
root     1336646 1336537  0 17:56 pts/3    00:00:00 grep --color=auto redis
  • 关闭 redis 服务:shutdown
127.0.0.1:6379> shutdown
not connected> exit
  • 再次查看进程是否存在
[root@VM-0-6-centos ~]# ps -ef|grep redis        # 进程已经关闭
root     1337290 1336537  0 18:00 pts/3    00:00:00 grep --color=auto redis

四、性能测试

  • redis-benchmark 是一个(自带)压力测试工具,命令可选参数:
Usage: redis-benchmark [-h <host>] [-p <port>] [-c <clients>] [-n <requests>] [-k <boolean>]-h <hostname>      Server hostname (default 127.0.0.1)        # 指定服务器主机名-p <port>          Server port (default 6379)        # 指定服务器端口-s <socket>        Server socket (overrides host and port)        # 指定服务器-a <password>      Password for Redis Auth--user <username>  Used to send ACL style 'AUTH username pass'. Needs -a.-c <clients>       Number of parallel connections (default 50)        # 指定并发连接数-n <requests>      Total number of requests (default 100000)        # 指定请求数-d <size>          Data size of SET/GET value in bytes (default 3)  # 以字节的形式指定 SET/GET 值的数据大小--dbnum <db>       SELECT the specified db number (default 0)--threads <num>    Enable multi-thread mode.--cluster          Enable cluster mode.--enable-tracking  Send CLIENT TRACKING on before starting benchmark.-k <boolean>       1=keep alive 0=reconnect (default 1)-r <keyspacelen>   Use random keys for SET/GET/INCR, random values for SADD,random members and scores for ZADD. # SET/GET/INCR 使用随机 key, SADD 使用随机值Using this option the benchmark will expand the string __rand_int__inside an argument with a 12 digits number in the specified rangefrom 0 to keyspacelen-1. The substitution changes every time a commandis executed. Default tests use this to hit random keys in thespecified range.-P <numreq>        Pipeline <numreq> requests. Default 1 (no pipeline). # 通过管道传输 <numreq> 请求-q                 Quiet. Just show query/sec values        # 强制退出 redis。仅显示 query/sec 值--precision        Number of decimal places to display in latency output (default 0)--csv              Output in CSV format          # 以 CSV 格式输出-l                 Loop. Run the tests forever        # 成循环,永久执行测试-t <tests>         Only run the comma separated list of tests. The testnames are the same as the ones produced as output.        # 仅运行以逗号分隔的测试命令列表。-I                 Idle mode. Just open N idle connections and wait.      # Idle 模式。仅打开 N 个 idle 连接并等待--help             Output this help and exit.--version          Output version and exit.
序号选项描述默认值
1-h指定服务器主机名127.0.0.1
2-p指定服务器端口6379
3-s指定服务器socket
4-c指定并发连接数50
5-n指定请求数10000
6-d以字节的形式指定 SET/GET 值的数据大小3
7-k1=keep alive 0=reconnect1
8-r SET/GET/INCR 使用随机 key, SADD 使用随机值
9-P通过管道传输 <numreq> 请求1
10-q强制退出 redis。仅显示 query/sec
11—csvCSV 格式输出
12-l生成循环,永久执行测试
13-t仅运行以逗号分隔的测试命令列表。
14-I Idle 模式。仅打开 Nidle 连接并等待。
  • 示例:测试 100 个并发,连接 100000 请求
# 测试:100个并发连接 100000请求
[root@VM-0-6-centos bin]# redis-benchmark -h localhost -p 6379 -c 100 -n 100000
====== SET ======                                                   100000 requests completed in 2.60 seconds    # 对100000个测试请求写入测试100 parallel clients      # 100个并发客户端3 bytes payload      # 每次3字节写入keep alive: 1      # 只有一台服务器来处理这些请求,单机性能host configuration "save": 3600 1 300 100 60 10000host configuration "appendonly": nomulti-thread: noLatency by percentile distribution:
0.000% <= 0.623 milliseconds (cumulative count 1)
50.000% <= 1.735 milliseconds (cumulative count 50412)
75.000% <= 2.111 milliseconds (cumulative count 75215)
87.500% <= 2.535 milliseconds (cumulative count 87554)
93.750% <= 2.943 milliseconds (cumulative count 93767)
96.875% <= 3.687 milliseconds (cumulative count 96875)
98.438% <= 4.511 milliseconds (cumulative count 98450)
99.219% <= 5.079 milliseconds (cumulative count 99220)
99.609% <= 5.567 milliseconds (cumulative count 99611)
99.805% <= 6.135 milliseconds (cumulative count 99807)
99.902% <= 7.343 milliseconds (cumulative count 99903)
99.951% <= 21.663 milliseconds (cumulative count 99953)
99.976% <= 21.983 milliseconds (cumulative count 99977)
99.988% <= 22.095 milliseconds (cumulative count 99988)
99.994% <= 22.159 milliseconds (cumulative count 99995)
99.997% <= 22.175 milliseconds (cumulative count 99997)
99.998% <= 22.207 milliseconds (cumulative count 99999)
99.999% <= 22.223 milliseconds (cumulative count 100000)
100.000% <= 22.223 milliseconds (cumulative count 100000)
……
Summary:throughput summary: 38402.46 requests per second        # 每秒处理 38402.46 个请求latency summary (msec):avg       min       p50       p95       p99       max1.858     0.616     1.735     3.111     4.911    22.223


喜欢的朋友记得点赞、收藏、关注哦!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/504181.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

eNSP之家——路由器--入门实例详解

eNSP路由器配置&#xff1a;IP、DHCP与DNS详解-CSDN博客 练习1&#xff1a;两个路由器配置ip地址&#xff0c;并用ping命令测试连通性。 打开ensp&#xff0c;拉进来两个路由器AR2220,再用auto连接两个路由器。 选中两个路由器&#xff0c;右键启动&#xff0c;等待半分钟路由…

Electron快速入门——跨平台桌面端应用开发框架

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

机器学习基础-机器学习的常用学习方法

目录 半监督学习的概念 规则学习的概念 基本概念 机器学习里的规则 逻辑规则 规则集 充分性与必要性 冲突消解 命题逻辑 → 命题规则 序贯覆盖 单条规则学习 剪枝优化 强化学习的概念 1. 强化学习对应了四元组 2. 强化学习的目标 强化学习常用马尔可夫决策过程…

Qt QDockWidget详解以及例程

Qt QDockWidget详解以及例程 引言一、基本用法二、深入了解2.1 窗口功能相关2.2 停靠区域限制2.3 在主窗体布局 引言 QDockWidget类提供了一个可以停靠在QMainWindow内的小窗口 (理论上可以在QMainWindow中任意排列)&#xff0c;也可以作为QMainWindow上的顶级窗口浮动 (类似一…

【设计模式-2】23 种设计模式的分类和功能

在软件工程领域&#xff0c;设计模式是解决常见设计问题的经典方案。1994 年&#xff0c;Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides&#xff08;四人帮&#xff0c;GoF&#xff09;在《设计模式&#xff1a;可复用面向对象软件的基础》一书中系统性地总结了…

【Linux 之 二十 】使用 ln 命令创建符号链接

ln&#xff08;英文全拼&#xff1a;link files&#xff09;是Linux中非常重要的一个命令&#xff0c;用创建一个硬链接或者一个符号链接&#xff08;也叫软链接&#xff09;。它的功能是为某一个文件或目录在另外一个位置建立一个同步的链接。当我们需要在多个目录下都能显示某…

B树及其Java实现详解

文章目录 B树及其Java实现详解一、引言二、B树的结构与性质1、节点结构2、性质 三、B树的操作1、插入操作1.1、插入过程 2、删除操作2.1、删除过程 3、搜索操作 四、B树的Java实现1、节点类实现2、B树类实现 五、使用示例六、总结 B树及其Java实现详解 一、引言 B树是一种多路…

Nature Electronics——近传感器计算:50 nm异构集成技术的革命

创新点&#xff1a;1.高密度互联设计&#xff1a;基于二维材料&#xff0c;开发出互连密度高达62,500 I/O每平方毫米的M3D集成结构。2.异构层堆叠&#xff1a;整合了第二层石墨烯化学传感器和第一层MoS₂记忆晶体管&#xff0c;实现功能互补。3.超短传感器与计算元件距离&#…

如何用 ESP32-CAM 做一个实时视频流服务器

文章目录 ESP32-CAM 概述ESP32-S 处理器内存Camera 模块MicroSD 卡槽天线板载 LED 和闪光灯其他数据手册和原理图ESP32-CAM 功耗 ESP32-CAM 引脚参考引脚排列GPIO 引脚哪些 GPIO 可以安全使用&#xff1f;GPIO 0 引脚MicroSD 卡引脚 ESP32-CAM 的烧录方式使用 ESP32-CAM-MB 编程…

江科大STM32入门——IIC通信笔记总结

wx&#xff1a;嵌入式工程师成长日记 &#xff08;一&#xff09;简介 STM32内部集成了硬件I2C收发电路&#xff0c;可以由硬件自动执行时钟生成、起始终止条件生成、应答位收发、数据收发等功能&#xff0c;减轻CPU的负担 支持多主机 支持7位/10位地址模式 支持不同的通讯速…

vue2日历组件

这个代码可以直接运行&#xff0c;未防止有组件库没安装&#xff0c;将组件库的代码&#xff0c;转成文字了 vue页面 <template><div class"about"><div style"height: 450px; width: 400px"><div style"height: 100%; overflo…

Java语法总结

Java的数据类型分为基本数据类型和引用数据类型。 1.基本数据类型&#xff1a;四类八种 byte 和short 比较特殊&#xff0c;不必考虑int类型&#xff0c;只关注是否超出了表示范围。 数据超出了int的范围&#xff0c;改正&#xff1a;在后边添加L &#xff0c;定义变量报错…

自动驾驶控制与规划——Project 6: A* Route Planning

目录 零、任务介绍一、算法原理1.1 A* Algorithm1.2 启发函数 二、代码实现三、结果分析四、效果展示4.1 Dijkstra距离4.2 Manhatten距离4.3 欧几里德距离4.4 对角距离 五、后记 零、任务介绍 carla-ros-bridge/src/ros-bridge/carla_shenlan_projects/carla_shenlan_a_star_p…

闲谭SpringBoot--ShardingSphere分库分表探究

文章目录 1. 背景2. 创建数据库3. 修改yml配置文件4. 分片算法类5. 测试6 小结 1. 背景 接上文&#xff0c;我们对日志表&#xff0c;进行了按月的分表&#xff0c;这样每个月几百万条数据量还是扛得住的。 但是如果数据再多呢&#xff0c;除了提高硬件性能&#xff0c;还有一…

IT面试求职系列主题-Jenkins

想成功求职&#xff0c;必要的IT技能一样不能少&#xff0c;先说说Jenkins的必会知识吧。 1) 什么是Jenkins Jenkins 是一个用 Java 编写的开源持续集成工具。它跟踪版本控制系统&#xff0c;并在发生更改时启动和监视构建系统。 2&#xff09;Maven、Ant和Jenkins有什么区别…

STM32供电参考设计

STM32供电参考设计 ​ 在图中有VDD&#xff0c;VSS和VDDA&#xff0c;VSSA两种类型的供电引脚&#xff0c;其数据手册解释如下&#xff1a; ​ 令我不解的是&#xff1a;VDDA和VSSA必须分别连接到VDD和VSS&#xff0c;这是什么意思&#xff1f;有大佬能够解答一下吗&#xff1f…

和为0的四元组-蛮力枚举(C语言实现)

目录 一、问题描述 二、蛮力枚举思路 1.初始化&#xff1a; 2.遍历所有可能的四元组&#xff1a; 3.检查和&#xff1a; 4.避免重复&#xff1a; 5.更新计数器&#xff1a; 三、代码实现 四、运行结果 五、 算法复杂度分析 一、问题描述 给定一个整数数组 nums&…

嵌入式系统 (2.嵌入式硬件系统基础)

2.嵌入式硬件系统基础 2.1嵌入式硬件系统的组成 嵌入式硬件系统以嵌入式微处理器为核心&#xff0c;主要由嵌入式微处理器、总线、存储器、输入/输出接口和设备组成。 嵌入式微处理器 嵌入式微处理器采用冯诺依曼结构或哈佛结构&#xff1a;前者指令和数据共享同一存储空间…

对快速由表及里说拜拜/如何正确运用由表及里

你是不是还&#xff1a;看到一男子拖走一女子就以为小情侣吵架而已&#xff08;可能人贩子&#xff09;&#xff1b;看到男友对你好个几次就从此死心塌地&#xff08;可能有手就行&#xff0c;细节装装而已&#xff09;结果耽误终身&#xff1b;看到女同事对你微笑不排斥就以为…

(七)人工智能进阶之人脸识别:从刷脸支付到智能安防的奥秘,小白都可以入手的MTCNN+Arcface网络

零、开篇趣谈 还记得第一次用支付宝"刷脸"时的新奇感吗&#xff1f;或者被抖音的人脸特效逗乐的瞬间&#xff1f;这些有趣的应用背后&#xff0c;其实藏着一个精妙的AI世界。今天&#xff0c;就让我们开启一段奇妙的人脸识别技术探索之旅吧&#xff01; 一、人脸识…