Redis入门第一步:认识Redis与快速安装配置

news2025/1/23 3:26:38

认识Redis与快速安装配置🍃

Redis是什么🐲

1.Redis的背景🎍

       Redis(Remote Dictionary Server)译为"远程字典服务",它是一款基于内存实现的键值型 NoSQL 数据库, 通常也被称为数据结构服务器,这是因为它可以存储多种数据类型,比如 string(字符串),hash(哈希散列),list(列表),set(集合)和 sorted set(有序集合)等

        Redis 是由意大利人 Salvatore Sanfilippo 使用 C语言编写,它遵守 BSD 开源协议,并且对多种编程语言提供了良好的 API 支持,比如 Java,C/C++,C#,PHP,JavaScript,Perl,Python,Ruby 等

        Redis是常见的内存型数据库,除 Redis 之外,还有 Oracle Berkeley DB(甲骨文旗下的一款产品)、SQlite(轻量级内存数据库)、Memcache(键值型分布式缓存数据库)、Altibase(基于内存的高性能数据库)

2.Redis的特点🎍

与其他内存型数据库相比,Redis 具有以下特点:

  • Redis 不仅可以将数据完全保存在内存中,还可以通过磁盘实现数据的持久存储;

  • Redis 支持丰富的数据类型,包括 string、list、set、zset、hash 等多种数据类型,因此它也被称为"数据结构服务器";

  • Redis 支持主从同步,即 master-slave 主从复制模式。数据可以从主服务器向任意数量的从服务器上同步,有效地保证数据的安全性;

  • Redis 支持多种编程语言,包括 C、C++、Python、Java、PHP、Ruby、Lua 等语言

       与 SQL 型数据库截然不同,Redis 没有提供新建数据库的操作,因为它自带了 16 (0—15)个数据库(默认使用 0 库)。在同一个库中,key 是唯一存在的、不允许重复的,它就像一把密钥,只能打开一把。键值存储的本质就是使用 key 来标识 value,当想要检索 value 时,必须使用与 value 相对应的 key 进行查找

       Redis 数据库没有的概念,它通过不同的数据类型来实现存储数据的需求,不同的数据类型能够适应不同的应用场景,从而满足开发者的需求

3.Redis的架构🎍

Redis体系架构主要分为两个部分:

  • Redis服务端

  • Redis客户端

客户端和服务端可以位于同一台计算机上,也可以位于不同的计算机上。服务端是整个架构的"大脑",能够把数据存储到内存中,并且起到管理数据的作用

4.Redis的优劣势🎍

下面对 Redis 的优势进行了简单总结:

  • 性能极高:Redis 基于内存实现数据存储,它的读取速度是 110000次/s,写速度是 81000次/s;

  • 多用途工具: Redis 有很多的用途,比如可以用作缓存、消息队列、搭建 Redis 集群等;

  • 命令提示功能:Redis 客户端拥有强大的命令提示功能,使用起来非常的方便,降低了学习门槛;

  • 可移植性:Redis 使用用标准 C语言编写的,能够在大多数操作系统上运行,比如 Linux,Mac,Solaris 等

  • 数据结构丰富:除了支持string类型的value外还支持hash,set,zset,list等数据结构

  • 支持主从复制:主机会自动将数据同步到从机,可以进行读写分离

下面对 Redis 的劣势进行了简单总结:

  • 数据库容量受到物理内存的限制,不能用作海量数据的高性能读写,因此Redis适合的场景主要局限在较小数据量的高性能操作和运算上

  • Redis 不具备自动容错和恢复功能,主机从机的宕机都会导致前端部分读写请求失败,需要等待机器重启或者手动切换前端的IP才能恢复

  • 主机宕机,宕机前有部分数据未能及时同步到从机,切换IP后还会引入数据不一致的问题,降低了系统的可用性

  • Redis 较难支持在线扩容,在集群容量达到上限时在线扩容会变得很复杂。为避免这一问题,运维人员在系统上线时必须确保有足够的空间,这对资源造成了很大的浪费

5.Redis的应用场景🎍

        Redis 用来缓存一些经常被访问的热点数据、或者需要耗费大量资源的内容,通过把这些内容放到 Redis 中,可以让应用程序快速地读取它们。例如,网站的首页需要经常被访问,并且在创建首页的过程中会消耗的较多的资源,此时就可以使用 Redis 将整个首页缓存起来,从而降低网站的压力,减少页面访问的延迟时间。

        我们知道,数据库的存储方式大体可分为两大类,基于磁盘存储和基于内存存储。磁盘存储的数据库,因为磁头机械运动以及系统调用等因素导致读写效率较低。Redis 基于内存来实现数据存取,相对于磁盘来说,其读写速度要高出好几个数量级。下表将 Redis 数据库与其他常用数据库做了简单对比:

名称类型数据存储选项附加功能
Redis基于内存存储的键值非关系型数据库字符串、列表、散列、有序集合、无序集合发布与订阅、主从复制、持久化存储等
Memcached基于内存存储的键值缓存型数据库键值之间的映射为提升性能构建了多线程服务器
MySQL基于磁盘的关系型数据库每个数据库可以包含多个表,每个表可以包含多条记录; 支持第三方扩展。支持 ACID 性质、主从复制和主主复制
MongoDB基于磁盘存储的非关系文档型数据库每个数据库可以包含多个集合,每个集合可以插入多个文档支持聚合操作、主从复制、分片和空间索引

       Redis 基于内存来实现数据的存储,因此其速度非常快。但是我们知道,计算机的内存是非常珍贵的资源,所以 Redis 不适合存储较大的文件或者二进制数据,否则会出现错误,Redis 适合存储较小的文本信息。理论上 Redis 的每个 key、value 的大小不超过 512 MB

6.Redis为什么这么快🎍
  1. 完全基于内存,绝大部分请求是纯粹的内存操作,非常迅速。数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的事件复杂度都是O(I)

  2. 数据结构简单,对数据的操作也简单,Redis中的数据结构是专门进行设计的

  3. 采用单线程,避免了不必要的上下文切换和竞争条件,也不存在多进程或者多线程导致的切换而消耗CPU,不用去考虑各种锁的问题,不存在加锁释放锁操作,没有出现死锁而导致的性能消耗的情况

  4. 使用多路I/O复用模型,非阻塞IO

  5. 使用的底层模型不同,它们之间底层实现方式以及与客户端之间通信的应用协议不一样,Redis直接自己构建了VM机制,因为一般的系统调用系统函数的话,会浪费一定的时间去请求

Redis的安装搭建🐲

1.Windows操作系统的安装搭建🐙

Redis 官方网站没有提供 Windows 版的安装包,但可以通过 GitHub 来下载 Windows 版 Redis 安装包

下载地址:https://github.com/tporadowski/redis/releases

注意:Windows 安装包是某位民间“大神”根据 Redis 源码改造的,并非 Redis 官方网站提供

下载完成后,打开相应的文件夹,您会看到如下图所示的文件目录:

创建Redis临时服务

1) 启动服务端程序

如上图所示,双击 Redis 服务端启动程序 redis-server.exe,您会看到以下界面:

上图中显示一些 Redis 的相关信息,比如 Redis 的版本号以及默认端口号(6379)。注意,为了实现后续操作,请您保持服务端开启状态,否则客户端无法正常工作

2) 启动客户端程序

启动服务端后,双击客户端启动程序 redis-cli.exe,得到如下界面:

得到如上界面,说明 Redis 本地客户端与服务端连接成功

命令创建Redis服务

上述方式虽然简单快捷,但是显然不是程序员的操作,下面介绍,通过命令启动 Redis 服务端,并将 Redis 服务添加到 Windows 资源管理器,实现开机后自动启动。

1) 注册Redis服务

通过 CMD 命令行工具进入 Redis 安装目录,将 Redis 服务注册到 Windows 服务中,执行以下命令:

# redis-server.exe --service-install redis.windows.conf --loglevel verbose

执行完后,得到以下输出,说明注册成功。

[1868] 07 Jan 15:00:08.223 # Granting read/write access to 'NT AUTHORITY\NetworkService' on: "D:\Redis-x64-5.0.10" "D:\Redis-x64-5.0.10\"
[1868] 07 Jan 15:00:08.230 # Redis successfully installed as a service.

2) 启动Redis服务

执行以下命令启动 Redis 服务,命令如下:

# redis-server --service-start

如下图所示:

注意:此时 Redis 已经被添加到 Windows 服务中,因此不会再显示 Redis 服务端的相应的信息,如下图所示:

3) 启动Redis客户端

在 CMD 命令行输出 redis-cli 命令启动客户端,如下所示:

4) 检查是否连接成功

测试客户端和服务端是否成功连接。输出PING命令,若返回PONG则证明成功连接。如下所示:

通过上面的操作,我们完成了 Redis 的安装。当然,您也可以将 Redis 加入到环境变量中,如下所示:

注意:根据自己的安装路径添加环境变量。

总结

下面对安装过程中涉及到的命令进行总结,主要包括以下命令:

安装服务:redis-server --service-install 
卸载服务:redis-server --service-uninstall 
开启服务:redis-server --service-start 
停止服务:redis-server --service-stop 
服务端启动时重命名:redis-server --service-start --service-name Redis1
2.Linux操作系统的安装搭建🐙
Yum源方式安装
[root@localhost ~]# yum -y install update  # 更新yum源
[root@localhost ~]# yum -y install redis.x86_64 # 下载redis
[root@localhost ~]# redis-server # 启动redis服务端
[root@localhost ~]# ps aux | grep redis | grep -v "grep" # 查看redis的进程
 
`Redis客户端启动语法:
#若设置了密码,使用如下格式启动
# redis-cli -h [ip] -p [port] -a [password] 
#简单格式
# redis-cli
[root@localhost ~]# redis-cli
127.0.0.1:6379> ping  # 验证是否成功安装
PONG
127.0.0.1:6379> 

源码方式安装
[root@localhost ~]# wget https://download.redis.io/releases/redis-5.0.14.tar.gz
[root@localhost ~]# tar xvzf redis-5.0.14.tar.gz
[root@localhost ~]# cd redis-5.0.14/
[root@localhost redis-5.0.14]# make && make install
[root@localhost redis-5.0.14]# cd
[root@localhost ~]#sed -i 's/daemonize no/daemonize yes/g' redis.conf # 开启后台模式将on改为yes
[root@localhost ~]# redis-server &  #放入后台执行
[root@localhost ~]# redis-cli
redis> set name www.biancheng.net
OK
127.0.0.1:6379> get name
"www.baidu.com"
 
[root@localhost ~]# mv redis-5.0.14 /usr/bin/redis
[root@localhost ~]# cd /usr/bin/redis/
[root@localhost redis]# mkdir -p /data/log/redis # 创建日志文件的存放路径
[root@localhost redis]# mkdir -p /data/redis/  # 本地数据库存放持久化数据的目录
`修改配置文件
[root@localhost redis]# sed -i 's/logfile ""/logfile \/data\/log\/redis\/redis.log/g' redis.conf   # 定义log文件
[root@localhost redis]# cat redis.conf | grep logfile
logfile /data/log/redis/redis.log
# 修改登录redis密码
[root@localhost redis]# sed -i 's/# requirepass foobared/requirepass redis/g' redis.conf 
# 定义本地数据库存放持久化数据的目录
[root@localhost redis]# sed -i 's/dir .\//dir \/data\/redis\//g' redis.conf

Redis配置文件🐲

`配置文件名称
Windows--->redis.windows.conf
Linux  --->redis.conf
1.查看配置项
`使用 Redis 的CONFIG命令来查看或者更改 Redis 的配置信息.语法格式如下:
127.0.0.1:6379> CONFIG GET 配置名称
​
eg:
# 获取日志等级的配置项
127.0.0.1:6379> CONFIG GET loglevel 
# 查看所有的配置项
127.0.0.1:6379> CONFIG GET *

2.更改配置项
`如果想要重新设置配置项,语法格式为:
127.0.0.1:6379> CONFIG SET 配置项名称 配置项参数值
​
eg:
127.0.0.1:6379> CONFIG SET loglevel "notice"
OK
127.0.0.1:6379> CONFIG GET loglevel
1) "loglevel"
2) "notice"

扩展: Redis的日志等级为:

1.debug:会打印出很多信息,适用于开发和测试阶段

2.verbose:包含很多不太常用的信息,但是比debug简短

3.notice:适用于生产场景

4.warning:警告信息

3.配置项说明
配置项参数说明
daemonizeno/yes默认为 no,表示 Redis 不是以守护进程的方式运行,通过修改为 yes 启用守护进程
pidfile文件路径当 Redis 以守护进程方式运行时,会把进程 pid 写入自定义的文件中
port6379指定 Redis 监听端口,默认端口为 6379
bind127.0.0.1绑定的主机地址
timeout0客户端闲置多长秒后关闭连接,若指定为 0 ,表示不启用该功能
loglevelnotice指定日志记录级别,支持四个级别:debug、verbose、notice、warning,默认为 notice
logfilestdout日志记录方式,默认为标准输出
databases16设置数据库的数量(0-15个)共16个,Redis 默认选择的是 0 库,可以使用 SELECT 命令来选择使用哪个数据库储存数据
save[seconds] [changes]可以同时配置三种模式: save 900 1 save 300 10 save 60 10000表示在规定的时间内,执行了规定次数的写入或修改操作,Redis 就会将数据同步到指定的磁盘文件中。比如 900s 内做了一次更改,Redis 就会自动执行数据同步
rdbcompressionyes/no当数据存储至本地数据库时是否要压缩数据,默认为 yes
dbfilenamedump.rdb指定本地存储数据库的文件名,默认为 dump.rdb
dir./指定本地数据库存放目录
slaveof <masterip> <masterport>主从复制配置选项当本机为 slave 服务时,设置 master 服务的 IP 地址及端口,在 Redis 启动时,它会自动与 master 主机进行数据同步。
requirepassfoobared 默认关闭密码配置项,默认关闭,用于设置 Redis 连接密码。如果配置了连接密码,客户端连接 Redis 时需要通过<password> 密码认证。
maxmemory <bytes>最大内存限制配置项指定 Redis 最大内存限制,Redis 在启动时会把数据加载到内存中,达到最大内存后,Redis 会尝试清除已到期或即将到期的 Key,当此方法处理 后,若仍然到达最大内存设置,将无法再进行写入操作,但可以进行读取操作。
appendfilenameappendonly.aof指定 AOF 持久化时保存数据的文件名,默认为 appendonly.aof。
glueoutputbufyes设置向客户端应答时,是否把较小的包合并为一个包发送,默认开启状态

4.常见配置案例
  1. NETWORK网络

    bind 127.0.0.1  #绑定的 IP
    protected-mode no   #保护模式
    port 6379   #端口设置
  2. GENERAL通用

    daemonize yes # 以守护进程的方式运行,默认是no
    pidfile /var/run/redis_6379.pid # 如果是后台启动,需要指定pid文件
    ​
    # 日志级别
    # debug(调试日志,大量的信息)
    # verbose(许多不太有用的信息,但是不是debug级别)
    # notice(适度信息,可能是您在生产中想要的)
    # warning(警告信息)
    ​
    loglevel notice
    logfile ""  # 日志文件的位置
    databases 16 # 数据库的数量,默认是 16
    always-show-logo yes  # 是否总是显示 LOG

  3. SNAPSHOTTING快照

    # 持久化,在规定的时间内,执行了多少次操作则会持久化到磁盘
    # Redis是内存数据库,如果没有持久化,那么数据断电即丢失
    ​
    ……
    # 如果 900s 内,至少有 1 个 key 进行了修改,进行持久化操作
    save 900 1
    # 如果 300s 内,至少有10个key进行了修改,进行持久化操作
    save 300 10
    save 60 10000
    ​
    stop-writes-on-bgsave-error yes # 如果持久化出错,是否还要继续工作
    rdbcompression yes # 是否压缩rdb文件,需要消耗一些cpu资源
    rdbchecksum yes # 保存rdb文件的时候,进行错误的检查校验
    dir ./ # rdb文件保存的目录

  4. SECURITY 安全

    `可以设置Redis密码,默认是没有密码
    [root@localhost ~]# redis-cli
    127.0.0.1:6379> ping
    PONG
    127.0.0.1:6379> config get requirepass  # 获取 redis 密码
    1) "requirepass"
    2) ""
    127.0.0.1:6379> config set requirepass "123456"  # 设置 redis 密码
    OK
    127.0.0.1:6379> ping
    (error) NOAUTH Authentication required.  # 发现所有的命令都没有权限了
    127.0.0.1:6379> auth 123456   # 使用密码登录
    OK
    127.0.0.1:6379> config get requirepass
    1) "requirepass"
    2) "123456"
    127.0.0.1:6379> 
  5. CLUENTS 限制

    # maxclients 10000 设置能连接上redis的最大客户端数量
    # maxmemory <bytes> redis设置最大的内存容量
    maxmemory-policy noeviction # 内存达到上限之后的处理策略
        - noeviction:当内存使用达到阈值的时候,所有引起申请内存的命令会报错
        - allkeys-lru:在所有键中采用lru算法删除键,直到腾出足够内存为止
        - volatile-lru:在设置了过期时间的键中采用lru算法删除键,直到腾出足够内存为止
        - allkeys-random:在所有键中采用随机删除键,直到腾出足够内存为止
        - volatile-random:在设置了过期时间的键中随机删除键,直到腾出足够内存为止
        - volatile-ttl:在设置了过期时间的键空间中,具有更早过期时间的key优先移除
  6. APPEND ONLY 模式 AOF 配置

    appendonly no  # 默认是不开启 AOF 模式的,默认使用 rdb 方式持久化,大部分情况下,rdb 完全够用
    ​
    appendfilename "appendonly.aof"  # 持久化的文件的名字
    # appendfsync always  # 每次修改都会 sync 消耗性能
    appendfsync everysec  # 每秒执行一次 sync 可能会丢失这 1s 的数据。
    # appendfsync no      # 不执行 sync 这个时候操作系统自己同步数据,速度最快

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2182114.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

An End-to-End Local Attention Based Model for Table Recognition(ICDAR 2023)

An End-to-End Local Attention Based Model for Table Recognition(ICDAR 2023) 一.前述 作者认为基于Transformer的表格识别模型很难处理大表格的识别&#xff0c;原因是受限于它的全局注意力global attention机制。 基于以上&#xff0c;作者提出了一种局部注意力local a…

【HTML并不简单】笔记1-常用rel总结:nofollow、noopener、opener、noreferrer,relList

文章目录 rel"nofollow"rel"noopener"与rel"opener"rel"noreferrer"relList对象 《HTML并不简单&#xff1a;Web前端开发精进秘籍》张鑫旭&#xff0c;一些摘要&#xff1a; HTML&#xff0c;这门语言的知识体系非常庞杂&#xff0c;涉…

Windows开发工具使用技巧全面指南

目录 目录 Visual Studio 功能概述 使用技巧 快捷键表 Visual Studio Code 功能概述 常用扩展 使用技巧 PowerShell 功能概述 常用命令 脚本编写技巧 Git for Windows 功能概述 集成技巧 常用命令表 调试工具 Visual Studio调试器 使用技巧 WinDbg 使用技…

828华为云征文|部署音乐流媒体服务器 mStream

828华为云征文&#xff5c;部署音乐流媒体服务器 mStream 一、Flexus云服务器X实例介绍二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置2.4 Docker 环境搭建 三、Flexus云服务器X实例部署 mStream3.1 mStream 介绍3.2 mStream 部署3.3 mStream 使用 四、…

UE4完整教程 UE4简介 UE4学习攻略及文件格式

开头附上工作招聘面试必备问题噢~~包括综合面试题、无领导小组面试题资源文件免费!全文干货。 UE4简介学习攻略UE4Demo代码面试内容资源-CSDN文库https://download.csdn.net/download/m0_72216164/89825102 工作招聘无领导小组面试全攻略最常见面试题(第一部分)共有17章+可…

PCL 点云模型滤波(圆形)

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.1.1 生成点云数据 2.1.2 模型滤波函数 2.1.3 可视化函数 2.2完整代码 三、实现效果 PCL点云算法汇总及实战案例汇总的目录地址链接&#xff1a; PCL点云算法与项目实战案例汇总&#xf…

「JavaScript深入」彻底理解JS中的闭包

JavaScript深入 — 闭包 一、概念二、示例三、实用的闭包四、用闭包模拟私有方法五、一个常见错误&#xff1a;在循环中创建闭包&#x1f330; 另一个经典例子-定时器与闭包 六、优劣好处坏处解决 七、图解闭包八、应用 &#x1f4aa;封装私有变量函数工厂异步操作中的回调函数…

css中背景色、背景图的使用

1、同时使用背景色、背景图片 参考链接&#xff1a;链接 以下样式&#xff0c;背景色在图片下方(缺点&#xff1a;图片不透明时&#xff0c;背景色会被完全遮挡。) .header {height: 100%;width: 100%;background-color: #000;background-image: url(/static/images/back.pn…

云原生之运维监控实践-使用Prometheus与Grafana实现对MySQL和Redis服务的监测

背景 如果你要为应用程序构建规范或用户故事&#xff0c;那么务必先把应用程序每个组件的监控指标考虑进来&#xff0c;千万不要等到项目结束或部署之前再做这件事情。——《Prometheus监控实战》 去年写了一篇在Docker环境下部署若依微服务ruoyi-cloud项目的文章&#xff0c;当…

数据结构之手搓顺序表(顺序表的增删查改)

目录 文章目录 前言 一、什么是顺序表&#xff1f; 二、动态顺序表的实现 1.头文件定义 2.实现顺序表的初始化 3.检查顺序表空间容量是否足够&#xff0c;不够就增容 4.顺序表的销毁 5.顺序表的打印 6.顺序表的尾插 7.顺序表的头插 8.顺序表的头删 9.顺序表的尾删 10.顺序…

LeetCode题练习与总结:二叉树的所有路径--257

一、题目描述 给你一个二叉树的根节点 root &#xff0c;按 任意顺序 &#xff0c;返回所有从根节点到叶子节点的路径。 叶子节点 是指没有子节点的节点。 示例 1&#xff1a; 输入&#xff1a;root [1,2,3,null,5] 输出&#xff1a;["1->2->5","1->…

RabbitMQ基本原理

一、基本结构 所有中间件技术都是基于 TCP/IP 协议基础之上进行构建新的协议规范&#xff0c;RabbitMQ遵循的是AMQP协议&#xff08;Advanced Message Queuing Protocol - 高级消息队列协议&#xff09;。 生产者发送消息流程&#xff1a; 1、生产者和Broker建立TCP连接&#…

国庆同欢,祖国昌盛!肌肉纤维启发,水凝胶如何重构聚合物

在这个国庆佳节&#xff0c;我们共同感受祖国的繁荣昌盛&#xff0c;同时也迎来了知识的探索之旅。今天来了解聚合物架构的重构的研究——《Hydrogel‐Reactive‐Microenvironment Powering Reconfiguration of Polymer Architectures》发表于《Advanced Science》。材料科学不…

【数据结构与算法】算法和算法分析

文章目录 一.算法1.定义2.描述 二.算法与程序三.算法特性四.算法效率的度量4.1算法时间事前分析法算法时间复杂度的渐进表示法分析算法时间复杂度的基本方法 4.2算法空间 数据的逻辑结构映像到内存就是数据的存储结构&#xff0c;针对数据的逻辑结构可以选择多种存储结构。数据…

Kotlin:2.0.0 的新特性

一、概述 kotlin 2.0.0版本英文官方文档 The Kotlin 2.0.0 release is out and the new Kotlin K2 compiler is Stable! Additionally, here are some other highlights: Kotlin 2.0.0发布了&#xff0c;新的Kotlin K2编译器已经稳定了。此外&#xff0c;以下是其他一些亮点: …

Linux操作系统中dubbo

1、简介 dubbo框架是做微服务通信的&#xff0c;是由阿里巴巴开发&#xff0c;后捐赠给阿帕奇基金会。 2、与OpenFeign的区别 dubbo是采用RPC协议实现微服务通信&#xff0c;OpenFeign是采用Http请求的方式实现的。 OpenFeign 最简单的&#xff0c;就是Spring公司开发的&am…

TinyAP:使用TinyML对抗Wi-Fi攻击的智能接入点

论文标题&#xff1a; 英文&#xff1a;TinyAP: An intelligent Access Point to combat Wi-Fi attacks using TinyML中文&#xff1a;TinyAP&#xff1a;使用TinyML对抗Wi-Fi攻击的智能接入点 作者信息&#xff1a; Anand Agrawal 和 Rajib Ranjan Maiti&#xff0c;来自印…

C语言常用标准库 -- 5.<time.h>

目录 引言 5. C标准库--time.h 5.1 简介 5.2 常量与宏 5.3 库变量 5.4 库宏 5.5 库函数 5.6 注意事项 &#x1f308;你好呀&#xff01;我是 程序猿 &#x1f30c; 2024感谢你的陪伴与支持 ~ &#x1f680; 欢迎一起踏上探险之旅&#xff0c;挖掘无限可能&#xff0c;…

线程池面试集

目录 线程池中提交一个任务的流程是怎样的? 线程池有五种状态 如何优雅的停止一个线程? 线程池的核心线程数、最大线程数该如何设置? 如何理解Java并发中的可见性、原子性、有序性? Java死锁如何避免? 线程池中提交一个任务的流程是怎样的? 线程池有五种状态 如何优…

【docker学习】Linux系统离线方式安装docker环境方法

centos7-linux安装docker(离线方式) 下载docker的安装文件 https://download.docker.com/linux/static/stable/x86_64/ 下载的是&#xff1a;docker-18.06.3-ce.tgz 这个压缩文件 将docker-18.06.3-ce.tgz文件上传到centos7-linux系统上&#xff0c;用ftp工具上传即可 解压…