《python打卡学数据库的第一天》快来跟着小编从零开始学习redis数据库吧~(代码片段)

小可爱酥酥 小可爱酥酥     2022-12-13     437

关键词:

 目录

学习目标

nosql介绍

NoSQL:一类新出现的数据库(not only sql)

NoSQL和SQL数据库的比较:

Redis简介

Redis特性

Redis 优势

Redis应用场景

推荐阅读

Redis 安装

其他补充

学习目标

配置

核心配置选项

参考资料

学习目标

服务器端

客户端

学习目标

重要文档

数据结构

数据操作行为

与Python交互

安装包

调⽤模块

学习目标

主从概念

主从配置

配置主

配置从

数据操作

为什么要有集群

集群的概念

redis集群

搭建集群

参考阅读


学习目标

  • 能够描述出什么是 nosql
  • 能够说出 Redis 的特点

nosql介绍

NoSQL:一类新出现的数据库(not only sql)

  • 泛指非关系型的数据库
  • 不支持SQL语法
  • 存储结构跟传统关系型数据库中的那种关系表完全不同,nosql中存储的数据都是KV形式
  • NoSQL的世界中没有一种通用的语言,每种nosql数据库都有自己的api和语法,以及擅长的业务场景
  • NoSQL中的产品种类相当多:
    • Redis
    • Mongodb
    • 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还支持 publish/subscribe, 通知, key 过期等等特性。

Redis应用场景

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

推荐阅读

Redis 安装

  • step2:解压

    tar xzf redis-4.0.9.tar.gz

  • step3:移动,放到usr/local⽬录下

    sudo mv ./redis-4.0.9 /usr/local/redis/

  • step4:进⼊redis⽬录

    cd /usr/local/redis/

  • step5:生成

    sudo make

 

step6:测试,这段运⾏时间会较⻓

sudo make test

其他补充

核心配置选项

参考资料

redis配置信息http://blog.csdn.net/ljphilp/article/details/52934933

客户端

重要文档

数据结构

数据操作行为

点击中⽂官⽹查看命令⽂档http://redis.cn/commands.html

与Python交互

  • step7:安装,将redis的命令安装到/usr/local/bin/⽬录

    sudo make install

  • step8:安装完成后,我们进入目录/usr/local/bin中查看

    cd /usr/local/bin
    ls -all

    • redis-server redis服务器
    • redis-cli redis命令行客户端
    • redis-benchmark redis性能测试工具
    • redis-check-aof AOF文件修复工具
    • redis-check-rdb RDB文件检索工具
  • step9:配置⽂件,移动到/etc/⽬录下

    • 配置⽂件⽬录为/usr/local/redis/redis.conf

      sudo cp /usr/local/redis/redis.conf /etc/redis/

  • Mac 上安装 Redis:

    • 安装 Homebrew:

    https://brew.sh/

    • 使用 brew 安装 Redis

    https://www.cnblogs.com/cloudshadow/p/mac_brew_install_redis.html

    学习目标

  • 能够根据参考资料修改常用Redis配置
  • 配置

  • Redis的配置信息在/etc/redis/redis.conf下。

  • 查看

    sudo vi /etc/redis/redis.conf

  • 绑定ip:如果需要远程访问,可将此⾏注释,或绑定⼀个真实ip

    bind 127.0.0.1

  • 端⼝,默认为6379

    port 6379

  • 是否以守护进程运⾏

    • 如果以守护进程运⾏,则不会在命令⾏阻塞,类似于服务
    • 如果以⾮守护进程运⾏,则当前终端被阻塞
    • 设置为yes表示守护进程,设置为no表示⾮守护进程
    • 推荐设置为yes

    daemonize yes

  • 数据⽂件

    dbfilename dump.rdb

  • 数据⽂件存储路径

    dir /var/lib/redis

  • ⽇志⽂件

    logfile "/var/log/redis/redis-server.log"

  • 数据库,默认有16个

    database 16

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

    slaveof

    学习目标

  • 了解Redis服务器端和客户端的命令

    服务器端

  • 服务器端的命令为redis-server

  • 客户端的命令为redis-cli
  • 可以使⽤help查看帮助⽂档

    redis-cli --help

  • 连接redis

    redis-cli

  • 可以使⽤help查看帮助⽂档

    redis-server --help

  • 个人习惯

    ps aux | grep redis 查看redis服务器进程
    sudo kill -9 pid 杀死redis服务器
    sudo redis-server /etc/redis/redis.conf 指定加载的配置文件

  • 运⾏测试命令

    ping

  • 切换数据库

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

    select 10

  • 学习目标

  • 能够写出Redis中string类型数据的增删改查操作命令
  • 能够写出Redis中hash类型数据的增删改查相关命令
  • Redis 参考命令
  • Redis 官方文档
  • redis是key-value的数据结构,每条数据都是⼀个键值对
  • 键的类型是字符串
  • 保存
  • 修改
  • 获取
  • 删除
  • 注意:键不能重复

  • 值的类型分为五种:

    • 字符串string
    • 哈希hash
    • 列表list
    • 集合set
    • 有序集合zset
  • 太多啦~这里就省略了哈~详细的可以在官方交流口口裙获取:1141860209

安装包

安装Redis的有3种方式https://github.com/andymccurdy/redis-py

第一种:进⼊虚拟环境,联⽹安装包redis

pip install redis

第二种:进⼊虚拟环境,联⽹安装包redis

easy_install redis

调⽤模块

  • 引⼊模块

    from redis import StrictRedis

  • 这个模块中提供了StrictRedis对象,⽤于连接redis服务器,并按照不同类型提供 了不同⽅法,进⾏交互操作
  • 第三种:到中⽂官⽹-客户端下载redis包的源码,使⽤源码安装

    一步步执行 wget https://github.com/andymccurdy/redis-py/archive/master.zip
    unzip master.zip
    cd redis-py-master
    sudo python setup.py install

学习目标

  • 能够根据课件中的步骤搭建 Redis 的主从

主从概念

  • ⼀个master可以拥有多个slave,⼀个slave⼜可以拥有多个slave,如此下去,形成了强⼤的多级服务器集群架构
  • master用来写数据,slave用来读数据,经统计:网站的读写比率是10:1
  • 通过主从配置可以实现读写分离

  • master和slave都是一个redis实例(redis服务)

主从配置

配置主

  • 查看当前主机的ip地址

    ifconfig

  • 修改/etc/redis/redis.conf文件

    sudo vi redis.conf
    bind 192.168.26.128

  • 重启redis服务

    sudo service redis stop
    sudo redis-server redis.conf

配置从

  • 复制/etc/redis/redis.conf文件

    sudo cp redis.conf ./slave.conf

  • 修改redis/slave.conf文件

    sudo vi slave.conf

  • 编辑内容

    bind 192.168.26.128
    slaveof 192.168.26.128 6379
    port 6378

  • redis服务

    sudo redis-server slave.conf

  • 查看主从关系

    redis-cli -h 192.168.26.128 info Replication

数据操作

  • 在master和slave分别执⾏info命令,查看输出信息 进入主客户端

    redis-cli -h 192.168.26.128 -p 6379

  • 进入从的客户端

    redis-cli -h 192.168.26.128 -p 6378

  • 在master上写数据

    set aa aa

  • 在slave上读数据
     

    get aa

为什么要有集群

  • 之前我们已经讲了主从的概念,一主可以多从,如果同时的访问量过大(1000w),主服务肯定就会挂掉,数据服务就挂掉了或者发生自然灾难
  • 大公司都会有很多的服务器(华东地区、华南地区、华中地区、华北地区、西北地区、西南地区、东北地区、台港澳地区机房)

集群的概念

  • 集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户与集群相互作用时,集群像是一个独立的服务器。集群配置是用于提高可用性和可缩放性。 

当请求到来首先由负载均衡服务器处理,把请求转发到另外的一台服务器上。

redis集群

  • 分类
    • 软件层面
    • 硬件层面
  • 软件层面:只有一台电脑,在这一台电脑上启动了多个redis服务。

  • 硬件层面:存在多台实体的电脑,每台电脑上都启动了一个redis或者多个redis服务。

搭建集群

  • 当前拥有两台主机172.16.179.130、172.16.179.131,这⾥的IP在使⽤时要改为实际值

下面是我整理的一些学习资料

 - Python学习路线
 - Python自学视频
 - 300本电子书加学霸笔记
 - 100个游戏源码、项目案例
 - Python安装包以及教程和激活码
   君羊号:【881744585】获取

这都是我总结出来的宝贝,给需要的小伙伴,希望大家的努力都不负所望。【广告勿扰谢谢】

 

git打卡的第一天

因为某种原因,所以不得不重新巩固下前端的基础知识,从最基本的学习还得额外的学习新知识,倍感压力之大。昨天初略学习下git,算是自己学习的一个新知识。简单记录下,希望四海八荒的大神看过来,有错的请指导。git下... 查看详情

第一天打卡,fighting

...英语啦!虽然只是背单词,但学的进去就是个好的开头啊??打卡第一天,抄完了词缀并主动在背单词时去学习应用,背了42个单词?虽然还没达到单词书规划的量,但也不错哦!背了将近三个小时啊??还是背单词的方法不太熟练,不... 查看详情

如何学习网络安全?手把手带你跟着b站一起学——网络安全渗透测试篇(第一天)

...手把手带你跟着B站一起学——网络安全渗透测试篇(第一天)前言物理机,虚拟机,集成开发环境,网站的关系基础概念名词的补充1.什么是服务器2.什么是客户端3.什么是getshell4.什么是菜刀、蚁剑、冰蝎5.什... 查看详情

photoshop初学一些常用指令(学ps的第一天)

选区部分:撤销(只能20步):ctrl+alt+z              取消选框:ctrl+alt+d            &nbs 查看详情

跟着java教程学习,第一天(代码片段)

...笔记,比对着iOS的Objective-C语言,对照着学习学习的第一天,肯定就是HelloWorld!了。(习惯去快速格式化代码,我总忘,写出来代码好丑)首先定义一个类,类名习惯首字母大写。publicclassHello...类中,... 查看详情

[盘点]现今热门的h5网游

...息了一周,又要开始新的一年的奋斗了!于是小编从回来的第一天就开始花时间自己整理了一篇文章,所有各位是不是应该夸一夸小编呢?因为小编又要开始分享“干货”了。(都是小编自己的一些理解,若有错误或不足... 查看详情

第一天

来到这里的第一天,希望自己能学有所获。放一张自己拍的照片,激励自己!! 查看详情

学python的第一堂课程:记录第一次(代码片段)

2021年11月10日,在B站上搜索了Python的学习课程,简单学习了一天的编程课程,这也是我第一次尝试着写一篇博客,菜鸟初来乍到,望大家多多包涵!首先来给大家分享一下我所学的几个代码块,主要是... 查看详情

[盘点]现今热门的h5网游

...,又要开始新的一年的奋斗了!于是小编从回来的第一天就开始花时间自己整理了一篇文章,所有各位是不是应该夸一夸小编呢?因为小编又要开始分享“干货”了。(都是小编自己的一些理解,若有错误... 查看详情

python二次学习之二(第一天学到的一个重点pickle模块)

ythonpickle模块作用是持久化的储存数据。经常遇到在Python程序运行中得到了一些字符串、列表、字典等数据,想要长久的保存下来,方便以后使用,而不是简单的放入内存中关机断电就丢失数据。python模块大全中的Pickle模块就派... 查看详情

21天python打卡第9天基础技能(代码片段)

...c;比如将时间日期的处理,数据文件的读写,以及数据库的简单操作。今天来说说源码打包和网络编程。​​ 活动地址:CSDN21天学习挑战赛学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天... 查看详情

python怎么获得每个月的第一天和最后一天

第一天不用获取吧,都是1呀,最后一天的话可以使用标准模块的calendar模块的monthrange(year,month)方法该方法返回指定年月的最后一天星期和日期,类型为tuple,如import calendarprint calendar.monthrange(2015, 2)结果为(6,28),6为最... 查看详情

培训的第一天

第一天来,上午主要讲了一些大纲性质的东西,我们将做什么样的工作,有什么样的学习内容之类。讲真都好多年没正儿八经学过东西了,这双操作鼠标键盘驰骋沙场多年的手也好久没干过正事了,不过为了最原始的目的,为了... 查看详情

基础学习之第一天(代码片段)

一.python介绍python的创始人为吉多·范罗苏姆(GuidovanRossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。最新的TIOBE排行榜,Python已经占据世界第... 查看详情

沛齐的第一天授课

开发语言:   高级语言:PythonJava、PHPC#GorubyC++...===》字节码   低级语言:C、汇编===》机器码 1.语言之间的对比:   PHP类:适用于写网页,局限性   PythonJava:及可以写网页 也可以写后台功能   -Python执... 查看详情

在 Java HSQL 数据库中获取上个月的第一天

】在JavaHSQL数据库中获取上个月的第一天【英文标题】:GetfirstdayoflastmonthinJavaHSQLdatabase【发布时间】:2018-01-2311:35:48【问题描述】:如何在HSQL数据库中选择上个月的第一天和下个月的最后一天?我尝试了postgres方式如下:SELECTdat... 查看详情

显示(日历)周的第一天和最后一天

...r)week【发布时间】:2021-08-2603:11:53【问题描述】:在我的数据库中,我有一个包含连续日期的表。我将所有日期分组到日历周,并将它们显示在我的CSS的表格中。现在我想在我的表格中显示日历周的第一天和最后一天。这是我的... 查看详情

pandas通过datetimeproperties对象获取日期对象是否是所在年份的第一天(isyearstart)筛选dataframe数据中日期对象是所在年份第一天的数据行

pandas通过DatetimeProperties对象获取日期对象是否是所在年份的第一天(isyearstart)、筛选dataframe数据中日期对象是所在年份第一天的数据行目录pandas通过DatetimeProperties对象获取日期对象是否是所在年份的第一天(is 查看详情