〖Redis指南①〗快速入门|配置文件|运行镜像|数据结构|常用命令|客户端

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
日志服务 SLS,月写入数据量 50GB 1个月
简介: Redis诞生于2009年全称是Remote Dictionary Server,远程词典服务器,是一个基于内存的键值型NoSQL数据库。

SQL和NoSQL


1.png


redis简介


Redis诞生于2009年全称是Remote Dictionary Server,远程词典服务器,是一个基于内存的键值型NoSQL数据库。


特征:


键值(key-value)型,value支持多种不同数据结构,功能丰富

单线程,每个命令具备原子性

低延迟,速度快(基于内存、IO多路复用、良好的编码)。

支持数据持久化

支持主从集群、分片集群

支持多语言客户端


下载镜像


为了方便学习和演示,我们这里采用docker安装


下载redis镜像

docker pull redis


配置文件

传给服务器一个redis的配置文件,因为redis默认的配置有些时候不会满足我们的需求


2.png


我们先cp一份出来,养成良好的习惯


cp redis.conf redis.conf.bck

3.png


修改常见的配置


# 允许访问的地址,默认是127.0.0.1,会导致只能在本地访问。
# 修改为0.0.0.0则可以在任意IP访问,生产环境不要设置为0.0.0.0
bind 0.0.0.0
# 守护进程,修改为yes后即可后台运行,默认为no
daemonize no 
# 密码,设置后访问Redis必须输入密码,默认没有密码
requirepass 123456
# 监听的端口
port 6379
# 工作目录,默认是当前目录,也就是运行redis-server时的命令,日志、持久化等文件会保存在这个目录
dir .
# 数据库数量,设置为1,代表只使用1个库,默认有16个库,编号0~15
databases 16
# 设置redis能够使用的最大内存
maxmemory 512mb
# 日志文件,默认为空,不记录日志,可以指定日志文件名
logfile "redis.log"

这里需要注意一下,如果使用docker运行redis,daemonize 不可以设置为 yes ,因为会和docker的 -d 命令发生冲突。


等会,突然想起,如果你是用的云服务器,那么这里我并不建议你修改上述配置,不然,很容易被坏人植入恶意脚本,然后就会有不可描述的后果~


如果,你不听劝,中招了,就留言吧,我写一篇如何大战黑客,手把手教你以黑吃黑~


运行redis镜像


docker run -p 6379:6379 --name myredis --privileged=true \

-v ~/issa/redis/redis.conf:/etc/redis/redis.conf \

-v ~/issa/redis/data:/data \

-d redis redis-server /etc/redis/redis.conf \

--appendonly yes --requirepass "123456"


Redis命令行客户端


Redis安装完成后就自带了命令行客户端:redis-cli,使用方式如下:


redis-cli [options] [commonds]

其中常见的options有:


  • -h 127.0.0.1:指定要连接的redis节点的IP地址,默认是127.0.0.1
  • -p 6379:指定要连接的redis节点的端口,默认是6379
  • -a 123321:指定redis的访问密码


其中的commonds就是Redis的操作命令,例如:


ping:与redis服务端做心跳测试,服务端正常会返回pong

不指定commond时,会进入redis-cli的交互控制台


操作:


redis-cli -h 127.0.0.1 -p 6379 -a 654321


4.png


上述连接方式会有警告,采用如下的方式即可。

懂了么?懂了懂了。


5.png


数据结构


Redis是一个key-value的数据库,key一般是String类型,不过value的类型多种多样:


6.png


命令字典


官方提供了命令查找的字典:https://redis.io/commands/


通过help [command] 可以查看一个命令的具体用法


常用命令


通用指令是部分数据类型的,都可以使用的指令,常见的有:


  1. KEYS:查看符合模板的所有key
  2. DEL:删除一个指定的key
  3. EXISTS:判断key是否存在
  4. EXPIRE:给一个key设置有效期,有效期到期时该key会被自动删除
  5. TTL:查看一个KEY的剩余有效期


开机自启


有些小伙伴并不是使用docker运行redis,那么可以设置redis开机自启,和docker的always差不多吧。


首先,新建一个系统服务文件:


vi /etc/systemd/system/redis.service

内容如下:


[Unit]
Description=redis-server
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /usr/local/src/redis-6.2.6/redis.conf
PrivateTmp=true
[Install]
WantedBy=multi-user.target

然后重载系统服务:


systemctl daemon-reload

现在,我们可以用下面这组命令来操作redis了:


# 启动
systemctl start redis
# 停止
systemctl stop redis
# 重启
systemctl restart redis
# 查看状态
systemctl status redis

执行下面的命令,可以让redis开机自启:


systemctl enable redis
相关文章
|
4月前
|
存储 缓存 NoSQL
【📕分布式锁通关指南 12】源码剖析redisson如何利用Redis数据结构实现Semaphore和CountDownLatch
本文解析 Redisson 如何通过 Redis 实现分布式信号量(RSemaphore)与倒数闩(RCountDownLatch),利用 Lua 脚本与原子操作保障分布式环境下的同步控制,帮助开发者更好地理解其原理与应用。
263 6
|
3月前
|
消息中间件 缓存 NoSQL
Redis各类数据结构详细介绍及其在Go语言Gin框架下实践应用
这只是利用Go语言和Gin框架与Redis交互最基础部分展示;根据具体业务需求可能需要更复杂查询、事务处理或订阅发布功能实现更多高级特性应用场景。
283 86
|
5月前
|
存储 缓存 NoSQL
Redis核心数据结构与分布式锁实现详解
Redis 是高性能键值数据库,支持多种数据结构,如字符串、列表、集合、哈希、有序集合等,广泛用于缓存、消息队列和实时数据处理。本文详解其核心数据结构及分布式锁实现,帮助开发者提升系统性能与并发控制能力。
|
3月前
|
存储 消息中间件 NoSQL
Redis数据结构:别小看这5把“瑞士军刀”,用好了性能飙升!
Redis提供5种基础数据结构及多种高级结构,如String、Hash、List、Set、ZSet,底层通过SDS、跳表等实现高效操作。灵活运用可解决缓存、计数、消息队列、排行榜等问题,结合Bitmap、HyperLogLog、GEO更可应对签到、UV统计、地理位置等场景,是高性能应用的核心利器。
|
3月前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
116 12
|
3月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
3月前
|
存储 缓存 NoSQL
【Redis】 常用数据结构之String篇:从SET/GET到INCR的超全教程
无论是需要快速缓存用户信息,还是实现高并发场景下的精准计数,深入理解String的特性与最佳实践,都是提升Redis使用效率的关键。接下来,让我们从基础命令开始,逐步揭开String数据结构的神秘面纱。
|
7月前
|
存储 NoSQL 算法
Redis设计与实现——数据结构与对象
Redis 是一个高性能的键值存储系统,其数据结构设计精妙且高效。主要包括以下几种核心数据结构:SDS、链表、字典、跳跃表、整数集合、压缩列表。此外,Redis 对象通过类型和编码方式动态转换,优化内存使用,并支持引用计数、共享对象和淘汰策略(如 LRU/LFU)。这些特性共同确保 Redis 在性能与灵活性之间的平衡。
|
7月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?

热门文章

最新文章