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

该篇已经被收录进《中间件核心技术》专栏

SQL和NoSQL

在这里插入图片描述

redis简介

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

特征:

  1. 键值(key-value)型,value支持多种不同数据结构,功能丰富
  2. 单线程,每个命令具备原子性
  3. 低延迟,速度快(基于内存、IO多路复用、良好的编码)。
  4. 支持数据持久化
  5. 支持主从集群、分片集群
  6. 支持多语言客户端

下载镜像

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

下载redis镜像
docker pull redis

配置文件

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

在这里插入图片描述
我们先cp一份出来,养成良好的习惯

cp redis.conf redis.conf.bck

在这里插入图片描述

修改常见的配置

# 允许访问的地址,默认是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

在这里插入图片描述
上述连接方式会有警告,采用如下的方式即可。
懂了么?懂了懂了。

在这里插入图片描述

数据结构

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

在这里插入图片描述

命令字典

官方提供了命令查找的字典: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

猜你喜欢

转载自blog.csdn.net/CSDN_SAVIOR/article/details/124914588
今日推荐