Docker Portainer使用

Portainer是什么

Docker Portainer是一个轻量级的 Web UI 管理界面,可以用来管理Docker环境。它提供了一个直观的控制台,用户可以通过它来管理Docker主机、容器、网络、卷等Docker资源。

Portainer的主要功能和特点包括:

  1. 容器管理:可以查看、启动、停止、删除容器,以及查看容器日志和统计信息。

  2. 镜像管理:可以查看、创建、部署镜像,以及查看镜像层级信息。

  3. 网络管理:可以查看、创建、删除网络。

  4. 卷管理:可以查看、创建、删除数据卷。

  5. 访问控制:支持基于用户和团队的访问控制。

  6. 监控和分析:提供容器、镜像、网络等的监控和分析功能。

  7. 服务编排:支持通过可视化界面编排Docker Compose应用。

  8. 多主机管理:可以管理部署在多个Docker主机上的资源。

总的来说, Portainer 是一个非常好用的 Docker 管理工具,能够大大简化Docker环境的管理和运维工作。对于不熟悉命令行的用户来说,Portainer 提供了一个友好的图形化界面,可以更方便地管理Docker资源。

Portainer的官方网站地址是

https://www.portainer.io/

安装Portainer

注意,最新的v26版本的Docker,在安装protainer后会有些许问题,比如进入容器控制台页面会出错,这里建议降低版本,比如docker25.0.5版本

1.下载汉化

下载地址如下,linux下载tar.gz文件

https://github.com/eysp/public/releases/tag/public

上传到linux服务器的目录中,并解压:

[root@localhost portainer]# tar -xzf public-public.tar.gz 
[root@localhost portainer]# 

解压后多了一个public-punlic的文件夹:

image-20240520203938289

2.拉取并运行

使用下面的命令安装portainer,如果本地没有会自动拉取镜像

docker run -d -p 8000:8000 -p 9000:9000 --name portainer --restart=always 
-v /var/run/docker.sock:/var/run/docker.sock 
-v portainer_data:/data 
-v /wzy/portainer/public-public:/public 
portainer/portainer-ce
  • docker run: 这个命令用于启动一个新的 Docker 容器。
  • -d: 这个参数指定容器以 “detached” 模式运行,也就是在后台运行。
  • -p 8000:8000 -p 9000:9000: 这个参数将容器的 8000 和 9000 端口映射到宿主机的对应端口上,这样我们就可以通过宿主机访问容器内的服务。
  • --name portainer: 给这个容器起名为 “portainer”。
  • --restart=always: 这个参数指定只要 Docker 启动,这个容器就自动重启。
  • -v /var/run/docker.sock:/var/run/docker.sock: 这个参数将宿主机的 Docker 套接字文件挂载到容器内部,这样 Portainer 就可以管理宿主机上的 Docker 服务。
  • -v portainer_data:/data: 这个参数创建了一个名为 “portainer_data” 的数据卷,并挂载到容器的 /data 目录。这样可以保存 Portainer 的配置和数据。
  • -v /wzy/portainer/public-public:/public :将解压的汉化包目录挂载到Portainer容器的/public目录。
  • portainer/portainer-ce: 这是 Portainer 的 Docker 镜像名称,告诉 Docker 使用这个镜像来创建容器。

注意,docker portainer有两个版本:portainer/portainerportainer/portainer-ce:

  • portainer/portainer是早期版本,已不再更新
  • portainer/portainer-ce是新版本,使用新版本

运行

[root@localhost ~]# docker run -d -p 8000:8000 -p 9000:9000 --name portainer --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data -v /wzy/portainer/public-public:/public portainer/portainer-ce
Unable to find image 'portainer/portainer:latest' locally
latest: Pulling from portainer/portainer
94cfa856b2b1: Pull complete 
49d59ee0881a: Pull complete 
a2300fd28637: Pull complete 
Digest: sha256:fb45b43738646048a0a0cc74fcee2865b69efde857e710126084ee5de9be0f3f
Status: Downloaded newer image for portainer/portainer:latest
32d9f2b4d36f04a0984afbc2171a5e26876d39dd8429906760e2b92c3e31ac16

docker ps查看运行的容器

[root@localhost ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND        CREATED          STATUS          PORTS                                                                                  NAMES
32d9f2b4d36f   portainer/portainer   "/portainer"   20 seconds ago   Up 18 seconds   0.0.0.0:8000->8000/tcp, :::8000->8000/tcp, 0.0.0.0:9000->9000/tcp, :::9000->9000/tcp   portainer

3.验证登录

登录管理界面

使用ip:9000即可,这里的192.168.0.106是我的虚拟机,初次登陆时需要设置一个admin账号的密码,在admin下方输入8位密码创建用户,输入密码后点击创建用户即可 (下方的允许匿名我也勾选上了):

image-20240521200202612

在下一步环境中选择本地连接即可:

image-20240521200342483

然后会进入如下界面:

image-20240521200416014

点击local进入查看容器详情:

image-20240521200450961

image-20240521200510697

上面页面展示的对应如下命令

[root@localhost ~]# docker system df
TYPE            TOTAL     ACTIVE    SIZE      RECLAIMABLE
Images          3         3         901MB     0B (0%)
Containers      3         3         141B      0B (0%)
Local Volumes   1         1         69.07kB   0B (0%)
Build Cache     0         0         0B        0B
[root@localhost ~]# 



界面操作

1.启动

启动已停止的mysql容器,勾选后点击启动:

image-20240520212942325

可以看到由红色的stop变为绿色的running:

image-20240520213015635

去虚拟机查看

[root@localhost ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                   CREATED          STATUS              PORTS                                                                                  NAMES
32d9f2b4d36f   portainer/portainer   "/portainer"              17 minutes ago   Up 17 minutes       0.0.0.0:8000->8000/tcp, :::8000->8000/tcp, 0.0.0.0:9000->9000/tcp, :::9000->9000/tcp   portainer
2d9e86240ee2   mysql:latest          "docker-entrypoint.s…"   47 hours ago     Up About a minute   0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp                                   wzy-mysql-1

2.查看日志

点击文档标志:

image-20240520213231412

会进入如下页面,可以设置日志显示的行数并下载:

image-20240520213309386

3.查看容器的详细信息

点击如下的圆圈i图标:

image-20240520213644449

进入如下页面,展示容器的配置参数等:

image-20240520213733339

4.查看监控信息

点击统计图标:

image-20240520213521591

进入如下界面,显示各项占用:

image-20240520213437561

5.执行容器命令

点击如下的大于号下划线图标:

image-20240521200716245

在如下页面点击连接:

image-20240521200810363

进入命令执行页面:

image-20240521200839592

6.添加新容器

点击添加容器按钮

image-20240522191437656

进入如下页面填写相关参数,这里以安装nginx为例,然后点击部署容器:

我这里80端口被占用,使用了81,可以用lsof -i :80查看linux 80端口是否被占用

image-20240522192242942

如果想做其他更多设置可以在高级设置中进行,这里就不做设置了:

image-20240522191830962

如果不报错,结果如下:

image-20240522192317305

访问

image-20240522192551450



编排方式安装监控

1.编排配置

Docker-Compose的使用参考:

https://blog.csdn.net/onePlus5T/article/details/139103477

结合本专栏前面的文章Docker-Compose的使用,利用之前的微服务,然后把portainer相关放在了最下面

services:
  #自定义的服务名,必须小写
  eureka7001:
  #指定dockerfile来构建镜像并运行实例,context用来指定Dockerfile所在的目录
    build:
      context: /wzy/cloud-images/eureka
      dockerfile: Dockerfile
    #image: eureka_docker:1.0 #如果有现成的镜像,可以在这里指定,直接用来运行容器,使用此项要注释掉build及其内容
    #container_name: eureka01 指定容器的名字,如果不指定,会由docker自动生成
    ports:
      - "7001:7001"
    #挂载容器卷  
    volumes:
      - /wzy/eurekaService:/data 
    #指定使用的网络,所有服务的网络一致,即可以使用服务名通信忽略ip地址  
    networks:
      - wzy_net
  
  #自定义的服务名,必须小写
  payment8001:
    build:
      context: /wzy/cloud-images/pay8001
      dockerfile: Dockerfile  
    #image: payment01_docker:1.0
    #container_name: payment01
    ports:
      - "8001:8001"
    volumes:
      - /wzy/paymentMysqlService:/data 
    networks:
      - wzy_net
     #指定本服务依赖的服务,会等依赖的服务运行后在运行本服务 
    depends_on:
      - eureka7001	
      - mysql    
      
  #自定义的服务名,必须小写    
  payment8002:
    build:
      context: /wzy/cloud-images/pay8002
      dockerfile: Dockerfile  
    #image: payment02_docker:1.0
    #container_name: payment02
    ports:
      - "8002:8002"
    volumes:
      - /wzy/paymentRedisService:/data 
    networks:
      - wzy_net
    depends_on:
      - eureka7001
      - redis  
      
  #自定义的服务名,必须小写,也可以叫别的,springboot服务可以在yaml中将redis的ip换成这个名字    
  redis:
    image: redis:6.2.6
    ports:
      - "6379:6379"
    volumes:
      - /wzy/redis/redis.conf:/etc/redis/redis.conf
      - /wzy/redis/data:/data 
    networks:
      - wzy_net
    #运行指令  
    command: redis-server /etc/redis/redis.conf   
  
  #自定义的服务名,必须小写,也可以叫别的,springboot服务可以在yaml中将redis的ip换成这个名字     
  mysql:
    image: mysql:latest
    #环境参数配置
    environment:
      #注意这里的密码要和微服务连接mysql的配置对应上
      MYSQL_ROOT_PASSWORD: '123456'
      MYSQL_ALLOW_EMPTY_PASSWORD: 'NO'
      MYSQL_DATABASE: 'mybatis-plus'
      MYSQL_USER: 'wzy'
      MYSQL_PASSWORD: '123456'
    ports:
      - "3306:3306"
    volumes: 
      - /wzy/mysql/log:/var/log/mysql
      - /wzy/mysql/data:/var/lib/mysql
      - /wzy/mysql/conf:/etc/mysql/conf.d
    networks:
      - wzy_net
    command: --default-authentication-plugin=mysql_native_password #解决外部无法访问
    
  #portainer监控服务
  portainer:
    image: portainer/portainer-ce
    ports:
      - 8000:8000
      - 9000:9000
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock #挂载 Docker 套接字,以便 Portainer 可以管理 Docker 容器
      - portainer_data:/data  # 数据创建持久化存储卷
      - /wzy/portainer/public-public:/public
    restart: always  #确保 Portainer 容器在 Docker 主机重启后自动启动
    networks:
      - wzy_net	 
      
#定义 portainer_data 持久化存储卷。
volumes:
  portainer_data:      

#创建网络
networks:
  wzy_net:    

2.运行编排

运行编排文件检查命令:docker-compose config -q,无输出则证明yml格式正确。

再执行编排:docker-compose -f /wzy/docker-compose.yml up -d

[root@localhost wzy]# docker-compose config -q
[root@localhost wzy]# docker-compose -f /wzy/docker-compose.yml up -d
[+] Running 4/4
 ✔ portainer Pulled                                                              20.2s 
   ✔ 0ea73420e2bb Pull complete                                                   0.8s 
   ✔ c367f59be2e1 Pull complete                                                   0.8s 
   ✔ b71b88d796e2 Pull complete                                                  18.9s 
[+] Building 103.5s (20/20) FINISHED                                    docker:default
 => [eureka7001 internal] load build definition from Dockerfile                   0.1s
 => => transferring dockerfile: 579B                                              0.0s
 => [payment8002 internal] load metadata for docker.io/library/java:8            16.3s
 => [eureka7001 internal] load .dockerignore                                      0.0s
 => => transferring context: 2B                                                   0.0s
 => [eureka7001 internal] load build context                                      0.7s
 => => transferring context: 48.86MB                                              0.7s
 => CACHED [payment8002 1/3] FROM docker.io/library/java:8@sha256:c1ff613e8ba25  77.1s
 => => resolve docker.io/library/java:8@sha256:c1ff613e8ba25833d2e1940da0940c382  0.0s
 => => sha256:d23bdf5b1b1b1afce5f1d0fd33e7ed8afbc084b594b9ccf742 4.73kB / 4.73kB  0.0s
 => => sha256:5040bd2983909aa8896b9932438c3f1479d25ae837a5f622 51.36MB / 51.36MB  5.5s
 => => sha256:76610ec20bf5892e24cebd4153c7668284aa1d1151b7c3b 42.50MB / 42.50MB  11.0s
 => => sha256:c1ff613e8ba25833d2e1940da0940c3824f03f802c449f3d18 2.00kB / 2.00kB  0.0s
 => => sha256:fce5728aad85a763fe3c419db16885eb6f7a670a42824ea6 18.54MB / 18.54MB  9.3s
 => => sha256:60170fec2151d2108ed1420625c51138434ba4e0223d30 593.15kB / 593.15kB  6.4s
 => => extracting sha256:5040bd2983909aa8896b9932438c3f1479d25ae837a5f6220242a2  13.4s
 => => sha256:e98f73de8f0d2ef292f58b004d67bc6e9ee779dcfaff7ebb396464 214B / 214B  6.7s
 => => sha256:11f7af24ed9cf47597dd6cf9963bb3e9109c963f0135e869a9e9b4 242B / 242B  7.1s
 => => sha256:49e2d6393f32abb1de7c9395c04c822ceb2287383d5a9 130.10MB / 130.10MB  22.3s
 => => sha256:bb9cdec9c7f337940f7d872274353b66e118412cbfd433 289.05kB / 289.05kB  9.8s
 => => extracting sha256:fce5728aad85a763fe3c419db16885eb6f7a670a42824ea618414b8  2.8s
 => => extracting sha256:76610ec20bf5892e24cebd4153c7668284aa1d1151b7c3b0c7d50c  18.9s
 => => extracting sha256:60170fec2151d2108ed1420625c51138434ba4e0223d3023353d3f3  0.4s
 => => extracting sha256:e98f73de8f0d2ef292f58b004d67bc6e9ee779dcfaff7ebb3964649  0.0s
 => => extracting sha256:11f7af24ed9cf47597dd6cf9963bb3e9109c963f0135e869a9e9b49  0.0s
 => => extracting sha256:49e2d6393f32abb1de7c9395c04c822ceb2287383d5a90998f7bd8  34.1s
 => => extracting sha256:bb9cdec9c7f337940f7d872274353b66e118412cbfd433c711361bc  0.1s
 => [eureka7001 2/3] ADD cloud-eureka-server-1.0-SNAPSHOT.jar wzy_eureka.jar      1.1s
 => [eureka7001 3/3] RUN bash -c 'touch /wzy_eureka.jar'                          1.2s
 => [eureka7001] exporting to image                                               0.2s
 => => exporting layers                                                           0.2s
 => => writing image sha256:131a3a890a4752e6ee52f37241e34d93e8a7452e68612d1768ec  0.0s
 => => naming to docker.io/library/wzy-eureka7001                                 0.0s
 => [payment8002 internal] load build definition from Dockerfile                  0.0s
 => => transferring dockerfile: 606B                                              0.0s
 => [payment8001 internal] load build definition from Dockerfile                  0.0s
 => => transferring dockerfile: 606B                                              0.0s
 => [payment8001 internal] load .dockerignore                                     0.0s
 => => transferring context: 2B                                                   0.0s
 => [payment8002 internal] load .dockerignore                                     0.1s
 => => transferring context: 2B                                                   0.0s
 => [payment8001 internal] load build context                                     1.3s
 => => transferring context: 66.18MB                                              1.2s
 => [payment8002 internal] load build context                                     1.1s
 => => transferring context: 60.94MB                                              1.0s
 => [payment8002 2/3] ADD cloud-provider-payment8002-1.0-SNAPSHOT.jar wzy_paymen  2.0s
 => [payment8001 2/3] ADD cloud-provider-payment8001-1.0-SNAPSHOT.jar wzy_paymen  1.9s
 => [payment8002 3/3] RUN bash -c 'touch /wzy_payment8002.jar'                    3.5s
 => [payment8001 3/3] RUN bash -c 'touch /wzy_payment8001.jar'                    3.5s
 => [payment8001] exporting to image                                              0.3s
 => => exporting layers                                                           0.3s
 => => writing image sha256:231e68f5fc55027ea54ec28db5e2aff53804494641dfe8160ec3  0.0s
 => => naming to docker.io/library/wzy-payment8001                                0.0s
 => [payment8002] exporting to image                                              0.3s
 => => exporting layers                                                           0.3s
 => => writing image sha256:13313f5be823f61526bb2b53b7b019545783f52e8d8cdda4bc43  0.0s
 => => naming to docker.io/library/wzy-payment8002                                0.0s
[+] Running 6/8
 ✔ Network wzy_wzy_net          Created                                           1.0s 
 ✔ Volume "wzy_portainer_data"  Created                                           0.0s 
 ✔ Container wzy-portainer-1    Started                                           1.6s 
 ✔ Container wzy-eureka7001-1   Started                                           1.3s 
 ✔ Container wzy-mysql-1        Started                                           1.3s 
 ✔ Container wzy-redis-1        Started                                           1.1s 
 ✔ Container wzy-payment8002-1  Started                                           0.9s 
 ✔ Container wzy-payment8001-1  Started                                           0.9s 

如上即为成功,然后访问portainer,看到所有容器均已启动运行:

image-20240521203757962

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot中使用AOP实现日志记录功能

目录 一、SpringBoot框架介绍 二、什么是 AOP 三、日志记录的必要性 四、SpringBoot中如何使用AOP实现日志记录功能 一、SpringBoot框架介绍 SpringBoot是一个开源的Java开发框架,旨在简化基于Spring框架的应用程序的开发。它提供了一套开箱即用的工具&#xf…

WebGL的医学培训软件开发

开发基于WebGL的医学培训软件是一项复杂且技术性强的任务,需要结合医学专业知识和计算机图形学技术。以下是详细的开发流程和关键步骤。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。 1.需求分析与定义 目标用户&#xf…

【C语言】——函数栈帧的创建与销毁

函数栈帧的创建与销毁 本文主要讲解了函数调用过程中其栈帧的创建与销毁,内容干货较多,希望大家认真品味。 使用C语言进行函数调用时,是否会有很多疑问: 1.局部变量是如何创建的? 2.局部变量在未初始化的情况下&#x…

从ES5迈向ES6:探索 JavaScript 新增声明命令与解构赋值的魅力

个人主页:学习前端的小z 个人专栏:JavaScript 精粹 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结,欢迎大家在评论区交流讨论! ES5、ES6介绍 文章目录 💯声明命令 let、const🍟1 let声明符&a…

代码生成器(一)---项目概述以及项目初始化

目录 一、项目概述 1.代码生成器解决的问题 2.代码生成器的实际应用 3.本地代码生成器的业务流程 4.实现思路 二、项目初始化 项目Gitee地址:Code-Generator: 代码生成器!!! 一、项目概述 1.代码生成器解决的问题 代码生成器本…

使用vue和element_ui搭建后端页面

使用vue和element_ui搭建后台管理页面 效果顶部和左侧内容固定&#xff0c;中间内容滚动 <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"&g…

地理信息系统(GIS)软件开发

地理信息系统&#xff08;GIS&#xff09;软件开发是一项复杂且系统性很强的工程&#xff0c;涉及空间数据的采集、管理、分析和展示。以下是一个典型的GIS软件开发流程&#xff0c;包括各个步骤的详细说明。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#…

2024电工杯B题食谱评价与优化模型思路代码论文分析

2024年电工杯数学建模竞赛B题论文和代码已完成&#xff0c;代码为B题全部问题的代码&#xff0c;论文包括摘要、问题重述、问题分析、模型假设、符号说明、模型的建立和求解&#xff08;问题1模型的建立和求解、问题2模型的建立和求解、问题3模型的建立和求解&#xff09;、模型…

【STL专题】深入探索C++之std::string:不止于字符串【万字详解】

欢迎来到CILMY23的博客 &#x1f3c6;本篇主题为&#xff1a;深入探索C之std::string&#xff1a;不止于字符串 &#x1f3c6;个人主页&#xff1a;CILMY23-CSDN博客 &#x1f3c6;系列专栏&#xff1a;Python | C | C语言 | 数据结构与算法 | 贪心算法 | Linux &#x1f3…

Nginx - 一键实现Nginx的快速安装和优化配置

文章目录 思路实现二次优化 思路 初始化下载工具目录并下载依赖&#xff1a; 创建临时目录 /tmp/tools。下载 OpenSSL、PCRE 和 Zlib 的压缩包。解压这些依赖包到指定目录。 设置NGINX的用户和脚本&#xff1a; 添加 nginx 用户。创建目录和启动、停止、重载NGINX的脚本。 安装…

如何异地组网添加摄像机?

本文将介绍如何使用天联技术实现异地组网添加摄像机&#xff0c;并保障数据的安全性。 安防摄像机的应用愈发广泛&#xff0c;无论是家庭安防还是企业监控&#xff0c;摄像机都扮演着重要角色。在一些特殊场合或者特殊需求下&#xff0c;我们需要将摄像机添加到异地网络中进行监…

Web开发——HTMLCSS

1、概述 Web开发分前端开发和后端开发&#xff0c;前端开发负责展示数据&#xff0c;后端开发负责处理数据。 HTML&CSS是浏览器数据展示相关的内容。 1&#xff09;网页的组成部分 文字、图片、音频、视频、超链接、表格等等 2&#xff09;网页背后的本质 程序员写的前端…

神经网络基础结构

1. 神经网络 在神经网络中&#xff0c;每个神经元都有一个与之关联的权重和偏置&#xff0c;它们用于计算神经元的输出值。神经元接收来自上一层神经元的输入&#xff0c;并将这些输入与权重相乘并加上偏置&#xff0c;然后通过激活函数进行非线性处理&#xff0c;最终产生输出…

Qt案例练习(有源码)

项目源码和资源&#xff1a;Qt案例练习: qt各种小案例练习,有完整资源和完整代码 1.案例1 项目需求&#xff1a;中间为文本框&#xff0c;当点击上面的复选框和单选按钮时&#xff0c;文本框内的文本会进行相应的变化。 代码如下&#xff1a; #include "dialog.h" …

【全开源】智能名片系统源码(Fastadmin+ThinkPHP和Uniapp)

数字时代的新名片&#xff0c;连接未来的桥梁 引言 在数字化浪潮的推动下&#xff0c;传统名片已经逐渐淡出人们的视线。取而代之的是智能名片系统&#xff0c;它以其高效、便捷和智能化的特点&#xff0c;成为了商务交流的新宠。而智能名片系统源码&#xff0c;作为其核心驱…

nextcloud 安装部署

php版本不对 ubuntu nginx 配置php 网站-CSDN博客 抄自chatgpt ubuntu完全卸载干净某个包-CSDN博客 以及设置基本的php nginx环境参照上面两篇博文 然后参照官方文档 Example installation on Ubuntu 22.04 LTS — Nextcloud latest Administration Manual latest document…

datasheet芯片数据手册—新手入门学习(二)【8-18】

参考芯片手册已经上传&#xff0c;可自行下载 因为芯片参考手册内容比较多&#xff0c;故再一次介绍本文内容主要讲解章节。 目录 8、内容介绍 命令真值表 9、Command Definitions 10、READ Operations &#xff08;1&#xff09;页面读取操作 &#xff08;2&#xff…

Docker 开启 SSL 验证

最近看 OJ 项目的远程开发阶段&#xff0c;然后踩坑踩了 2 天&#x1f602; Docker 版本&#xff1a;在 CentOS 安装 sudo yum install docker-ce-20.10.9 docker-ce-cli-20.10.9 containerd.io Client: Docker Engine - CommunityVersion: 20.10.9API version: …

1673. 找出最具竞争力的子序列

题目 给定一个整数数组 nums 和一个正整数 k&#xff0c;返回长度为 k 且最具竞争力的 nums 子序列。 数组的子序列是从数组中删除一些元素&#xff08;可能不删除元素&#xff09;得到的序列。 在子序列 a 和子序列 b 第一个不相同的位置上&#xff0c;如果 a 中的数字小于…

Redis系统架构中各个处理模块是干什么的?no.19

Redis 系统架构 通过前面的学习&#xff0c;相信你已经掌握了 Redis 的原理、数据类型及访问协议等内容。本课时&#xff0c;我将进一步分析 Redis 的系统架构&#xff0c;重点讲解 Redis 系统架构的事件处理机制、数据管理、功能扩展、系统扩展等内容。 事件处理机制 Redis…