首页 > 数据库 >进阶 Redis 技术与应用

进阶 Redis 技术与应用

时间:2024-05-08 15:59:28浏览次数:31  
标签:AOF 持久 进阶 Redis 命令 内存 应用 使用

目录

1. Redis 高级数据结构

  • 1.1.HyperLogLog
  • 1.2.Bitmaps
  • 1.3.Geospatial 数据
  • 1.4.Pub/Sub(发布/订阅)

2. Redis 事务与持久化

  • 2.1.Redis 事务简介
  • 2.2.持久化方式:RDB 和 AOF
  • 2.3.配置和管理持久化

3. Redis 高级功能

  • 3.1.分布式锁
  • 3.2.Lua 脚本
  • 3.3.客户端连接和连接池
  • 3.4.内存管理与优化

 

1. Redis 高级数据结构

 Redis作为一款强大的开源内存数据库,除了常见的数据结构(如字符串、列表、集合等)外,还提供了许多高级数据结构

1.1.HyperLogLog

1.1.1.什么是Redis HyperLogLog高级数据结构?

HyperLogLog是一种用于近似计数的数据结构,它可以在极小的内存开销下,对一个数据集的基数(不重复元素的数量)进行估算。在处理大规模数据时,HyperLogLog能够以高效的方式提供准确的估算结果,从而节省内存资源。

1.1.2.如何工作?

HyperLogLog的工作原理非常巧妙。它利用哈希函数将输入的元素映射到一个固定长度的比特数组中,并通过统计比特数组中前缀0的数量来估算元素的基数。通过这种方式,HyperLogLog能够以非常小的内存消耗来进行近似计数,适用于大规模数据集的场景。

1.1.3.HyperLogLog的基本操作

1.1.3.1.添加元素

要向HyperLogLog数据结构中添加元素,我们可以使用PFADD命令。例如,将元素"hello"添加到名为"mylog"的HyperLogLog中:

PFADD mylog hello

1.1.3.2.获取近似基数

要获取HyperLogLog数据结构的近似基数,我们可以使用PFCOUNT命令。例如,获取名为"mylog"的HyperLogLog的近似基数:

PFCOUNT mylog

1.1.3.3.合并多个HyperLogLog

要合并多个HyperLogLog数据结构,我们可以使用PFMERGE命令。例如,将名为"mylog1"和"mylog2"的两个HyperLogLog合并成一个新的HyperLogLog"mylog3":

PFMERGE mylog3 mylog1 mylog2

1.1.4.HyperLogLog的优势

  • 内存占用低:HyperLogLog能够以非常小的内存开销来进行近似计数,比传统的计数方法具有更高的内存利用率。

  • 高度可扩展:在大规模数据集的情况下,HyperLogLog能够轻松处理数十亿甚至数万亿的元素,而不会受到内存限制的影响。

  • 快速计算:由于HyperLogLog的算法简单高效,因此可以快速对大规模数据集进行近似计数,提高了数据处理的效率。

 

1.2.Bitmaps

1.2.1.什么是Redis Bitmaps高级数据结构?

Bitmaps是一种位图数据结构,它可以存储大量的二进制位,并提供了一系列位操作命令,用于对位图进行操作。在实际应用中,Bitmaps通常被用来表示某种状态或者标记,例如用户在线状态、用户签到记录等。

1.2.2.如何工作?

Bitmaps的工作原理非常简单直观。它实际上就是一个由二进制位组成的数组,每个位代表一个状态或者标记。我们可以通过位操作命令来对位图进行设置、清除、查询等操作,从而实现对数据的灵活管理。

1.2.3.Bitmaps的基本操作

1.2.3.1.设置位

要设置Bitmaps数据结构中的某一位,我们可以使用SETBIT命令。例如,设置名为"online_users"的Bitmaps中的第100号位为1:

SETBIT online_users 100 1

1.2.3.2.查询位

要查询Bitmaps数据结构中的某一位的值,我们可以使用GETBIT命令。例如,查询名为"online_users"的Bitmaps中的第100号位的值:

GETBIT online_users 100

1.2.3.3.统计位

要统计Bitmaps数据结构中值为1的位的数量,我们可以使用BITCOUNT命令。例如,统计名为"online_users"的Bitmaps中值为1的位的数量:

BITCOUNT online_users

1.2.3.4.其他位操作

除了上述基本操作外,Bitmaps还提供了一系列位操作命令,如AND、OR、XOR、NOT等,用于对多个位图进行位操作,实现复杂的逻辑运算。

1.2.4.Bitmaps的优势

  • 高效的存储和查询:Bitmaps采用紧凑的二进制位存储数据,占用极少的内存空间,并且提供了快速的位操作命令,使得存储和查询效率非常高。

  • 灵活的应用场景:Bitmaps可以用来表示各种状态或者标记,如用户在线状态、用户签到记录、文章阅读记录等,具有很高的灵活性和通用性。

  • 简单直观的操作:Bitmaps提供了简单直观的位操作命令,使得对位图进行操作变得非常简单易懂,即使对于初学者也能轻松上手。

 

1.3.Geospatial 数据

1.3.1.什么是Redis Geospatial数据?

Geospatial数据是指地理位置信息,包括经度和纬度等坐标信息。在Redis中,Geospatial数据通过使用ZSET(有序集合)数据结构来存储,其中成员是地理位置的名称或标识,而分数则是该地理位置的经纬度信息。

1.3.2.如何工作?

Redis的Geospatial数据使用了一种叫做Geohash的编码方式来表示地理位置的经纬度信息。通过将地理位置的经纬度编码成一个字符串,然后将这个字符串作为ZSET的成员,从而实现了对地理位置的快速存储和检索。

1.3.3.Geospatial数据的基本操作

1.3.3.1.添加地理位置

要向Geospatial数据结构中添加地理位置,我们可以使用GEOADD命令。例如,将经度为116.404、纬度为39.915的地理位置添加到名为"cities"的Geospatial集合中:

GEOADD cities 116.404 39.915 "Beijing"

1.3.3.2.查询地理位置

要查询地理位置的经纬度信息,我们可以使用GEOPOS命令。例如,查询名为"cities"的Geospatial集合中"Beijing"的经纬度信息:

GEOPOS cities "Beijing"

1.3.3.3.查询地理位置之间的距离

要计算两个地理位置之间的距离,我们可以使用GEODIST命令。例如,计算名为"cities"的Geospatial集合中"Beijing"和"Shanghai"之间的距离:

GEODIST cities "Beijing" "Shanghai" km

1.3.3.4.查询地理位置周围的其他地理位置

要查询某个地理位置周围的其他地理位置,我们可以使用GEORADIUS命令。例如,查询名为"cities"的Geospatial集合中距离经度116.404、纬度39.915不超过100公里的其他地理位置:

GEORADIUS cities 116.404 39.915 100 km

1.3.4.Geospatial数据的优势

  • 快速存储和检索:Geospatial数据通过ZSET数据结构存储,实现了对地理位置的快速存储和检索,使得对地理位置的操作非常高效。

  • 方便的地理位置计算:通过使用Geospatial数据,我们可以方便地进行地理位置之间的距离计算、周围地理位置的查询等操作,为地理位置相关的应用提供了便利。

  • 灵活的应用场景:Geospatial数据可以应用于很多场景,如位置服务、地图应用、附近推荐等,具有很高的通用性和灵活性。

 

1.4.Pub/Sub(发布/订阅)

1.4.1.什么是Redis Pub/Sub功能?

Pub/Sub(发布/订阅)是Redis提供的一种消息传递模式,它允许消息的发布者(发布消息)和订阅者(接收消息)之间进行异步通信。在Pub/Sub模式下,消息的发布者将消息发送到指定的频道(Channel),而订阅者则可以订阅一个或多个频道,接收并处理相应的消息。

1.4.2.如何工作?

Pub/Sub的工作原理非常简单明了。首先,消息的发布者使用PUBLISH命令将消息发送到指定的频道中。然后,订阅者使用SUBSCRIBE命令订阅感兴趣的频道,当有消息发布到被订阅的频道时,订阅者将立即收到相应的消息。这种异步通信模式非常适用于实时通知、事件驱动等场景。

1.4.3.Pub/Sub的基本操作

1.4.3.1.发布消息

要发布消息到指定的频道,我们可以使用PUBLISH命令。例如,将消息"Hello, world!"发布到名为"news"的频道中:

PUBLISH news "Hello, world!"

1.4.3.2.订阅频道

要订阅感兴趣的频道,我们可以使用SUBSCRIBE命令。例如,订阅名为"news"的频道:

SUBSCRIBE news

1.4.3.3.接收消息

订阅者在订阅了频道后,将实时接收到发布到该频道的消息。无需使用额外的命令来接收消息,Redis会自动将消息推送给订阅者。

1.4.3.4.取消订阅频道

要取消订阅某个频道,我们可以使用UNSUBSCRIBE命令。例如,取消订阅名为"news"的频道:

UNSUBSCRIBE news

1.4.4.Pub/Sub的优势

  • 实时通信:Pub/Sub模式支持实时消息传递,消息的发布者和订阅者之间可以实现快速的异步通信,适用于实时通知、事件驱动等场景。

  • 解耦合:Pub/Sub模式将消息的发布者和订阅者解耦合,使得系统中的各个组件可以独立开发、部署和维护,提高了系统的灵活性和可扩展性。

  • 多对多通信:Pub/Sub模式支持多个发布者向多个订阅者发送消息,实现了多对多的消息传递,能够满足复杂的业务需求。

 

2. Redis 事务与持久化

2.1.Redis 事务简介

Redis作为一款快速、高效的内存数据库,不仅支持基本的数据存储和读取,还提供了强大的事务功能,可以帮助我们实现原子性操作,即要么全部执行成功,要么全部不执行。今天,让我们一起来深入了解Redis事务,掌握其基本概念和使用方法。

2.1.1.什么是Redis事务?

首先,我们来解释一下什么是事务。想象一下,你去银行取钱,你要么全额取出,要么一分钱也取不到,中间没有“抠门”的可能。对吧?那么,Redis事务就是这么个意思,一组操作要么全部成功,要么全部失败,中间不允许抠脚。

Redis事务是一组命令的集合,这组命令要么全部执行,要么全部不执行,Redis会保证事务中的所有命令都是原子性的,即要么全部执行成功,要么全部失败回滚。这样可以确保数据的一致性,避免了中间状态的出现。

2.1.2.为什么需要Redis事务?

因为有些操作是需要一起完成的。比如,你要给你的朋友转账,你要么扣掉你的钱,要么给你的朋友加钱,如果中间有个操作失败了,那你就糗大了。这时候,Redis事务就派上用场了,保证所有操作一气呵成,不会半途而废。

在实际应用中,有些操作需要多个命令组合才能完成,而且需要保证这些命令一起执行,要么全部成功,要么全部失败。这时候,就可以使用Redis事务来保证这两个命令的原子性执行。

2.1.3.如何使用Redis事务?

首先,你要开启一个事务,就像开启聚会一样,嗨起来!然后,把你要做的事情都写在一个清单上,一气呵成,不要中途停下来。最后,等到一切准备就绪,就执行你的计划,一举成功!

Redis事务的使用非常简单,一般包括以下几个步骤:

  1. 使用MULTI命令开始一个事务。
  2. 在事务块中依次执行需要执行的命令。
  3. 使用EXEC命令触发事务执行,Redis会将事务中的所有命令一起执行。
  4. 如果需要取消事务,可以使用DISCARD命令取消事务。

2.1.4.事务的特点和注意事项

  • 事务中的所有命令都是原子性的,要么全部执行成功,要么全部失败回滚。
  • Redis事务不支持回滚操作,即使事务中的某个命令执行失败,后续命令仍然会被执行。
  • 事务中的命令不会立即执行,而是在执行EXEC命令时才会执行。

2.1.5.事务的应用场景

  • 批量操作:事务可以将多个命令打包成一个原子操作,用于实现批量读写操作。
  • 原子性操作:事务中的所有命令都是原子性的,可以确保多个命令的一致性和完整性。
  • 乐观锁:通过使用WATCH命令监视键,在事务执行前检查键是否被修改,从而实现乐观锁机制。

 

2.2.持久化方式:RDB 和 AOF

Redis作为一款内存数据库,它的数据默认是存储在内存中的,但是一旦服务器重启或者断电,内存中的数据就会丢失。为了解决这个问题,Redis提供了持久化机制,可以将数据保存到硬盘上,保证数据的持久性。今天我们就来详细了解一下Redis的两种主要持久化方式:RDB和AOF。

2.2.1.RDB(Redis DataBase)持久化方式

RDB持久化方式是将Redis的数据以快照的形式周期性地保存到硬盘上,形成一个时间点的数据快照。具体来说,当满足一定条件(比如规定的时间间隔内,有一定数量的写操作)时,Redis会fork出一个子进程,将当前内存中的数据写入到一个临时文件中,待写入完成后,再替换原来的RDB文件。

RDB的优点在于:

  • 适用于大规模的数据恢复,因为数据以快照的形式保存,恢复速度较快。
  • RDB文件较小,占用空间较少。

但是,RDB也有一些缺点:

  • 如果出现宕机情况,可能会丢失一部分数据,因为RDB是定期保存的,并非实时保存。
  • RDB需要fork一个子进程来进行持久化操作,可能会影响服务器的性能。

2.2.2.AOF(Append Only File)持久化方式

AOF持久化方式是将Redis的写操作以追加的方式保存到一个文件中,这个文件就是AOF文件。Redis在执行写操作时,会将命令追加到AOF文件的末尾,以此来记录数据库状态的变化。AOF文件中记录的是所有的写操作命令,通过重新执行这些命令,可以完全恢复数据。

AOF的优点在于:

  • 数据的持久化是实时的,每一次写操作都会立即被记录到AOF文件中,不会丢失数据。
  • AOF文件是一个文本文件,易于阅读和理解。

但是,AOF也有一些缺点:

  • AOF文件相比RDB文件更大,占用磁盘空间较多。
  • AOF文件的恢复速度较慢,因为需要逐条执行文件中的命令。

2.2.3.如何选择持久化方式?

在实际应用中,我们可以根据自己的需求来选择合适的持久化方式:

  • 如果对数据的实时性要求较高,可以选择AOF持久化方式。
  • 如果对数据的恢复速度要求较高,可以选择RDB持久化方式。
  • 也可以同时开启RDB和AOF持久化方式,以实现数据的双重保护。

持久化是保证Redis数据持久性的重要手段,通过选择合适的持久化方式,可以保证数据的安全和可靠性。

 

2.3.配置和管理持久化

2.3.1.配置持久化方式

Redis提供了两种主要的持久化方式:RDB和AOF。那么,我们该如何配置持久化方式呢?

RDB持久化方式

  • 在Redis配置文件(redis.conf)中,找到并修改save选项,设置自动触发RDB持久化的条件,比如在一段时间内有一定数量的写操作。
  • 可以通过设置stop-writes-on-bgsave-error选项来决定是否在RDB持久化过程中出现错误时停止写操作。

AOF持久化方式

  • 在Redis配置文件中,将appendonly选项设置为yes,即可开启AOF持久化功能。
  • 可以通过设置appendfsync选项来控制AOF文件何时进行同步写入硬盘,有三种选项可供选择:always(每次写操作都进行同步写入)、everysec(每秒进行一次同步写入,默认选项)、no(由操作系统决定何时进行同步写入)。

2.3.2.管理持久化

除了配置持久化方式,我们还需要了解如何管理持久化:

手动触发持久化

  • 你可以在Redis命令行中执行相应的命令来手动触发持久化操作,比如SAVE命令触发RDB持久化、BGSAVE命令触发后台RDB持久化、BGREWRITEAOF命令触发AOF重写操作。

监控持久化过程

  • 你可以通过监控Redis的日志文件来了解持久化过程是否正常进行,同时可以借助第三方监控工具来实时监控持久化的状态和性能指标。

 

3. Redis 高级功能

3.1.分布式锁

3.1.1.什么是分布式锁?

首先,了解一下什么是分布式锁。在分布式系统中,多个节点同时访问共享资源时,为了避免数据混乱和冲突,我们需要一种机制来保证同一时刻只有一个节点能够访问资源,这就是分布式锁。

3.1.2.Redis中的分布式锁实现

Redis提供了一种简单而有效的分布式锁实现方式,即使用SETNX(SET if Not eXists)命令。具体实现如下:

  1. 使用SETNX命令设置一个特定的键作为锁,值为某个唯一标识符,表示锁的持有者。

  2. 如果SETNX命令返回1,表示锁设置成功,持有者为当前客户端,即获取到了锁;如果返回0,表示锁已经被其他客户端持有,获取锁失败。

  3. 当客户端需要释放锁时,可以使用DEL命令删除对应的键,释放锁。

3.1.3.分布式锁的问题与解决方案

虽然Redis的分布式锁实现非常简单,但也存在一些问题,比如死锁、锁过期等。为了解决这些问题,我们可以采取以下方案:

  1. 设置锁的过期时间:使用SET命令时,同时设置一个合理的过期时间,防止锁长时间被占用。

  2. 使用锁续约:在获取到锁之后,定期更新锁的过期时间,确保持有锁的客户端意外宕机时,锁可以自动释放。

  3. 采用阻塞式获取锁:使用Redis的BLPOP、BRPOP等命令,当获取锁失败时,进行阻塞等待,直到获取到锁为止。

3.1.4.Redis中的分布式锁实现

Redis提供了一种简单而有效的分布式锁实现方式,即使用SETNX(SET if Not eXists)命令。下面我们来看一下具体的实现过程:

package main

import (
    "fmt"
    "time"

    "github.com/go-redis/redis/v8"
)

var ctx = context.Background()

func main() {
    // 连接Redis服务器
    rdb := redis.NewClient(&redis.Options{
        Addr:     "localhost:6379",
        Password: "", // no password set
        DB:       0,  // use default DB
    })

    // 定义获取分布式锁的函数
    acquireLock := func(lockName string, acquireTimeout time.Duration) bool {
        // 设置锁的过期时间,防止死锁
        lockTimeout := 10 * time.Second
        endTime := time.Now().Add(acquireTimeout)
        for time.Now().Before(endTime) {
            // 尝试获取锁
            setNX := rdb.SetNX(ctx, lockName, "locked", lockTimeout)
            if setNX.Val() {
                // 设置锁的过期时间
                rdb.Expire(ctx, lockName, lockTimeout)
                return true
            }
            // 等待一段时间后重试
            time.Sleep(100 * time.Millisecond)
        }
        return false
    }

    // 定义释放分布式锁的函数
    releaseLock := func(lockName string) {
        rdb.Del(ctx, lockName)
    }

    // 使用分布式锁
    if acquireLock("my_lock", 10*time.Second) {
        defer releaseLock("my_lock")
        // 执行需要加锁的操作
        fmt.Println("成功获取到分布式锁,进行操作...")
        time.Sleep(5 * time.Second) // 模拟执行一些操作
        fmt.Println("成功释放分布式锁")
    } else {
        fmt.Println("获取分布式锁失败,可能有其他进程正在使用锁")
    }
}

 

3.2.Lua 脚本

3.2.1.什么是Lua脚本?

Lua是一种轻量级的脚本语言,被广泛应用于嵌入式系统和游戏开发领域。在Redis中,Lua脚本可以通过EVALEVALSHA命令执行,允许用户在Redis服务器端执行自定义的Lua脚本。

3.2.2.为什么要使用Lua脚本?

那么,为什么我们要使用Lua脚本呢?Lua脚本在Redis中有以下几个优势:

  1. 原子性操作:Lua脚本可以保证在执行期间不被其他命令中断,从而保证了原子性操作,避免了竞态条件的发生。

  2. 减少网络开销:将多个命令打包成Lua脚本一次性执行,可以减少网络往返开销,提高性能。

  3. 复杂逻辑支持:Lua脚本可以执行复杂的逻辑操作,包括条件判断、循环等,使得Redis能够处理更多种类的业务需求。

3.2.3.如何在Redis中使用Lua脚本?

接下来,我将向大家展示如何在Redis中使用Lua脚本来实现一个简单的计数器功能。我们将使用Lua脚本来实现原子性的递增操作。

-- 定义Lua脚本
local key = KEYS[1]
local current = tonumber(redis.call('GET', key) or "0")
local step = tonumber(ARGV[1] or "1")
local result = current + step
redis.call('SET', key, result)
return result

在这个Lua脚本中,我们首先获取了传入的键(key)和递增步长(step),然后通过GET命令获取当前值,对其进行递增操作,并使用SET命令更新键的值,最后返回递增后的结果。

 

3.3.客户端连接和连接池

3.3.1.什么是客户端连接?

在与Redis进行通信时,我们需要建立客户端与Redis服务器之间的连接,以便发送命令和接收响应。这个连接就是客户端连接。

3.3.2.为什么需要连接池?

每次执行Redis命令时都创建新的连接是非常低效的,因为连接的建立和销毁都会消耗资源。而连接池的作用就是在程序初始化时创建一定数量的连接,并在需要时从池中获取连接,使用完毕后再将连接归还给池,以减少连接的频繁创建和销毁,提高性能。

3.3.3.如何使用连接池?

接下来,我将向大家展示如何在不同的编程语言中使用连接池来连接Redis。

Go语言中,可以使用go-redis库来连接Redis并使用连接池。以下是一个简单的示例:

package main

import (
    "fmt"

    "github.com/go-redis/redis/v8"
)

func main() {
    // 创建连接池
    options := &redis.Options{
        Addr:     "localhost:6379",
        Password: "", // no password set
        DB:       0,  // use default DB
        PoolSize: 10, // 设置连接池大小
    }
    // 创建Redis客户端
    rdb := redis.NewClient(options)

    // 使用连接池执行Redis命令
    err := rdb.Set(ctx, "foo", "bar", 0).Err()
    if err != nil {
        panic(err)
    }
    val, err := rdb.Get(ctx, "foo").Result()
    if err != nil {
        panic(err)
    }
    fmt.Println("foo:", val)
}

 

3.4.内存管理与优化

3.4.1.内存管理策略

Redis采用了多种策略来管理内存,主要包括以下几点:

  1. 数据结构优化:选择合适的数据结构来存储数据,如使用哈希表来存储键值对数据,使用有序集合来存储有序数据等。

  2. 过期策略:通过设置键的过期时间,自动删除不再需要的数据,释放内存空间。

  3. 内存淘汰策略:当内存不足时,根据一定的策略删除一些数据以释放内存,常见的淘汰策略包括LRU(最近最少使用)、LFU(最少使用频率)等。

3.4.2.内存优化技巧

除了Redis自身的内存管理策略外,我们还可以通过一些优化技巧来进一步提升Redis的内存利用率和性能:

  1. 合并小键值对:将多个小键值对合并成一个大键值对,减少键的数量,降低内存开销。

  2. 使用压缩:对于存储的大量文本数据,可以考虑使用压缩算法,如Gzip或LZF等,减少内存占用。

  3. 限制数据大小:设置合理的数据大小限制,防止数据过大导致内存溢出。

  4. 定期清理无用数据:定期清理无用数据和过期数据,释放内存空间。

3.4.3.实际操作示例

下面是一个简单的Redis内存优化示例,我们将通过合并小键值对来减少内存占用:

package main

import (
    "context"
    "fmt"

    "github.com/go-redis/redis/v8"
)

func main() {
    // 连接Redis服务器
    rdb := redis.NewClient(&redis.Options{
        Addr:     "localhost:6379",
        Password: "", // no password set
        DB:       0,  // use default DB
    })

    // 设置小键值对
    _, err := rdb.MSet(ctx, "key1", "value1", "key2", "value2", "key3", "value3").Result()
    if err != nil {
        panic(err)
    }

    // 删除原来的小键值对
    _, err = rdb.Del(ctx, "key1", "key2", "key3").Result()
    if err != nil {
        panic(err)
    }

    fmt.Println("合并小键值对完成")
}

 

 

   

标签:AOF,持久,进阶,Redis,命令,内存,应用,使用
From: https://www.cnblogs.com/hxjcore/p/18145808

相关文章

  • BOSHIDA AC/DC电源模块在医疗设备领域的应用探讨
    BOSHIDAAC/DC电源模块在医疗设备领域的应用探讨AC/DC电源模块是一种将交流电转换为直流电的设备,广泛应用于各种电子设备中。在医疗设备领域,AC/DC电源模块的应用具有重要意义。本文将探讨AC/DC电源模块在医疗设备中的应用,并分析其优势和挑战。 首先,AC/DC电源模块在医疗设备中......
  • (一)Linux CentOS Redis 安装
    1、获取源//redis-stable是最新稳定版wgethttps://download.redis.io/redis-stable.tar.gz2、解压编译//我指定目录/apptar-xzvfredis-stable.tar.gz-C/appcd/app/redis-stablemake&&makeinstall3、修改配置启动//设置后台运行daemonizeno改成yes//运行......
  • 2. redis VM监控脚本
    可以根据实际情况进行修改#!/bin/bash#redis机器资源监控#--------#邮件配置:#curl-o/etc/yum.repos.d/CentOS-Base.repohttps://mirrors.aliyun.com/repo/Centos-7.repo#yum-yinstallsendmailmailx#vim/etc/mail.rc#setfrom=alerts@etocrm.com#setsmtp=smtp.ex......
  • Redis 学习笔记
    1.redis基本数据结构Redis基础数据结构包括:字符串(String) 简单动态字符串列表(List)     压缩列表快速链表集合(Set)    整型数组字典哈希表有序集合(SortedSet,或称为ZSet)压缩列表跳表哈希(Hash)压缩列表字典哈希表位图(Bitm......
  • 【视频监控】视频汇聚平台EasyCVR能力分析及应用分析
    一、方案背景安防视频监控技术是通过各种监控设备捕捉实时画面,并将其传输到监控中心或数据存储设备的技术。随着科技的发展,监控视频技术已经得到了不断的改进与创新,并在各种领域得到了广泛的应用。但是当前视频监控的发展也面临着以下问题:1)不同单位在视频平台建设中以所属领域......
  • redisearch 安装和使用
    方式一:源码编译安装(未成功)能找到的文档基本都是这一套,但是编译过程中会遇到各种坑,make版本,其他依赖问题,尝试解决无果。#--recursive选项递归下载子模块依赖gitclone--recursivehttps://github.com/RediSearch/RediSearch.gitmakesetupmakebuild#在redis.conf最后......
  • AI智能分析视频监控系统现状与应用场景浅析
    随着人工智能技术的快速发展,智能视频监控系统在安全监管工作中发挥着越来越重要的作用,为企业的安全生产管理提供了强有力的支持,也为企业在安全生产管理上大大提高了安全指数。那么目前安防视频分析的现状与应用场景有哪些呢?一、行业现状当前,智能视频分析技术通过利用计算机视觉......
  • 浅谈AI智能分析与视频流媒体能力下的自然灾害预防监测应用
    一、方案背景夏季是灾害多发季节,山洪、泥石流、洪涝、冰雹、飓风、地震等自然灾害每年都给国家经济带来巨大的损失。随着人工智能(AI)和视频流媒体技术的发展,这些技术在自然灾害预防和监测方面的应用正在变得越来越广泛和重要。AI智能分析技术能够处理复杂的数据,并且能够帮助人们......
  • 河南大学大礼堂火灾事故引发安防监控对智能分析技术应用的思考
    一、方案背景2024年5月2日,在修缮施工期间的河南大学河南留学欧美预备学校旧址大礼堂发生火情。现场航拍画面显示,大礼堂经过火灾,房顶已经基本坍塌,被火烧过的建筑呈焦黑状。公开资料显示,大礼堂属河南留学欧美预备学校旧址,2006年,河南留学欧美预备学校旧址被国务院公布为第六批全国......
  • DevTutor 一款旨在帮助开发者使用 SwiftUI 创建出色应用程序的应用
    提供可复制的代码示例和相应的用户界面预览,以简化您的编码过程。此外,还包括了《Swift编程语言》官方中英文文档的本地离线预览。主要功能■提供可直接在您的项目中使用的样本代码■实时查看您的代码如何影响应用的外观■提供官方中英文Swift编程语言离线文档■探索第......