Python视频学习(十四、Redis)

0. Redis基本介绍

  • NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
  • NoSQL中的产品种类相当多:
    • Mongodb
    • Redis
    • Hbase hadoop
    • Cassandra hadoop

NoSQL和SQL数据库的比较:

  • 适用场景不同:sql数据库适合用于关系特别复杂的数据查询场景,nosql反之
  • “事务”特性的支持:sql对事务的支持非常完善,而nosql基本不支持事务
    两者在不断地取长补短,呈现融合趋势

Redis简介

  • Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。
  • Redis是 NoSQL技术阵营中的一员,它通过多种键值数据类型来适应不同场景下的存储需求,借助一些高层级的接口使用其可以胜任,如缓存、队列系统的不同角色

Redis特性:

Redis 与其他 key - value 缓存产品有以下三个特点:

  • 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应用场景

  • 用来做缓存(ehcache/memcached)——redis的所有数据是放在内存中的(内存数据库)
  • 可以在某些特定应用场景下替代传统数据库——比如社交类的应用
  • 在一些大型系统中,巧妙地实现一些特定的功能:session共享、购物车
  • 只要你有丰富的想象力,redis可以用在可以给你无限的惊喜…….

1. 安装和配置

1.1 下载安装Redis

官网地址

$ wget http://download.redis.io/releases/redis-5.0.3.tar.gz
$ tar xzf redis-5.0.3.tar.gz
$ sudo mv  redis-5.0.3 /usr/local
$ cd /usr/local/redis-5.0.3
$ sudo make test
$ sudo make install

在这里插入图片描述

根据README.md中的说法,make install安装之后,可以在src目录下运行

./redis-server /path/to/redis.conf   # 运行server,并且制定配置文件
或者
% ./redis-server --port 9999 --replicaof 127.0.0.1 6379   # 不用配置文件,直接指定参数
% ./redis-server /etc/redis/6379.conf --loglevel debug

但是make install只会安装二进制文件,并不会配置init 脚本或者配置文件到合适的位置。为了创建一个开发环境,Redis提供了

% cd utils
% ./install_server.sh

这个脚本会询问所有情况,并且配置各种deamon服务和配置文件目录、log目录等等

之后就会有一个服务,名称叫做redis_端口号的,启动即可

遇到的问题

  1. 没有cc
sudo apt install gcc
  1. jemalloc错误
make[1]: Entering directory '/home/yyfyifan/Downloads/redis-5.0.3/src'
    CC Makefile.dep
    CC adlist.o
In file included from adlist.c:34:0:
zmalloc.h:50:10: fatal error: jemalloc/jemalloc.h: No such file or directory
 #include <jemalloc/jemalloc.h>
          ^~~~~~~~~~~~~~~~~~~~~
compilation terminated.
Makefile:248: recipe for target 'adlist.o' failed
make[1]: *** [adlist.o] Error 1
make[1]: Leaving directory '/home/yyfyifan/Downloads/redis-5.0.3/src'
Makefile:6: recipe for target 'test' failed
make: *** [test] Error 2

解决方式:

make MALLOC=libc
  1. tcl版本
You need tcl 8.5 or newer in order to run the Redis test

解决方式:

sudo apt install 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 
--------------------- 
原文:https://blog.csdn.net/luyee2010/article/details/18766911 

1.2 配置信息

sudo vi /etc/redis/redis.conf
  • 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip
    bind 127.0.0.1

  • 端⼝,默认为6379
    port 6379

  • 是否以守护进程运⾏
    daemonize yes

    • 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
    • 如果以⾮守护进程运⾏,则当前终端被阻塞
    • 设置为yes表示守护进程,设置为no表示⾮守护进程
  • 数据⽂件
    dbfilename dump.rdb

  • 数据⽂件存储路径
    dir /var/lib/redis

  • ⽇志⽂件
    logfile /var/log/redis/redis-server.log

  • 数据库,默认有16个
    database 16

  • 主从复制,类似于双机备份。
    slaveof

1.3 连接服务器

redis-cli  # 默认是连接到本地的6379端口,可以指定参数

运行测试命令:

PING
> PONG

数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库,即0号数据库

SELECT N # 切换到n号数据库

2. 数据操作

官网API

2.1 数据类型

redis是key-value的数据结构,每条数据都是⼀个键值对。

键是字符串,而值有5种类型:

  • 字符串string
  • 哈希hash(相当于字典)
  • 列表list(每个元素都是字符串)
  • 集合set(每个元素都是字符串)
  • 有序集合zset(每个元素都是字符串)
    在这里插入图片描述

2.2 字符串类型

字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值