Redis 入门之基础
Posted 不负光阴不负卿
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis 入门之基础相关的知识,希望对你有一定的参考价值。
1.安装
1.1 Window下安装
redis-server.exe redis.windows.conf
redis-cli.exe -h 127.0.0.1 -p 6379
1.2 mac下 安装
brew install redis
brew services start redis
redis-server /usr/local/etc/redis.conf
1.3 配置
ONFIG GET CONFIG_SETTING_NAME
CONFIG GET port
2.启动和停止Reids
本节将分别介绍开发环境和生产环境中运行Redis的方法以及正确停止Redis的步骤。
在这之前首先需要了解Redis包含的可执行文件有哪些,如下图:
我们最常使用的两个程序是redis-server和redis-cli,其中redis-server是Reids的服务器,启动Redis即运行redis-server;而redis-cli是Redis自带的Redis命令行客户端,是学习Redis的重要工具。
2.1 启动Redis
启动Redis有直接启动和通过初始化脚本启动两种方式,分别适用于开发环境和生产环境。
2.1.1 直接启动
直接运行redis-server即可启动Redis。
$ redis-server
Redis服务器默认会使用6379端口,通过--port参数可以自定义端口号。
$ redis-server --port 6380
2.1.2 停止Reids
考虑到Redis有可能正在将内存中的数据同步到硬盘中,强行终止 Redis 进程可能会导致数据丢失。正确停止Redis的方式应该是向Redis发送SHUTDOWN命令,方法为:
$ redis-cli SHUTDOWN
当Redis收到SHUTDOWN命令后,会先断开所有客户端连接,然后根据配置执行持久化,最后完成退出。
另一种方法是使用‘kill Redis 进程的PID’也可以正常结束Reids。
3. Redis命令行客户端
3.1 发送命令
redis-cli执行时会自动按照默认配置(服务器地址为127.0.0.1,端口号为6379)连接Reids.通过-h和-p参数可以自定义地址和端口号:
redis-cli -h 127.0.0.1 -p 6379
Redis提供了 PING 命令来测试客户端与Redis的连接是否正常,如果正常会收到回复 PONG,如:
$ redis-cli PING
PONG
第二种方式时不附带参数运行 redis-cli,这样会进入交互模式,可以自由输入命令,例如:
$ redis-cli
redis 127.0.0.1:6379>PING
PONG
redis 127.0.0.1:6379>ECHO hi
"hi"
这种方式在要输出多条命令时比较方便,也是本书中主要采用的方式。
3.2 命令返回值
命令的返回值有5种类型,对于每种类型redis-cli的展现结果都不同。
1.状态回复
状态回复(status reply)是最简单的一种回复,比如向Redis发送SET命令设置某个键的值时,Redis会回复状态OK表示设置成功。另外之前演示的对PING 命令的回复PONG也是状态回复。状态回复直接显示状态信息,例如:
redis 127.0.0.1:6379>PING PONG
2.错误回复
当出现命令不存在或命令格式有错误等情况时Redis会返回错误回复(error reply)。错误回复以(error)开头,并在后面跟上错误信息。如执行一个不存在的命令:
redis 127.0.0.1:6379>ERRORCOMMEND (error) ERR unknown command ‘ERRORCOMMEND‘
3.整数回复Redis虽然没有整数类型,但是却提供了一些用于整数操作的命令,如地增值的 INCR 命令会以整数形式返回递增后的键值。除此之外,一些其他命令会返回整数,如可以获取当前数据库中键的数量的 DBSIZE 命令等。整数回复(integer reply)以(integer)开头,并在后面跟上整数数据:
redis 127.0.0.1:6379>INCR foo (integer) 1
4.字符串回复 字符串回复(bulk reply)是最常见的一种回复类型,当请求一个字符串类型键的键值或一个其他类型键中的某个元素时就会得到一个字符串回复。字符串回复以双引号包裹:
redis 127.0.0.1:6379>GET foo
"1"
特殊情况是当请求的键值不存在时会得到一个空结果,显示为(nil).如:
redis 127.0.0.1:6379>GET noexists
(nil)
5.多行字符串回复
多行字符串回复(multi-bulk reply) 同样很常见,如当请求一个非字符类型键的元素列表时就会收到多行字符串回复。多行字符串回复中的每行字符串都以一个序号开头,如:
redis 127.0.0.1:6379>KEYS *
1) "bar"
2) "foo"
4. 多数据库
Redis是一个字典解构的存储服务器,而实际上一个Redis实例提供了多个用来存储数据的字典,客户端可以指定将数据存储在哪个字典中。
每个数据库对外都是一个从0开始的递增数字命名,Redis默认支持16个数据库,可以通过配置参数 databases 来修改这一数字。客户端与Redis建立连接后会自动选择0号数据库,不过可以随时使用SELECT 命令更换数据库,如要选择 1 号数据库:
redis 127.0.0.1:6379>SELECT 1
OK
redis 127.0.0.1:6379[1]> GET foo
(nil)
1.首先Redis不支持自定义数据库的名字,每个数据库都以编号命名,开发者必须自己记录哪些数据库存储了哪些数据。
2.Redis也不支持为每个数据库设置不同的访问密码。所以一个客户端要么可以访问全部数据库要么连一个数据库也没有权限访问。
3.多个数据之间并不是完全隔离的,比如 FLUSHALL 命令可以清空一个 Redis实例中所有数据库中的数据。
综上所述,这些数据库更像是一种命名空间,而不适宜存储不同应用程序的数据。
比如,可以使用0号数据库存储某个应用生产环境中的数据,使用1号数据库存储测试环境中的数据。
由于Redis非常轻量级,一个空Redis实例占用的内存只有1MB左右,所以不用担心多个Redis实例会额外占用很多内存。
以上是关于Redis 入门之基础的主要内容,如果未能解决你的问题,请参考以下文章