NoSQL概述
NoSQL = not only sql
优势:
高并发读写 high performance 海量数据的高效率存储和访问 huge storage 高可扩展性和高可用性 high scalability high availability
NoSQL四大分类
NoSQL特点
易扩展 灵活的数据模型 大数据量,高性能 高可用
Redis概述
高性能键值对数据库
键值数据类型
字符串 列表 散列 集合 有序集合
应用场景
缓存 任务队列 网站访问统计 数据过期处理 分布式集群架构中的session分离
Redis安装
环境搭建
虚拟机 VMware 10.0.2 Linux centOS-6.5 ssh客户端 secureCRT 7.3 secureFX 7.3
Linux 下安装
Window 下安装
下载地址:https://github.com/MSOpenTech/redis/releases
mac 下安装
执行 brew install redis 后台服务启动 brew services start redis 重启服务:brew services restart redis 或者直接启动:redis-server /usr/local/etc/redis.conf 打开客户端 redis-cli
通用设置
# 外网访问,注释本机访问 # bind 127.0.0.1 # 设置后台启动 daemonize yes # 设置密码 requirepass <password>
开机自启
vim /etc/init.d/redis
#!/bin/bash #chkconfig: 22345 10 90 #description: Start and Stop redis # ===== 修改为自己的参数 ====== REDISPORT=6379 EXEC=/opt/redis-5.0.5/src/redis-server CLIEXEC=/opt/redis-5.0.5/src/redis-cli PIDFILE=/var/run/redis_${REDISPORT}.pid CONF="/opt/redis-5.0.5/redis.conf" # =========== case "$1" in start) if [ -f $PIDFILE ];then echo "$PIDFILE exists,process is already running or crashed" else echo "Starting Redis server..." $EXEC $CONF fi ;; stop) if [ ! -f $PIDFILE ];then echo "$PIDFILE does not exist,process is not running" else PID=$(cat $PIDFILE) echo "Stopping..." $CLIEXEC -p $REDISPORT shutdown while [ -x /proc/${PID} ] do echo "Waiting for Redis to shutdown..." sleep 1 done echo "Redis stopped" fi ;; restart) "$0" stop sleep 3 "$0" start ;; *) echo "Please use start or stop or restart as first argument" ;; esac
启动指令
# 脚本权限 chmod +x /etc/init.d/redis # 配置redis开机启动 chkconfig redis on # 把脚本添加到系统服务列表 chkconfig --add redis chkconfig redis on chkconfig --list //查看所有注册的脚本文件 # 启动服务 service redis start
参考
简单使用
127.0.0.1:6379> set name imool OK 127.0.0.1:6379> get name "imool" 127.0.0.1:6379> keys * 1) "name" 2) "a" 127.0.0.1:6379> del name (integer) 1 127.0.0.1:6379> keys * 1) "a" select num 切换数据库 move key db 移动
数据类型
string(字符串)set key value ; get key hash(哈希)hmset key field value; hget key field; hgetall key list(列表)lpush key value; lrange key start stop set(集合)sadd key member; smembers key zset(sorted set:有序集合)zadd key score member; zrangebyscore key min max
中文文档:http://www.redis.cn/commands.html
Redis keys 命令
KEYS pattern 查找 key(所有 keys *, 部分keys xx?) DEL key 删除 key DUMP key 返回 key 序列化的值 EXISTS key 检查 key 是否存在 MOVE key db 移动 key EXPIRE key seconds 为 key 设置过期时间 PERSIST key 移除 key 的过期时间 TTL key 返回 key 的剩余生存时间(秒s)(TTL, time to live) RANDOMKEY 随机返回一个 key RENAME key newkey 修改 key 的名称 RENAMENX key newkey 仅当 newkey 不存在时,将 key 改名为 newkey TYPE key 返回 key 类型 flushdb //删除当前数据库中的所有Key flushall //删除所有数据库中的key
Redis string字符串 命令
SET key value 设置值 GET key 获取值 GETSET key value 获取旧值,设置新值 SETRANGE key offset value 覆写字符串值 GETRANGE key start end 返回子字符串 MSET key value [key value ...] 同时设置多个值 MGET key1 [key2..] 获取多个值 SETEX key seconds value 设置值和过期时间(秒s) SETNX key value 不存在时设置值 MSETNX key value [key value ...] 同时设置多个值,当且仅当所有key都不存在 INCR key 增一 DECR key 减一 INCRBY key increment 加值 DECRBY key decrement 减值 INCRBYFLOAT key increment 加浮点值 STRLEN key 返回长度 APPEND key value 末尾追加
Redis hash哈希 命令
HSET key field value 设置字段值 HGET key field 获取字段的值 HMSET key field1 value1 [field2 value2 ] 设置多个字段的值 HMGET key field1 [field2] 获取多个字段的值 HSETNX key field value 不存在时,设置字段的值 HGETALL key 获取所有字段和值 HKEYS key 获取所有字段 HVALS key 获取所有值 HLEN key 获取字段的数量 HDEL key field1 [field2] 删除多个字段 HEXISTS key field 查看字段是否存在 HINCRBY key field increment 字段加值 HINCRBYFLOAT key field increment 字段加浮点值
Redis list列表命令
LPUSH key value1 [value2] 头部插入 RPUSH key value1 [value2] 尾部插入 LPOP key 头部弹出 RPOP key 尾部弹出 LSET key index value 设置值 LINSERT key BEFORE|AFTER pivot value 插入元素 LINDEX key index 获取元素 LRANGE key start stop 获取多个元素(全部 0 -1) LREM key count value 移除元素(count:>0从前往后,=0所有,<0从后往前) LLEN key 获取长度 LTRIM key start stop 修剪,保留区间 LPUSHX key value 插入到已存在的列表头部 RPUSHX key value 插入到已存在的列表尾部 BLPOP key1 [key2 ] timeout 头部弹出,没有会阻塞 BRPOP key1 [key2 ] timeout 尾部弹出,没有会阻塞 RPOPLPUSH source destination 弹出一个值,插入到另外一个列表中并返回 BRPOPLPUSH source destination timeout 弹出一个值,插入到另外一个列表中并返回,如果没有会阻塞
Redis set集合命令
SADD key member1 [member2] 添加成员 SREM key member1 [member2] 移除成员 SCARD key 获取成员数 SMEMBERS key 所有成员 SISMEMBER key member 成员检查 SRANDMEMBER key [count] 随机返回 SPOP key 随机弹出 SMOVE source destination member 移动 SDIFF key1 [key2] 差集 SINTER key1 [key2] 交集 SUNION key1 [key2] 并集 SDIFFSTORE destination key1 [key2] 差集并存储 SINTERSTORE destination key1 [key2] 交集并存储 SUNIONSTORE destination key1 [key2] 并集存储
发表评论