热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

redisset不可重复_Redis的使用

1.Redis的概念Redis运行过程,也就是读写过程都是基于内存实现的keyvalue存储,对比与memcached而言,会基于异步方式

1.Redis的概念

  • Redis运行过程,也就是读写过程都是基于内存实现的key/value存储,对比与memcached而言,会基于异步方式(快照)同步到文件系统,实现数据 的持久性存储,单一进程响应用户的所有的请求,具有主从架构 ;
  • Redis支持存储的value类型有很多,包括string(字符串)、list(链表)、set(集合)、zset(有序集合)和hash(哈希类型);

2.Windows系统下安装Redis

安装地址:https://github.com/MicrosoftArchive/redis/releases

29f349ed29da464da193e6f186ddc150.png

redis连接

r = redis.Redis(host='127.0.0.1', port=6379)host是redis主机,需要redis服务端和客户端都启动 redis默认端口是6379;

3.Linux系统下安装Redis:

安装命令行yum install -y redis启动Redissystemctl start redis.service连接方式一redis-cli -h 192.168.23.10 -p 6379连接方式二redis-cli -h 192.168.23.10 -p 6379 -a 123456选择数据库由于在配置文件中默认定义使用16个database,因此每次登入Redis时,可以选择使用哪个数据库select 0:表示使用0号数据库select 1:表示使用1号数据库清空数据库flushdb :清空当前数据库flushall :清空所有的库

4.Redis中的命令和命令组

  • 命令组与命令的联系:一个命令组中包含多个命令,可以使用 help @命令组,查看某个命令组中有多少命令,以及这些命令如何使用,如

help @stringhelp @server

  • 查看特定命令的用法

help LLENhelp STRLEN;

5.Redis常用命令

set key value [EX seconds] [PX milliseconds] [NX|XX]

  • set robby ops:赋值; 、
  • get robby:取值;
  • EX:表示超时时长;
  • NX:如果一个键不存在则创建,存在不创建;
  • XX:如果一个键存在则创建,不存在不创建;
  • exists robby:判断一个键值是否存在, 如果存在返回整数类型1 ,否则返回0;
  • append robby "值":追加值;
  • 删除键;

del key [key.....]del robby

  • 设置一个整数值,让数值增加

set number 1

incr number (加1)

decr number (减1)

6.Redis中的5种数据类型

  • 字符串string:字符串类型是Redis中最为基础的数据存储类型,是一个由字节组成的序列,他在Redis中是二进制安全的,这便意味着该类型可以接 受任何格式的数据,如JPEG图像数据货Json对象描述信息等,是标准的key-value,一般来存字符串,整数和浮点数;
  • 列表list:Redis的列表允许用户从序列的两端推入或者弹出元素,列表由多个字符串值组成的有序可重复的序列,是链表结构,所以向列表两端添加 元素的时间复杂度为0(1),获取越接近两端的元素速度就越快;
  • 集合set:Redis的集合是无序不可重复的,和列表一样,在执行插入和删除和判断是否存在某元素时,效率是很高的,集合最大的优势在于可以进行 交集并集差集操作;
  • 有序集合sorted set:类似set,都是字符串的集合,都不允许重复的成员出现在一个set中,他们之间差别在于有序集合中每一个元素都会有一个 score与之关联,这个score可用于排序和排名;
  • 散列hash:Redis中的散列可以看成具有String key和String value的map容器,可以将多个key-value存储到一个key中,每一个Hash可以存储 4294967295个键值对;

7.Redis 事务

  • Redis 事务可以一次执行多个命令,多个操作要么一次性执行完毕,要么都不执行;
  • 一个事务从开始到执行会经历三个阶段:开始事务、命令入队、执行事务;

# 使用multi开启一个事务multi (开启一个事务日志)set name yhyset age 25set address changshaexec (提交,执行)

8.什么是Redis持久化

  • Redis支持RDB和AOF两种持久化机制,持久化功能有效地避免因进程退出造成的数据丢失问题,下次重启时利用之前持久化的文件即可实现数据恢 复;
  • RDB持久化方式会在一个特定的间隔保存那个时间点的一个数据快照;
  • AOF持久化方式则会记录每一个服务器收到的写操作;
  • Redis的持久化是可以禁用的,就是说你可以让数据的生命周期只存在于服务器的运行时间里;
  • 两种方式的持久化是可以同时存在的,但是当Redis重启时,AOF文件会被优先用于重建数据;

9.Redis的sentinel机制

### 启动systemctlsystemctl start redis-sentinel.service### 登入Sentinel,查看主从状态redis-cli -p 26379127.0.0.1:26379> info Sentinelsentinel_masters:1sentinel_tilt:0sentinel_running_scripts:0sentinel_scripts_queue_length:0sentinel_simulate_failure_flags:0master0:name=mymaster,status=ok,address=192.168.23.10:6379,slaves=2,sentinels=1### 停止Redis的master节点,登入sentinel查看节点信息systemctl stop redis.service[root@7 ~] # redis-cli -p 26379 127.0.0.1:26379> info sentinel sentinel_masters:1sentinel_tilt:0sentinel_running_scripts:0sentinel_scripts_queue_length:0sentinel_simulate_failure_flags:0master0:name=mymaster,status=ok,address=192.168.23.12:6379,slaves=2,sentinels=1127.0.0.1:26379> sentinel masters

  • 万一主节点打击,主从模型将会停止工作,为了解决这个问题,Redis提供了一个sentinel(哨兵),以此来实现主从切换的功能,一旦主节点宕机了 ,sentinel将会在从节点中挑一个作为主节点, 与zookeeper类似;
  • Redis-Sentinel是Redis官方推荐的高可用性(HA)解决方案;

它的主要功能有以下几点:

监控:Sentinel不断的检查master和slave是否正常的运行;

通知:如果发现某个redis节点运行出现问题,可以通过API通知系统管理员和其他的应用程序;

自动故障转移:能够进行自动切换,当一个master节点不可用时,能够选举出master的多个slave中的一个来作为新的master,其它的slave节点会 将它所追随的master的地址改为被提升为master的slave的新地址;

配置提供者:哨兵作为Redis客户端发现的权威来源:客户端连接到哨兵请求当前可靠的master的地址,如果发生故障,哨兵将报告新地址;

参考:https://www.9xkd.com/user/plan-view.html?id=1487078743



推荐阅读
  • 在Kubernetes上部署JupyterHub的步骤和实验依赖
    本文介绍了在Kubernetes上部署JupyterHub的步骤和实验所需的依赖,包括安装Docker和K8s,使用kubeadm进行安装,以及更新下载的镜像等。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • EPICS Archiver Appliance存储waveform记录的尝试及资源需求分析
    本文介绍了EPICS Archiver Appliance存储waveform记录的尝试过程,并分析了其所需的资源容量。通过解决错误提示和调整内存大小,成功存储了波形数据。然后,讨论了储存环逐束团信号的意义,以及通过记录多圈的束团信号进行参数分析的可能性。波形数据的存储需求巨大,每天需要近250G,一年需要90T。然而,储存环逐束团信号具有重要意义,可以揭示出每个束团的纵向振荡频率和模式。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • 本文介绍了三种方法来实现在Win7系统中显示桌面的快捷方式,包括使用任务栏快速启动栏、运行命令和自己创建快捷方式的方法。具体操作步骤详细说明,并提供了保存图标的路径,方便以后使用。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • 本文介绍了在Windows系统下安装Mongodb的详细步骤和注意事项。包括下载Mongodb官方文档、选择64位安装包、配置环境变量、命令行启动Mongodb等。通过本文的指导,用户可以轻松完成Mongodb的安装并进行相关操作。 ... [详细]
author-avatar
嗳__霞骸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有