分布式系列十: Redis安装和命令
redis是一个开源的, 内存数据结构存储, 一般用来作为数据库,缓存和消息代理.
Redis的优势
多种数据结构
- 字符类型String
- 散列类型Hash
- 列表类型List
- 集合类型Set
- 有序集合类型SortedSet
功能丰富
- 超时时间设置
- 可以通过列表类型来实现分布式队列
- pub/sub 消息模式
简单
- 多种操作命令
Redis应用场景
- 缓存
- 秒杀,抢购等
- 单点登陆, 分布式session等
- 网站访问排名
- 消息队列
安装
- 手工下载或通过
wget http://download.redis.io/releases/redis-5.0.4.tar.gz tar xzf redis-5.0.4.tar.gzcd redis-5.0.4make
缺少make包, 则需要通过
sudo apt-get install make安装
make报错
/bin/sh: cc: command not found缺少gcc包, 通过sudo apt-get install gcc
如果报错
fatal error: jemalloc/jemalloc.h: No such file or directory则使用make MALLOC=libc编译
可以使用命令
make test测试. 报错You need tcl 8.5 or newer in order to run the Redis test则需要安装tcl包.
安装方法如下:
wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz
sudo tar xzvf tcl8.6.1-src.tar.gz -C /usr/local/
cd /usr/local/tcl8.6.1/unix/
sudo ./configure
sudo make
sudo make install
安装完成后运行make test命令成功.
- 需要安装到指定目录, 则可以使用
make install PREFIX=/mnt/d/redis注意添加配置文件
启动命令
- 启动
sh /redis-server ../conf/redis.conf
以后台进程的方式启动需要修改redis.conf文件的daemonize=yes - 客户端连接
sh /redis-cli -h 192.168.1.123 -p 6379
配置文件中的
bind用来绑定服务端的ip, 为了安全,默认不允许外网访问
默认保护模式protect-mode=yes
多数据支持
默认支持16个数据库, databases=16, 默认使用的是DB 0 . redis数据库不支持自定义名称, 且不能单独做授权, 各个数据库之间并非完全隔离. flushall命令可以清空redis中所有的数据.
select 3 转到索引为3的数据库
使用命令
keys prifix*查找到所有开头为prifix的键,pattern可以使用[? * [] ]匹配EXISTS key是否存keytype key获取数据结构
字符类型
key的最大存储为512M.
set key value比较重要的setnxget keyincr key递增值incrby key [step]递增指定的stepstrlen key获得长度mget key1 key2 key3批量获取多个key的值set key1 value1 key2 value2批量设置多个键值
key的设计可以参看阿里的规范, 例如
业务名:表名:id
列表类型
lpush key value左边push数据,对应的是rpushlpop key获取数据, 同时数据被移除,对应的是rpopllen key列表长度lrange key start stop获取片段, start=-1 表示从头,stop=-1表示到结尾lrem key count value删除lset key index value设置索引的值
散列类型
不支持数据类型嵌套, 比如hash中存储一个list.
hset key field value设置hget key field获取hmset key field1 value1 field2 value2设置多个值hmget key field1 field2hgetall key获取全部信息, 包括key,valuehexists key field判断是否存在hincrybyhsetnxhdel key field删除一个或多个字段
集合类型
和list相比, 不能有重复元素, 且是无序的
sadd key member...设置一个或多个元素, 返回增加的数量smembers key获取元素sdiff key1 key2差集计算sunion key1 key2并集计算
有序集合
zadd key score member增加元素zrange key start stop withscores获取片段 withscores 用来获取分数
可以用来做排名统计.
redis的事务
比较鸡肋, 不建议使用, 有时候不能回滚
multi 开启事务;
set get...等操作为具体的事务操作
exec 提交事务
过期时间
expire key timeout 设置超时时间
ttl key 获得key过期时间
发布订阅
publish channel message
subscribe channel
分布式锁
可使用setnx实现.
分布式系列十: Redis安装和命令的更多相关文章
- Redis系列一 Redis安装
Redis系列一 Redis安装 1.安装所使用的操作系统为Ubuntu16.04 Redis版本为3.2.9 软件一般下载存放目录为/opt,以下命令操作目录均为/opt root@ubunt ...
- Redis安装、命令以及设置密码遇到的问题
一.下载Redis 如果没有 安装wget先安装wget和gcc(使用make的时候会用上) wget http://download.redis.io/releases/redis-4.0.8.ta ...
- 分布式系列十二: Redis高级主题
持久化 Redis 支持持久化, 其持久化数据有两种方式. 两种可以同时使用. 如果同时使用, Reids 在重启时将使用 AOF 方式来还原数据. RDB 按照一定策略定时同步内存的数据到磁盘.文件 ...
- 分布式系列十五: MongoDB数据库
MongoDB 是基于分布式文件存储的数据库. 开发语言是C++. 具有高性能,可扩展的特点. 是NoSql中最像关系数据库的. 什么是NoSql NoSQL 是 Not only SQL 的缩写. ...
- 分布式系列十一: Redis进阶
分布式锁 数据库 数据库是使用唯一索引不允许重复的特性(或自定义实现如乐观锁). 但持有锁的进程如果释放锁时异常则容易导致死锁. zookeeper 使用临时节点, watcher可以获得节点被删除的 ...
- redis安装和命令使用
前言: redis是一个key-value的存储系统,value支持string.list.set.zset.hash五种类型,且支持数据的本地存储 一.安装redis 前提:linux下需要安装 ...
- 分布式缓存技术redis学习系列(一)——redis简介以及linux上的安装
redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...
- 分布式缓存技术redis系列(一)——redis简介以及linux上的安装
redis简介 redis是NoSQL(No Only SQL,非关系型数据库)的一种,NoSQL是以Key-Value的形式存储数据.当前主流的分布式缓存技术有redis,memcached,ssd ...
- 分布式缓存技术redis学习系列(五)——redis实战(redis与spring整合,分布式锁实现)
本文是redis学习系列的第五篇,点击下面链接可回看系列文章 <redis简介以及linux上的安装> <详细讲解redis数据结构(内存模型)以及常用命令> <redi ...
随机推荐
- 《css世界》笔记之流、元素与基本尺寸
1. 块级元素 基本特性:就是一个水平流上只能单独显示一个元素,多个块级元素则换行显示. 块级元素和"display 为block 的元素"不是一个概念,display:list- ...
- PHP将汉字转为拼音
没什么难度,最大的难点应该是需要有一个汉字-拼音库. <?php function spell($str, $ishead=0){ $restr = ''; $str = trim($str); ...
- django捡破烂
一 Django的model form组件 这是一个神奇的组件,通过名字我们可以看出来,这个组件的功能就是把model和form组合起来,先来一个简单的例子来看一下这个东西怎么用:比如我们的数据库 ...
- jeecg入门操作—树型表单开发
树表类型表单 表单创建,基础配置如下: 1.设置表单类型为:单表; 2.是否树选择:是; 3.设置特殊字段:[树形表单父id][树开表单列] 结果测试
- 【alpha阶段】第十次Scrum Meeting
每日任务内容 队员 昨日完成任务 明日要完成的任务 牛宇航 #26 评价总览接口编写https://github.com/rRetr0Git/rateMyCourse/issues/26 alpha阶 ...
- 关于echarts.js 柱形图
echarts.js官网: http://www.echartsjs.com/index.html 这是我所见整理最详细echarts.js 柱形图博客: https://blog.csdn.net/ ...
- vue中watch检测到不到对象属性的变化的解决方法
watch: { option: { handler(newVal) { console.log(newVal); }, deep: true, immediate: true } }, 需要深层wa ...
- What Kind of Friends Are You? ZOJ 3960
比赛的时候用vector交集做的...情况考虑的不全面 wrong到疯 赛后考虑全了情况....T了 果然 set_intersection 不能相信 嗯 不好意思 交集a了 第二个代码 求出来 ...
- Linux系统中硬链接和软链接(符号链接)的区别
首先是创建链接的命令 ln file link //创建硬链接 ln -s item link //创建软链接 区别 硬链接 硬链接是一开始Unix创造链接的方式,而软连接就更现代一点.创建硬链接的时 ...
- 「洛谷4197」「BZOJ3545」peak【线段树合并】
题目链接 [洛谷] [BZOJ]没有权限号嘤嘤嘤.题号:3545 题解 窝不会克鲁斯卡尔重构树怎么办??? 可以离线乱搞. 我们将所有的操作全都存下来. 为了解决小于等于\(x\)的操作,那么我们按照 ...