MySQL+多线程+Redis+算法+网络,redis实操指南

 Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。

 Redis支持数据的备份,即master-slave模式的数据备份。

 Redis 优势

 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。

 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

 原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。

 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

二、 Redis下载及安装

1. Redis版本说明

Redis原生只支持linux系统

Redis官方是不支持windows平台,windows版本是微软自己建立的分支,基于官方的redis源码上进行编译、发布、维护的,所以window平台上的redis版本都略低于官方版本。

2. Redis下载

wget http://download.redis.io/releases/redis-5.0.5.tar.gz

当前redis最新版本是4.0,它是一个测试版本,稳定版本是3.2版本。

可以直接在windows上下载,通过上传安装包到linux系统,也可以在linux下直接

最新稳定版本下载链接:http://download.redis.io/releases/redis-3.2.8.tar.gz

注意:必须可以上网,如果不能上网的同学可以在今天的资源中查找,然后通过lrzsz上传到linux系统。

3. Redis安装

第一步:将redis.tar.gz解压

tar -zxvf redis-3.2.8.tar.gz

第二步:进入redis-3.2.8目录

cd redis-3.2.8

第三步:对redis进行编译

make

注意:如果安装redis是报下面的错误,是因为系统没有安装gcc环境,缺少依赖

解决方案

在使用yum安装gcc依赖的时候,会报出错误

报错原因是因为DNS服务器错误,所以需要在/etc/resolv.conf文件中添加

依赖安装完成后,对redis进行重新编译,发现还会报错一个错误

错误原因,是因为Redis默认加载的是jemalloc中的配置文件,有时候没有就会报错,可以使用

指令,加载备用的配置文件即可进行编译

第四步:安装到指定的目录

make PREFIX=/usr/local/redis install

安装完成后,我们进入目录bin中查看

redis-server redis服务器

redis-cli redis命令行客户端

redis-benchmark redis性能测试工具

redis-check-aof AOF文件修复工具

redis-check-rdb RDB文件检索工具

4. redis客户端测试

第一步:启动redis服务

注意:我们需要将redis编译后的目录 中的redis.conf文件copy到我们自己的redis目录中。

这个redis.conf文件是redis的配置文件。

./redis-server ./redis.conf

注意:前面是redis-server服务,后面redis.conf配置文件。

Redis占用的端口是6379

可以通过redis-cli命令行客户端来测试redis是否启动成功

/usr/local/redis/bin/redis-cli –h localhost –p 6379

三、 Redis数据类型与常见操作

1. Redis数据类型介绍

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。

2. string类型常见操作

字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。

常见操作

 SET key value

设定该Key持有指定的字符串Value,如果该Key已经存在,则覆盖其原有值。返回值:总是返回"OK"

 GET key

获取指定Key的Value。如果与该Key关联的Value不是string类型,Redis将返回错误信息,因为GET命令只能用于获取string Value。

返回值:与该Key相关的Value,如果该Key不存在,则返回nil。

 MSET key value [key value …]

该命令原子性的完成参数中所有key/value的设置操作,其具体行为可以看成是多次迭代执行SET命令,其实就是同时给多个key设置value

返回值:该命令不会失败,始终返回OK。

 MGET key [key …]

返回所有指定Keys的Values,如果其中某个Key不存在,或者其值不为string类型,该Key的Value将返回nil。其实就是同时获取多个key的value。

返回值:返回一组指定Keys的Values的列表。

 SETNX key value

如果指定的Key不存在,则设定该Key持有指定字符串Value,此时其效果等价于SET命令。相反,如果该Key已经存在,该命令将不做任何操作并返回。

返回值:1表示设置成功,否则0表示设置失败。

(not exists)

 MSETNX key value [key value …]

该命令原子性的完成参数中所有key/value的设置操作,其具体行为可以看成是多次迭代执行SETNX命令。然而这里需要明确说明的是,如果在这一批Keys中有任意一个Key已经存在了,那么该操作将全部回滚,即所有的修改都不会生效。返回值:1表示所有Keys都设置成功,0则表示没有任何Key被修改。

 APPEND key value

如果该Key已经存在,APPEND命令将参数Value的数据追加到已存在Value的末尾。如果该Key不存在,APPEND命令将会创建一个新的Key/Value。

返回值:追加后Value的长度。

 DECR key

将指定Key的Value原子性的递减1。如果该Key不存在,其初始值为0,在decr之后其值为-1。如果Value的值不能转换为整型值,如Hello,该操作将执行失败并返回相应的错误信息。。

返回值:递减后的Value值。

 INCR key

将指定Key的Value原子性的递增1。如果该Key不存在,其初始值为0,在incr之后其值为1。如果Value的值不能转换为整型值,如Hello,该操作将执行失败并返回相应的错误信息。

返回值:递增后的Value值。

 DECRBY key decrement

将指定Key的Value原子性的减少decrement。如果该Key不存在,其初始值为0,在decrby之后其值为-decrement。如果Value的值不能转换为整型值,如Hello,该操作将执行失败并返回相应的错误信息。注意:该操作的取值范围是64位有符号整型。

返回值:减少后的Value值。

 INCRBY key increment

将指定Key的Value原子性的增加increment。如果该Key不存在,其初始值为0,在incrby之后其值为increment。如果Value的值不能转换为整型值,如Hello,该操作将执行失败并返回相应的错误信息。注意:该操作的取值范围是64位有符号整型。

返回值:增加后的Value值。

 GETSET key value

原子性的设置该Key为指定的Value,同时返回该Key的原有值。和GET命令一样,该命令也只能处理string Value,否则Redis将给出相关的错误信息。其实就是重新设置key的value,返回原来的value。

返回值:返回该Key的原有值,如果该Key之前并不存在,则返回nil。

 STRLEN key

返回指定Key的字符值长度,如果Value不是string类型,Redis将执行失败并给出相关的错误信息。

返回值:指定Key的Value字符长度,如果该Key不存在,返回0。

 SETEX key seconds value

原子性完成两个操作,一是设置该Key的值为指定字符串,同时设置该Key在Redis服务器中的存活时间(秒数)。该命令主要应用于Redis被当做Cache服务器使用时。

(expire)

 SETRANGE key offset value

替换指定Key的部分字符串值。从offset开始,替换的长度为该命令第三个参数value的字符串长度,其中如果offset的值大于该Key的原有值Value的字符串长度,Redis将会在Value的后面补齐(offset - strlen(value))数量的0x00,之后再追加新值。如果该键不存在,该命令会将其原值的长度假设为0,并在其后添补offset个0x00后再追加新值。鉴于字符串Value的最大长度为512M,因此offset的最大值为536870911。最后需要注意的是,如果该命令在执行时致使指定Key的原有值长度增加,这将会导致Redis重新分配足够的内存以容纳替换后的全部字符串,因此就会带来一定的性能折损。

返回值:修改后的字符串Value长度。

 GETRANGE key start end

截取字符串。该命令在截取子字符串时,将以闭区间的方式同时包含start(0表示第一个字符)和end所在的字符,如果end值超过Value的字符长度,该命令将只是截取从start开始之后所有的字符数据。

返回值:子字符串;

 SETBIT key offset value

设置在指定Offset上BIT的值,该值只能为1或0,在设定后该命令返回该Offset上原有的BIT值。如果指定Key不存在,该

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值