当前位置: 首页 > news >正文

使用Spring Boot设计对象存储系统

对象存储系统是一种以对象为存储单位的存储架构,适合存储大量非结构化数据,如图片、音视频文件、文档等。MinIO是一个高性能的对象存储系统,基于开源和云原生的设计理念。本文将讨论如何使用Spring Boot设计一个类似MinIO的对象存储系统。

目录

  1. 引言
  2. 对象存储系统概述
  3. 系统需求分析
  4. 系统架构设计
  5. 核心功能模块设计
    1. 身份验证与授权
    2. 对象存储与检索
    3. 元数据管理
    4. 存储策略与数据分片
    5. 数据一致性与容错
  6. Spring Boot实现方案
    1. 身份验证与授权
    2. 对象存储与检索
    3. 元数据管理
    4. 存储策略与数据分片
    5. 数据一致性与容错
  7. 性能优化与扩展
  8. 安全性设计
  9. 部署与运维
  10. 结论

1. 引言

在大数据和云计算的时代,对象存储系统因其高扩展性、低成本和高可靠性,广泛应用于各类存储需求中。使用Spring Boot设计一个对象存储系统,可以充分利用Spring生态系统的优势,快速构建和部署高性能的存储服务。

2. 对象存储系统概述

对象存储系统将数据作为对象进行存储,每个对象包含数据本身、元数据和唯一标识符。对象存储系统具有如下特点:

  • 高扩展性:能够水平扩展以处理大量数据。
  • 高可靠性:通过冗余和分布式存储确保数据的安全。
  • 灵活性:支持各种类型的非结构化数据存储。

对象存储系统通常用于以下场景:

  • 静态文件存储:如图片、视频、音频等多媒体文件。
  • 备份和归档:存储大量需要长期保存的数据。
  • 大数据分析:存储大数据分析的原始数据和结果数据。
  • 内容分发网络(CDN):作为CDN的源站,存储需要分发的内容。

3. 系统需求分析

在设计一个类似MinIO的对象存储系统时,需要详细分析系统需求,以确保设计出的系统能够满足实际应用的需求。

基本功能需求

  • 数据存储:能够存储各种类型的文件,包括文本、图像、视频等。
  • 数据检索:能够快速检索存储的数据,包括按文件名、标签等进行检索。
  • 数据删除:支持删除存储的文件,释放存储空间。
  • 元数据管理:存储和管理文件的元数据,如文件名、大小、上传时间等。

高级功能需求

  • 身份验证与授权:确保只有授权用户才能访问和操作数据。
  • 多租户支持:支持多个用户或组织使用同一个存储系统,但数据互相隔离。
  • 存储策略:支持多种存储策略,如副本策略、分片存储等。
  • 数据一致性:确保在分布式环境中数据的一致性。
  • 数据备份与恢复:支持数据备份和恢复,以应对数据丢失的风险。
  • 性能优化:在高并发环境下保证系统的高性能。

非功能需求

  • 高可用性:确保系统在高并发访问下的稳定性和可靠性。
  • 可扩展性:能够通过增加节点来扩展存储容量和处理能力。
  • 安全性:保护数据的安全,防止未经授权的访问和操作。
  • 易维护性:系统易于维护和管理,包括配置、监控和日志记录等。

4. 系统架构设计

为了满足上述需求,系统架构需要具备良好的扩展性、可靠性和可维护性。可以将系统架构分为以下几个层次:

API层

API层提供RESTful API接口,供客户端进行数据操作。主要职责包括:

  • 接收客户端请求:处理客户端的上传、下载、删除等请求。
  • 请求路由:将请求转发到相应的服务层进行处理。
  • 返回响应:将处理结果返回给客户端。

服务层

服务层实现核心业务逻辑,包括对象存储、检索和管理等。主要职责包括:

  • 对象存储:将文件存储到指定的存储后端。
  • 对象检索:根据请求参数检索存储的文件。
  • 元数据管理:管理文件的元数据,包括创建、更新和删除等操作。
  • 身份验证与授权:验证用户身份,控制用户对数据的访问权限。

存储层

存储层管理数据的物理存储,支持多种存储后端。主要职责包括:

  • 数据存储:将数据存储到指定的存储介质,如本地磁盘、分布式文件系统等。
  • 数据检索:从存储介质中检索数据。
  • 数据备份与恢复:对数据进行备份和恢复,以保障数据安全。

安全层

安全层提供身份验证和授权功能,确保数据访问的安全性。主要职责包括:

  • 用户管理:管理用户信息,包括用户注册、登录等。
  • 权限控制:控制用户对数据的访问权限,确保只有授权用户才能操作数据。

监控与日志层

监控与日志层监控系统运行状态,记录操作日志。主要职责包括:

  • 系统监控:监控系统的性能指标,如CPU、内存、磁盘等资源使用情况。
  • 日志记录:记录系统操作日志,包括用户操作日志和系统日志等。
  • 报警机制:设置报警机制,当系统出现异常时及时报警。

5. 核心功能模块设计

5.1 身份验证与授权

身份验证与授权是确保系统安全的重要机制。使用Spring Security实现身份验证和授权,支持OAuth2和JWT等多种认证方式。

身份验证

身份验证负责验证用户的身份,确保只有合法用户才能访问系统。常见的身份验证方式包括用户名密码验证、OAuth2和JWT等。用户名密码验证适用于内部系统,而OAuth2和JWT适用于需要与第三方系统集成的场景。

授权

授权负责控制用户对资源的访问权限,确保用户只能访问自己有权限的资源。常见的授权方式包括基于角色的访问控制(RBAC)和基于属性的访问控制(ABAC)等。

5.2 对象存储与检索

对象存储与检索是对象存储系统的核心功能,负责存储、检索和删除对象。使用Spring Boot的文件上传和下载功能,实现对象的存储与检索。

对象存储

对象存储包括文件上传和存储操作。系统接收客户端上传的文件,将文件存储到指定的存储后端,并记录文件的元数据。

对象检索

对象检索包括文件下载和查询操作。系统根据客户端提供的查询参数,检索存储的文件,并将文件返回给客户端。

对象删除

对象删除包括删除存储的文件和相关的元数据。系统接收客户端的删除请求,删除指定的文件,并更新元数据。

5.3 元数据管理

元数据管理负责存储和管理对象的元数据,包括文件名、大小、上传时间等。使用Spring Data JPA或Spring Data MongoDB管理元数据,选择合适的数据库存储元数据。

元数据存储

元数据存储包括创建和更新元数据操作。系统在对象存储和更新时,创建或更新对象的元数据,并将其存储到数据库中。

元数据检索

元数据检索包括查询和获取元数据操作。系统根据客户端提供的查询参数,检索和获取对象的元数据。

元数据删除

元数据删除包括删除对象的元数据。系统在对象删除时,删除对象的元数据。

5.4 存储策略与数据分片

存储策略与数据分片是提高系统可用性和性能的重要手段。支持多种存储策略,如副本策略、数据分片和分区存储等。

副本策略

副本策略通过存储多个数据副本,提高数据的可用性和可靠性。在数据存储时,系统将数据复制到多个存储节点,以防止单点故障。

数据分片

数据分片通过将大文件分成多个小块存储,提高存储和访问性能。在大文件上传时,系统将文件分成多个小块,分别存储到不同的存储节点。

分区存储

分区存储通过将数据分区存储,提高系统的扩展性和性能。在数据存储时,系统根据一定的分区规则,将数据存储到不同的存储分区。

5.5 数据一致性与容错

数据一致性与容错是分布式系统设计中的重要考虑。使用分布式一致性算法(如Raft或Paxos)确保数据的一致性,采用多副本存储提高系统的容错能力。

数据一致性

数据一致性通过分布式一致性算法,确保在多个节点之间的数据一致性。在数据存储和更新时,系统通过一致性算法协调多个节点的数据状态,确保数据的一致性。

容错能力

容错能力通过多副本存储和自动故障恢复,提高系统的可靠性。在数据存储时,系统将数据复制到多个节点,以防止单点故障;在节点故障时,系统能够自动恢复数据,提高系统的容错能力。

6. Spring Boot实现方案

6.1 身份验证与授权

使用Spring Security实现身份验证和授权,支持OAuth2和JWT等多种认证方式。

配置Spring Security

在Spring Boot项目中,配置Spring Security,启用OAuth2和JWT认证。

实现用户管理

实现用户注册、登录和管理功能,提供用户注册、登录和信息修改的API接口。

实现权限控制

实现基于角色的访问控制(RBAC),配置不同角色的访问权限,确保用户只能访问自己有权限的资源。

6.2 对象存储与检索

使用Spring Boot的文件上传和下载功能,实现对象的存储与检索。

配置文件上传

在Spring Boot项目中,配置文件上传功能,处理客户端上传的文件请求。

实现对象存储

实现对象存储的业务逻辑,将客户端上传的文件存储到指定的存储后端,并记录文件的元数据。

配置文件下载

在Spring Boot项目中,配置文件下载功能,处理客户端下载文件的请求。

实现对象检索

实现对象检索的业务逻辑,根据客户端提供的查询参数,检索存储的文件,并将文件返回给客户端。

6.3 元数据管理

使用Spring Data JPA或Spring Data MongoDB管理元数据,选择合适的数据库存储元数据。

配置数据库

在Spring Boot项目中,配置数据库连接,选择合适的数据库(如MySQL或MongoDB)存储元数据。

实现元数据存储

实现元数据存储的业务逻辑,在对象存储和更新时,创建或更新对象的元数据,并将其存储到数据库中。

实现元数据检索

实现元数据检索的业务逻辑,根据客户端提供的查询参数,检索和获取对象的元数据。

实现元数据删除

实现元数据删除的业务逻辑,在对象删除时,删除对象的元数据。

6.4 存储策略与数据分片

使用Spring Boot的配置管理支持多种存储策略,实现数据分片和副本存储。

配置存储策略

在Spring Boot项目中,配置存储策略,支持副本策略、数据分片和分区存储等。

实现副本存储

实现副本存储的业务逻辑,在数据存储时,将数据复制到多个存储节点,提高数据的可用性和可靠性。

实现数据分片

实现数据分片的业务逻辑,在大文件上传时,将文件分成多个小块,分别存储到不同的存储节点,提高存储和访问性能。

实现分区存储

实现分区存储的业务逻辑,在数据存储时,根据一定的分区规则,将数据存储到不同的存储分区,提高系统的扩展性和性能。

6.5 数据一致性与容错

集成分布式一致性算法库(如Apache Zookeeper或etcd)实现数据一致性,采用多副本存储提高系统的容错能力。

配置分布式一致性算法

在Spring Boot项目中,集成分布式一致性算法库(如Apache Zookeeper或etcd),配置一致性算法,确保在多个节点之间的数据一致性。

实现数据一致性

实现数据一致性的业务逻辑,在数据存储和更新时,通过一致性算法协调多个节点的数据状态,确保数据的一致性。

实现容错能力

实现容错能力的业务逻辑,在数据存储时,将数据复制到多个节点;在节点故障时,系统能够自动恢复数据,提高系统的容错能力。

7. 性能优化与扩展

为了确保系统在高并发环境下的性能和扩展性,需要对系统进行性能优化和扩展设计。

7.1 性能优化

缓存机制

使用缓存技术(如Redis或Memcached)提高数据访问速度,减轻数据库负载。缓存热点数据和常用数据,减少对数据库的直接访问。

负载均衡

使用负载均衡技术(如Nginx或Spring Cloud LoadBalancer)分散请求压力,提高系统的并发处理能力。配置多个应用实例,通过负载均衡器分发请求,确保系统的高可用性。

异步处理

使用Spring Boot的异步处理机制(如@Async注解)提高并发处理能力。将耗时的操作(如文件上传和数据处理)异步执行,提升系统响应速度。

数据库优化

优化数据库设计和查询性能,包括合理设计表结构、添加索引、优化查询语句等。定期进行数据库性能监测和优化,确保数据库的高效运行。

7.2 系统扩展

水平扩展

通过增加节点实现系统的水平扩展,提高存储容量和处理能力。使用分布式存储系统(如Ceph或HDFS)支持大规模数据存储和管理。

模块化设计

采用模块化设计,将系统功能模块化,便于扩展和维护。每个功能模块独立开发、部署和维护,提高系统的灵活性和可维护性。

8. 安全性设计

为了保护数据的安全,防止未经授权的访问和操作,需要进行全面的安全性设计。

数据加密

传输层加密

使用HTTPS协议对数据传输进行加密,防止数据在传输过程中被截获和篡改。配置SSL证书,启用HTTPS访问,确保数据传输的安全性。

存储层加密

对存储的数据进行加密,保护敏感数据的安全。使用加密算法(如AES或RSA)对数据进行加密存储,确保数据在存储介质中的安全性。

访问控制

细粒度权限控制

使用细粒度的访问控制策略,确保只有授权用户能够访问特定数据。配置用户角色和权限,控制用户对数据的访问权限,提高系统的安全性。

日志监控

记录用户操作日志,监控系统访问情况,及时发现和处理安全问题。配置日志记录策略,记录用户的关键操作和系统日志,便于审计和追踪。

安全审计

定期进行安全审计,检查系统的安全状况,发现并修复安全漏洞。进行安全测试和评估,确保系统的安全性和可靠性。

9. 部署与运维

为了确保系统的稳定运行和高效运维,需要进行合理的部署与运维设计。

容器化部署

使用Docker进行容器化部署,简化部署流程,提高部署效率。将应用和依赖打包成Docker镜像,通过容器管理平台(如Kubernetes)进行部署和管理。

自动化运维

使用Kubernetes进行容器编排,实现自动化运维和管理。配置自动伸缩策略,根据负载情况自动调整实例数量,确保系统的高可用性。

持续集成与持续交付(CI/CD)

使用Jenkins或GitLab CI实现持续集成和持续交付,提高开发和运维效率。配置CI/CD流水线,自动化构建、测试和部署,提高开发效率和质量。

系统监控与报警

使用监控工具(如Prometheus和Grafana)监控系统的性能指标,及时发现和处理问题。配置报警机制,当系统出现异常时及时报警,确保系统的稳定运行。

10. 结论

使用Spring Boot设计一个类似MinIO的对象存储系统,可以充分利用Spring生态系统的优势,快速构建和部署高性能的存储服务。本文详细讨论了对象存储系统的核心功能模块设计、Spring Boot实现方案、性能优化与扩展、安全性设计以及部署与运维。希望本文能够对读者在实际项目中设计和实现对象存储系统提供有价值的参考和指导。

相关文章:

使用Spring Boot设计对象存储系统

对象存储系统是一种以对象为存储单位的存储架构,适合存储大量非结构化数据,如图片、音视频文件、文档等。MinIO是一个高性能的对象存储系统,基于开源和云原生的设计理念。本文将讨论如何使用Spring Boot设计一个类似MinIO的对象存储系统。 目…...

Apple开发者macOS设备与描述文件Profile创建完整过程

安装并打开Apple Configurator 新建描述文件 输入macOS平台的描述文件的相关信息,然后选择证书 选择一个可用证书 存储描述文件 存储成功如下: 使用文本编辑器打开刚才保存的描述文件,找到设备名与UDID...

SpringBootWeb 篇-深入了解 Redis 五种类型命令与如何在 Java 中操作 Redis

🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍ 文章目录 1.0 Redis 概述 1.1 Redis 下载与安装 2.0 Redis 数据类型 3.0 Redis 常见五种类型的命令 3.1 字符串操作命令 3.2 哈希操作命令 3.3 列表操作命令 3.4 集合操作命令 …...

mysql设置允许外部ip访问,局域网IP访问

(支持MYSQL8版本) 1. 登录进入mysql;mysql -uroot -p输入密码进入 2. 输入以下语句,进入mysql库,查看user表中root用户的访问 use mysql; select host,user from user; 3. 更新user表中root用户域属性&#xff0c…...

mac虚拟光驱工具:Daemon Tools for Mac

Daemon Tools for Mac是一款功能强大的虚拟光驱工具,它为用户提供了在Mac上模拟物理光驱的能力,从而方便用户处理各种光盘映像文件。以下是关于Daemon Tools for Mac的详细介绍: 守护进程工具:Daemon Tools不仅是一个简单的虚拟光…...

软考 系统架构设计师系列知识点之杂项集萃(32)

接前一篇文章:软考 系统架构设计师系列知识点之杂项集萃(31) 第51题 网络逻辑结构设计的内容不包括( )。 A. 逻辑网络设计图 B. IP地址方案 C. 具体的软硬件、广域网连接和基本服务 D. 用户培训计划 正确答案&am…...

Web--CSS基础

文章目录 定义方式选择器文本字体背景边框元素展示格式内边距与外边距盒子模型位置浮动flex布局响应式布局 定义方式 行内样式表 直接定义在style属性中&#xff0c;作用于当前标签 <img src "/imges/logo.jpg" alt "" style "width 400"…...

服务部署:Linux系统部署C# .NET项目

1. 安装 .NET SDK 首先&#xff0c;你需要在你的 Linux 系统上安装 .NET SDK。 Ubuntu系统&#xff1a; 下载 Microsoft 包配置文件 wget https://packages.microsoft.com/config/ubuntu/20.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb 这个命令使用 wge…...

【机器学习】基于卷积LSTM的视频预测

1. 引言 1.1 LSTM是什么 LSTM&#xff08;Long Short-Term Memory&#xff09;是一种特殊的循环神经网络&#xff08;RNN&#xff09;变体&#xff0c;旨在解决传统RNN在处理长序列数据时遇到的梯度消失和梯度爆炸问题。LSTM通过引入门控机制和细胞状态的概念&#xff0c;使得…...

细说wayland和X11

文章目录 协议介绍协议区别开发差异 Wayland和X11都是用于Linux和其他类Unix系统的显示服务器协议。它们负责在用户和应用程序之间的交互中管理屏幕的输出以及输入设备的输入。 协议介绍 X11通常称为X Window System&#xff0c;是一个历史悠久的显示服务器&#xff0c;自1987…...

数据结构:二叉树的实现

目录 二叉树的遍历方式 前序遍历&#xff1a; 中序遍历&#xff1a; 后序遍历&#xff1a; 二叉树的基本结构和功能 基本结构&#xff1a; 基本功能&#xff1a; 二叉树功能的实现思路 二叉树功能的实现 1、构建一个二叉树 2、二叉树的销毁 3、计算二叉树里的节点个数 4、得…...

Helm离线部署Rancher2.7.10

环境依赖&#xff1a; K8s集群、helm 工具 Rancher组件架构 Rancher Server 包括用于管理整个 Rancher 部署的所有软件组件。 下图展示了 Rancher 2.x 的上层架构。下图中&#xff0c;Rancher Server 管理两个下游 Kubernetes 集群 准备Rancher镜像推送到私有仓库 cat >…...

Linux目录的作用和常用指令

目录结构及其详细作用 / (根目录) Linux文件系统的起点&#xff0c;所有文件和目录都在其下。 /bin 存放系统启动和运行时所需的基本命令&#xff0c;如 ls, cp, mv, rm&#xff0c;这些命令在单用户模式下或系统崩溃时仍然可用。 /boot 包含启动引导加载器的文件和Linux内核…...

Nvidia/算能 +FPGA+AI大算力边缘计算盒子:隧道和矿井绘图设备

RockMass 正在努力打入采矿业和隧道工程利基市场。 这家位于多伦多的初创公司正在利用 NVIDIA AI 开发一款绘图平台&#xff0c;帮助工程师评估矿井和施工中的隧道稳定性。 目前&#xff0c;作为安全预防措施&#xff0c;地质学家和工程师会站在离岩石五米远的地方&#xff0…...

MySQL物理备份

目录 备份策略 全量备份 (Full Backup) 增量备份 (Incremental Backup) 差异备份 (Differential Backup) 使用 Percona XtraBackup 全量备份 步骤 1&#xff1a;全量备份 步骤 2&#xff1a;备份后处理&#xff08;应用日志&#xff09; 步骤 3&#xff1a;恢复备份 验…...

AWT常用组件

AWT中常用组件 前言一、基本组件组件名标签(Label类)Label类的构造方法注意要点 按钮(Button)Button的构造方法注意要点 文本框(TextField)TextField类的构造方法注意要点 文本域&#xff08;TextArea&#xff09;TextArea 的构造方法参数scrollbars的静态常量值 复选框&#x…...

CorelDRAW2024破解激活码序列号一步到位

亲们&#xff0c;今天给大家种草一个神奇的软件——CorelDRAW破解2024最新版&#xff01;&#x1f3a8;这是一款专业级的矢量图形设计软件&#xff0c;无论你是平面设计师、插画师还是设计师&#xff0c;都能在这个软件中找到你需要的工具和功能。✨ 让我来给大家介绍一下这款软…...

Webpack前端打包工具详解

目录 Webpack前端打包工具详解一、Webpack 的作用二、Webpack 的安装和基本使用1. 安装 Webpack2. 创建 Webpack 配置文件3. 运行 Webpack 三、Webpack 核心概念1. 入口&#xff08;Entry&#xff09;2. 输出&#xff08;Output&#xff09;3. 加载器&#xff08;Loaders&#…...

计网总结☞网络层

.................................................. 思维导图 ........................................................... 【Wan口和Lan口】 WAN口&#xff08;Wide Area Network port&#xff09;&#xff1a; 1)用于连接外部网络&#xff0c;如互联…...

【全开源】云调查考试问卷系统(FastAdmin+ThinkPHP+Uniapp)

便捷、高效的在线调研与考试新选择​ 云调查考试问卷是一款基于FastAdminThinkPHPUniapp开发的问卷调查考试软件&#xff0c;可以自由让每一个用户自由发起调查问卷、考试问卷。发布的问卷允许控制问卷的搜集、回答等各个环节的设置&#xff0c;同时支持系统模板问卷&#xff…...

网络安全难学吗?2024该怎么系统学习网络安全?

学习网络安全需要循序渐进&#xff0c;由浅入深。很多人对网络安全进行了解以后&#xff0c;就打算开始学习网络安全&#xff0c;但是又不知道怎么去系统的学习。 网络安全本身的知识不难&#xff0c;但需要学习的内容有很多&#xff0c;其中包括Linux、数据库、渗透测试、等保…...

2 程序的灵魂—算法-2.4 怎样表示一个算法-2.4.6 用计算机语言表示算法

我们的任务是用计算机解题&#xff0c;就是用计算机实现算法&#xff1b; 用计算机语言表示算法必须严格遵循所用语言的语法规则。 【例 2.20】求 12345 用 C 语言表示。 main() {int i,t; t1; i2; while(i<5) {tt*i; ii1; } printf(“%d”,t); } 【例 2.21】求级数的…...

重生之我要精通JAVA--第八周笔记

文章目录 多线程线程的状态线程池自定义线程池最大并行数多线程小练习 网络编程BS架构优缺点CS架构优缺点三要素IP特殊IP常用的CMD命令 InetAddress类端口号协议UDP协议&#xff08;重点&#xff09;UDP三种通信方式 TCP协议&#xff08;重点&#xff09;三次握手四次挥手 反射…...

51单片机独立按键控制LED灯,按键按一次亮,再按一次灭

1、功能描述 独立按键控制LED灯&#xff0c;按键按一次亮&#xff0c;再按一次灭 2、实验原理 轻触按键:相当于是一种电子开关&#xff0c;按下时开关接通&#xff0c;松开时开关断开&#xff0c;实现原理是通过轻触按键内部的金属弹片受力弹动米实现接通和断开&#xff1b;…...

【上海大学计算机组成原理实验报告】七、程序转移机制

一、实验目的 学习实现程序转移的硬件机制。 掌握堆栈寄存器的使用。 二、实验原理 根据实验指导书的相关内容&#xff0c;实验箱系统的程序转移硬件机制在于&#xff0c;当LDPC有效时&#xff0c;如果此时DUBS上的值就是转移的目标地址&#xff0c;则此目标地址被打入PC&am…...

LLVM Cpu0 新后端7 第一部分 DAG调试 dot文件 Machine Pass

想好好熟悉一下llvm开发一个新后端都要干什么&#xff0c;于是参考了老师的系列文章&#xff1a; LLVM 后端实践笔记 代码在这里&#xff08;还没来得及准备&#xff0c;先用网盘暂存一下&#xff09;&#xff1a; 链接: https://pan.baidu.com/s/1yLAtXs9XwtyEzYSlDCSlqw?…...

修复www服务trace漏洞

验证方式&#xff1a;curl -v -X TRACE ip:port&#xff0c;或使用其他接口调试工具如Postman 响应&#xff1a;状态行405 Method Not Allowed且响应体无内容 方案一&#xff1a;使用过滤器 若webserver是tomcat, 添加过滤器的方式有很多 Component public class TraceHttpMe…...

算法:101. 对称二叉树

对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,3,4,4,3] 输出&#xff1a;true示例 2&#xff1a; 输入&#xff1a;root [1,2,2,null,3,null,3] 输出&#xff1a;false提示&#xff1a; 树中节…...

wordpress 使用api发布文章

1.安装插件 在/wp-content/plugins/目录执行以下命令 $ sudo git clone https://github.com/WP-API/Basic-Auth.git 2.Python脚本 import requestsurl http://www.ziyuanwang.online/wp-json/wp/v2/postsuser adminpassword xxxxxheaders {Content-Type: application/j…...

《Brave New Words 》2.2 阅读理解的未来,让文字生动起来!

Part II: Giving Voice to the Social Sciences 第二部分&#xff1a;为社会科学发声 The Future of Reading Comprehension, Where Literature Comes Alive! 阅读理解的未来&#xff0c;让文字生动起来&#xff01; Saanvi, a ninth grader in India who attends Khan World S…...

口碑好的番禺网站建设/广州网站优化方式

小程序的火爆已经不是一两天了&#xff0c;有些小程序成本价可能几百几千&#xff0c;但是如果是卖的话&#xff0c;可能几万、几十万都是有可能的&#xff0c;也造成现在很多年轻人学习小程序&#xff0c;小猿圈web前端讲师解读微信小程序文件下载--视频和图片&#xff0c;希望…...

幼儿园网站建设工作总结/搜索app下载安装

介绍一款新的绘图神器&#xff1a;sviewgui。sviewgui介绍sviewgui是一个基于 PyQt 的 GUI&#xff0c;用于 csv 文件或 Pandas 的 DataFrame 的数据可视化。此 GUI 基于 matplotlib&#xff0c;您可以通过多种方式可视化您的 csv 文件。主要特点&#xff1a;Ⅰ 散点图、线图、…...

商标转让交易网/搜索引擎优化分析报告

目录 JavaScript高程学习笔记之事件(13)JavaScript高程学习笔记之事件(13) (JavaScript)[学习笔记] 1. 事件流 事件流描述从页面中接收事件的顺序 1.1 事件冒泡 IE的事件流叫做事件冒泡&#xff0c;即事件开始时有最具体的元素&#xff08;文档中嵌套层次最深的那个节点&#x…...

网站解析是做a记录吗/网上怎么发布广告

目录 1 BIO基本介绍 2 BIO工作机制 3 同步阻塞案例 4 BIO模式多发和多收消息 1 BIO基本介绍 BIO是就是传统的io编程&#xff0c;其相关的类和接口在Java.io BIO:同步阻塞&#xff0c;服务器实现模式为一个线程一个连接&#xff0c;即客户端有连接请求时服务器端就需要启动一个…...

会搭建网站找什么工作室/谷歌seo综合查询

http://blog.csdn.net/smartempire/article/details/23168945 看关于LBP人脸识别的论文时提到了Histogram intersection这个方法&#xff0c;方法最初来自The Pyramid Match Kernel:Discriminative Classification with Sets of Image Features这篇论文&#xff0c;用来对特征构…...

无法定位 wordpress 根目录./seo策略工具

一直以来&#xff0c;我们在网页上都是使用图片作为表情。但是图片表情使用起来麻烦&#xff0c;同时衍生了css sprite技术&#xff08;雪碧图&#xff0c;就是很多个小图片拼接成一张大图片&#xff09;。但其实unicode编码中就定义了大量的表情符号&#xff0c;而且你还可以使…...