万能网站/抚州网络推广

万能网站,抚州网络推广,360免费wifi电脑版,网站引导页动态效果怎么做微服务 - 中级篇 一、微服务架构深化(一)服务拆分原则(二)服务通信方式 二、微服务技术选型(一)开发框架(二)容器技术 三、微服务实践与优化(后续会详细分析)…

微服务 - 中级篇

  • 一、微服务架构深化
    • (一)服务拆分原则
    • (二)服务通信方式
  • 二、微服务技术选型
    • (一)开发框架
    • (二)容器技术
  • 三、微服务实践与优化(后续会详细分析)

一、微服务架构深化

(一)服务拆分原则

1.业务功能内聚性

  • 核心概念是将逻辑上紧密关联的业务功能组合在一个微服务中。以电商系统为例,用户管理模块包含用户注册、登录、个人信息修改、密码重置等功能。这些功能围绕用户实体展开,相互之间存在紧密的业务逻辑联系。将它们整合在用户管理微服务中,使得该微服务成为一个独立的业务单元,具备清晰的边界和职责。这种内聚性设计有助于提高代码的可维护性和可理解性。开发人员在维护用户管理相关功能时,只需关注这个特定的微服务,而不必在庞大的单体应用代码库中四处寻找相关代码片段。
  • 在实现过程中,要深入分析业务流程。比如在一个在线教育平台中,课程管理功能包括课程创建、编辑、发布、下架以及课程详情展示等。这些功能紧密围绕课程这一业务对象,应归属于课程管理微服务。通过合理的代码分层和模块化设计,将这些功能的实现代码组织在一起,例如在Java 的 Spring Boot 框架中,可以通过不同的 Service 类和 Controller类来分别处理业务逻辑和对外接口,确保整个微服务的结构清晰。

2.数据独立性

  • 每个微服务拥有独立的数据存储是微服务架构的重要特性。以电商系统的订单微服务和商品微服务为例,订单微服务维护自己的订单数据库,存储订单的详细信息,如订单编号、下单时间、用户信息、商品清单、订单状态等。商品微服务则有自己的商品数据库,存储商品的名称、描述、价格、库存等信息。这种设计避免了不同微服务对同一数据的直接访问,降低了数据一致性问题的复杂性。例如,如果订单微服务和商品微服务共享一个数据库,当商品信息发生变化时,可能会导致订单微服务读取到不一致的数据,影响订单处理流程。
  • 在技术实现上,订单微服务可以使用关系型数据库如 MySQL 来存储订单数据,通过 ORM(对象关系映射)框架如 MyBatis 将Java 对象与数据库表进行映射。商品微服务则可以根据业务需求选择不同的存储方案,对于一些需要快速查询商品信息的场景,可以使用 Redis等缓存数据库来存储商品的基本信息,同时使用关系型数据库存储商品的详细描述等不常变动的数据。并且,每个微服务负责自己数据的完整性和一致性维护,通过事务管理等机制确保数据操作的原子性。

3.演进性

  • 业务在不断发展变化,微服务架构需要具备良好的演进性。在设计微服务拆分时,要充分考虑未来业务的扩展方向。例如,一个社交媒体平台最初可能只提供用户发布文字动态、点赞和评论的功能。随着业务发展,计划增加短视频发布、直播等功能。在最初的微服务设计中,就应将用户动态相关功能设计成具有扩展性的微服务结构。可以将用户动态发布功能设计成一个独立的微服务,其接口设计具有一定的通用性,能够方便地扩展支持短视频、直播等新类型的动态发布。这样,当业务扩展时,只需在该微服务基础上进行功能增强,而不需要大规模地重构整个系统架构。
  • 在实践中,可以采用领域驱动设计(DDD)的方法来帮助实现演进性。通过对业务领域的深入分析,识别出核心领域模型和边界上下文。以在线旅游平台为例,酒店预订和机票预订可以看作是两个不同的边界上下文,分别设计成独立的微服务。随着业务拓展到旅游套餐预订等新领域,可以基于已有的领域模型和设计思路,在合适的边界上下文中添加新的微服务或扩展现有微服务,确保系统能够适应业务的不断变化。

(二)服务通信方式

1.RESTful API

  • RESTful API 基于 HTTP协议,具有简洁、通用、可读性强的特点,在微服务通信中广泛应用。它遵循一套统一的资源访问规范,通过不同的 HTTP方法来操作资源。例如,在一个博客系统中,要获取一篇博客文章的详情,可以使用 GET 请求,请求 URL为/api/blogs/{blogId},其中{blogId}是博客文章的唯一标识符。服务器接收到请求后,根据blogId从数据库中查询相应的博客文章信息,并以JSON 或 XML 格式返回给客户端。如果要创建一篇新的博客文章,则使用 POST 请求,将新文章的内容以 JSON格式放在请求体中发送到/api/blogsURL。
  • 在实现 RESTful API 时,要遵循一些最佳实践。首先,URL设计要简洁且具有语义化,能够清晰地表示所操作的资源。例如,对于用户资源的操作,/api/users表示用户集合,/api/users/{userId}表示单个用户。其次,合理使用HTTP 状态码来表示请求的处理结果,如 200 表示请求成功,404 表示资源未找到,500 表示服务器内部错误等。在 Java 的Spring Boot 框架中,通过@RestController注解和相关的 HTTP请求映射注解(如@GetMapping、@PostMapping等)可以方便地实现 RESTful API。

2.消息队列

  • 消息队列在微服务架构中用于异步通信,能有效解耦服务之间的依赖关系。以电商系统为例,当用户下单后,订单微服务创建订单记录,并将一个包含订单信息的消息发送到消息队列,如RabbitMQ。库存微服务监听该消息队列,当接收到订单消息后,从消息中解析出商品信息,然后进行库存扣减操作。这种方式避免了订单服务直接调用库存服务的接口,减少了服务之间的直接依赖。如果库存服务暂时不可用,订单服务发送的消息会在消息队列中等待,不会影响订单的创建流程,提高了系统的可靠性和可扩展性。
  • 在技术选型方面,RabbitMQ功能丰富,支持多种消息协议和灵活的路由策略。它适用于对消息可靠性要求较高、需要复杂消息路由的场景。Kafka则具有高吞吐量、低延迟的特点,适合处理大数据量的实时消息流,例如在日志收集系统中,各个微服务产生的日志消息可以通过 Kafka进行快速传输和处理。在使用消息队列时,要注意消息的持久化、消息顺序性以及消息重复消费等问题。例如,可以通过设置 RabbitMQ的队列和消息属性来保证消息的持久化,通过合理的分区和消费者组设计来处理消息顺序性和重复消费问题。

3.gRPC

  • gRPC 基于 HTTP/2协议,具有高性能、轻量级的优势,尤其适用于对性能要求苛刻的场景,特别是跨语言的微服务通信。在一个大型分布式系统中,可能存在多种编程语言开发的微服务,如Java、Python、Go 等。gRPC 使用 Protobuf(ProtocolBuffers)作为接口定义语言,它能够将接口定义编译成不同语言的代码,实现跨语言的无缝通信。例如,一个由 Java开发的用户认证微服务和一个由 Go 开发的业务逻辑微服务之间需要进行通信。通过 gRPC,首先定义一个用户认证的接口.proto文件,然后使用 Protobuf 编译器生成 Java 和 Go 版本的接口代码。在 Java 微服务中实现接口的服务端逻辑,在 Go微服务中生成客户端代码来调用该接口。

  • gRPC 的性能优势主要体现在它的二进制序列化格式比 JSON 等文本格式更紧凑,传输效率更高,并且 HTTP/2 协议支持多路复用、头部压缩等特性,减少了网络开销。在实际应用中,对于一些实时性要求高、数据传输量大的场景,如视频流处理系统中的微服务通信,gRPC 能够显著提高系统的性能和响应速度。同时,gRPC 还提供了服务发现、负载均衡等功能的支持,方便与其他微服务组件集成。

二、微服务技术选型

(一)开发框架

1.Spring Boot

  • Spring Boot 极大地简化了 Spring 应用程序的开发和配置过程,遵循约定大于配置的原则。在构建微服务时,开发人员无需手动编写大量繁琐的 XML 配置文件。例如,要创建一个简单的用户管理微服务,使用 Spring Boot 只需要引入相关的依赖,如 Spring Web Starter 用于处理 HTTP 请求,Spring Data JPA Starter 用于数据库访问。然后通过创建 Java 配置类和相关的 Controller、Service、Repository 类来实现业务逻辑。在配置类中,使用@SpringBootApplication注解来启动 Spring Boot 应用,该注解包含了@EnableAutoConfiguration(自动配置)、@ComponentScan(组件扫描)等多个重要注解,自动完成了大部分的 Spring 框架配置工作。
  • Spring Boot 提供了丰富的 starter 依赖,方便集成各种功能。例如,要集成 MySQL 数据库,只需在pom.xml文件中添加spring - boot - starter - data - jpa和mysql - connector - java依赖,Spring Boot 会自动根据配置文件中的数据库连接信息进行数据源的配置和初始化。对于安全性方面,可以引入spring - boot - starter - security依赖来快速实现用户认证和授权功能。这种一站式的开发体验使得开发人员能够快速搭建微服务架构,专注于业务逻辑的实现。

2.Spring Cloud

  • Spring Cloud 是基于 Spring Boot 构建的一整套微服务解决方案。它提供了多个核心组件来支持微服务架构的各个方面。例如,Eureka 作为服务注册与发现组件,微服务在启动时会向 Eureka Server 注册自己的服务实例信息,包括服务名称、IP 地址、端口等。其他微服务通过 Eureka Client 从 Eureka Server 获取服务列表,实现服务的动态发现和调用。在一个分布式电商系统中,订单微服务、商品微服务等都可以注册到 Eureka Server 上,当订单微服务需要调用商品微服务的接口获取商品信息时,它可以从 Eureka Server 获取商品微服务的实例地址,然后进行远程调用。
  • Spring Cloud 还包括 Hystrix 熔断器组件,用于防止微服务之间的级联故障。当某个微服务出现故障或响应超时等情况时,Hystrix 会自动熔断,不再将请求转发到故障服务,而是返回一个预先定义好的降级响应,保证系统的部分功能仍然可用。例如,在旅游预订系统中,如果酒店预订微服务出现故障,Hystrix 可以对调用酒店预订微服务的请求进行熔断,同时提供一个降级方案,如提示用户稍后重试,避免因酒店预订微服务的故障导致整个旅游预订流程的崩溃。此外,Spring Cloud 还提供了配置管理(Spring Cloud Config)、网关(Spring Cloud Gateway)等组件,全面支持微服务架构的构建和运行。

3.Quarkus

  • Quarkus 是专为云原生和微服务架构设计的 Java 框架,具有快速启动和低内存占用的显著优势。在传统的 Java 应用开发中,启动时间长和内存占用高是常见问题,尤其在容器化部署的微服务环境中,这些问题会影响系统的资源利用率和快速弹性伸缩能力。Quarkus 通过采用多种优化技术,如编译期优化、AOT(Ahead - Of - Time)编译等,极大地缩短了应用的启动时间。例如,一个基于 Quarkus 开发的微服务在容器中启动可能只需要几百毫秒,而传统的 Spring Boot 应用可能需要几秒甚至更长时间。
  • 在内存占用方面,Quarkus 通过对依赖的精简和优化,以及对运行时资源的高效管理,使得应用在运行时的内存消耗大幅降低。这对于在资源有限的云环境中部署大量微服务非常有利。例如,在一个使用 Kubernetes 进行容器编排的云平台上,基于 Quarkus 的微服务可以在相同的硬件资源下部署更多的实例,提高了系统的整体性能和资源利用率。同时,Quarkus 对多种 Java 生态系统中的技术栈都有良好的支持,如 JPA、RESTEasy 等,方便开发人员将现有的 Java 技术和知识应用到基于 Quarkus 的微服务开发中。

(二)容器技术

1.Docker

  • Docker 通过将应用程序及其所有依赖项打包成一个独立的容器,实现了环境的一致性和隔离性。以一个 Python Web 应用为例,该应用依赖于特定版本的 Python 解释器、Flask 框架以及一些数据库驱动库。使用 Docker,可以创建一个 Dockerfile,在其中定义基础镜像(如 Python 官方镜像),然后通过一系列指令安装应用所需的依赖项,复制应用代码到容器中,并设置容器的启动命令。例如:
# 使用Python 3.8官方镜像作为基础镜像
FROM python:3.8 - slim# 设置工作目录
WORKDIR /app# 复制requirements.txt文件并安装依赖
COPY requirements.txt.
RUN pip install -r requirements.txt# 复制应用代码到容器中
COPY. /app# 暴露应用运行的端口
EXPOSE 5000# 设置容器启动命令
CMD ["python", "app.py"]
  • 通过上述 Dockerfile 构建的 Docker 镜像,可以在任何支持 Docker 的环境中运行,无论是开发人员的本地机器、测试服务器还是生产环境的云服务器,都能保证应用运行环境的一致性,避免了 “在我机器上能运行,在其他环境不行” 的问题。同时,容器之间相互隔离,一个容器的故障或资源消耗不会影响其他容器,提高了应用的稳定性和安全性。

2.Kubernetes

  • Kubernetes 是用于容器编排和管理的强大工具。在一个包含大量微服务容器的生产环境中,Kubernetes 可以实现容器的自动化部署、扩展和故障转移。例如,在一个电商促销活动期间,订单量会大幅增加,通过 Kubernetes 可以根据预先设定的规则,自动增加订单微服务的容器实例数量,以应对高并发的订单请求。当某个订单微服务容器出现故障时,Kubernetes 会自动检测到,并将流量从故障容器转移到其他正常运行的容器上,同时启动新的容器来替换故障容器,保证订单处理业务的连续性。
  • Kubernetes 通过一系列的资源对象来管理容器,如 Pod(容器的逻辑分组,一个 Pod 可以包含一个或多个紧密相关的容器)、Deployment(用于管理 Pod 的生命周期,包括创建、更新、扩展等)、Service(为一组 Pod 提供统一的访问入口,实现负载均衡和服务发现)等。在部署微服务时,首先创建一个 Deployment 来定义微服务容器的配置和副本数量,然后创建一个 Service 将该 Deployment 暴露给其他微服务或外部客户端。例如,通过创建一个 Nginx Ingress Controller 和相应的 Ingress 资源,可以将外部的 HTTP 请求路由到内部的不同微服务的 Service 上,实现统一的入口管理和域名映射。

三、微服务实践与优化(后续会详细分析)

1.服务注册与发现

  • 服务注册与发现是微服务架构中的关键环节。以 Consul 为例,它是一个分布式服务发现和配置管理工具。在一个由多个微服务组成的系统中,每个微服务在启动时会向 Consul Server 注册自己的服务实例信息。例如,一个由 Java 开发的用户微服务,在启动过程中,通过 Consul Client 将自己的服务名称(如user - service)、IP 地址、端口以及一些健康检查信息(如 HTTP 健康检查 URL)发送到 Consul Server。Consul Server 维护一个服务注册表,记录所有注册的服务及其实例信息。
  • 当其他微服务需要调用用户微服务时,它们通过 Consul Client 从 Consul Server 查询user - service的服务实例列表。Consul Client 可以根据负载均衡策略(如轮询、随机等)选择一个可用的用户微服务实例进行调用。同时,Consul Server 会定期对注册的服务实例进行健康检查,如果发现某个实例不健康(如 HTTP 健康检查失败),会将其从服务注册表中移除,避免其他微服务调用到故障实例。这种服务注册与发现机制使得微服务架构具有动态性和灵活性,方便服务的扩展和维护。

2.负载均衡

  • 负载均衡是提高微服务系统并发处理能力和可用性的重要手段。Nginx 作为常用的服务端负载均衡器,可以将客户端的请求均匀地分发到多个微服务实例上。例如,在一个 Web 应用中,Nginx 部署在前端,接收来自用户的 HTTP 请求。它通过配置文件定义了后端的微服务实例列表,如upstream user_service_backend { server 192.168.1.100:8080; server 192.168.1.101:8080; },这里定义了两个用户微服务实例。当用户请求到达 Nginx 时,Nginx 根据配置的负载均衡算法(如轮询算法,依次将请求发送到不同的后端服务器)将请求转发到其中一个用户微服务实例上。
  • 在客户端负载均衡方面,Ribbon 是 Spring Cloud 中的一个组件,它与 Eureka 等服务注册与发现组件紧密集成。当一个微服务(如订单微服务)需要调用另一个微服务(如商品微服务)时,Ribbon 作为客户端负载均衡器,从 Eureka Server 获取商品微服务的实例列表,然后根据内置的负载均衡算法(如随机算法、加权轮询算法等)选择一个商品微服务实例进行调用。这种客户端负载均衡方式使得负载均衡决策分布在各个调用微服务的客户端,减轻了服务端负载均衡器的压力,并且可以根据客户端的实际情况进行更灵活的负载均衡策略调整。

3.熔断器

  • Hystrix 作为熔断器组件,在微服务架构中起到了保护系统免受级联故障影响的重要作用。当一个微服务(如 A 微服务)调用另一个微服务(如 B 微服务)时,如果 B 微服务出现故障或响应超时的次数达到一定阈值,Hystrix 会自动熔断,不再将请求转发到 B 微服务。例如,在一个旅游预订系统中,酒店预订微服务调用第三方酒店接口获取酒店信息。如果第三方接口出现故障,大量的请求在等待响应,可能会导致酒店预订微服务的线程资源耗尽,进而影响整个旅游预订系统的其他功能。Hystrix 在检测到这种情况后,会快速熔断,不再向第三方接口发送请求。

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

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

相关文章

STM32__红外避障模块的使用

目录 一、红外避障模块 概述 二、直接读取OUT引脚电平 三、使用中断方式触发 一、红外避障模块 概述 引脚解释: VCC接3.3V 或 5.0VGND接开发板的GNDOUT数字量输出(0或1); 低电平时表示前方有障碍 ; 通过可调电阻调整检测距离 产品特点: …

【AI大模型】DeepSeek + 通义万相高效制作AI视频实战详解

目录 一、前言 二、AI视频概述 2.1 什么是AI视频 2.2 AI视频核心特点 2.3 AI视频应用场景 三、通义万相介绍 3.1 通义万相概述 3.1.1 什么是通义万相 3.2 通义万相核心特点 3.3 通义万相技术特点 3.4 通义万相应用场景 四、DeepSeek 通义万相制作AI视频流程 4.1 D…

帆软第二题 - 多源报表

第二题,多源报表 实现功能: 多源报表:供应商与所在地区来源于表PRODUCER 明细来源于表PRODUCT 分组报表:按组显示数据,每个供应商对应其产品明细 按组分页:每个供应商一页 表头重复: 数据…

SVN忽略不必提交的文件夹和文件方法

最近有小伙伴在问:SVN在提交时如何忽略不必提交的文件夹和文件,如node_modules,.git,.idea等? 操作其实很简单,下面直接上图: 第一步: 第二步: 最后一步: 第…

Uthana,AI 3D角色动画生成平台

Uthana是什么 Uthana 是专注于3D角色动画生成的AI平台。平台基于简单的文字描述、参考视频或动作库搜索,快速为用户生成逼真的动画,支持适配任何骨骼结构的模型。Uthana 提供风格迁移、API集成和定制模型训练等功能,满足不同用户需求。平台提…

六十天前端强化训练之第二十九天之深入解析:从零构建企业级Vue项目的完整指南

欢迎来到编程星辰海的博客讲解 看完可以给一个免费的三连吗,谢谢大佬! 目录 一、Vite核心原理与开发优势 二、项目创建深度解析 三、配置体系深度剖析 四、企业级项目架构设计 五、性能优化实战 六、开发提效技巧 七、质量保障体系 八、扩展阅读…

Ceph集群2025(Squid版)导出高可用NFS集群(上集)

#创建一个CephFS 文件系统 ceph fs volume create cephfs02#创建子卷 ceph fs subvolumegroup create cephfs02 myfsg2#查看子卷 ceph fs subvolumegroup ls cephfs02[{"name": "myfsg2"} ]创建 NFS Ganesha 集群 #例子 $ ceph nfs cluster create <c…

第2.3节 Android生成全量和增量报告

覆盖率报告&#xff08;Coverage Report&#xff09;是一种软件测试工具生成的报告&#xff0c;用于评估测试用例对代码的覆盖程度。它通过统计代码中哪些部分已经被测试用例执行过&#xff0c;哪些部分还没有被执行&#xff0c;来衡量测试的充分性。覆盖率报告通常包括以下几种…

网络HTTPS协议

Https HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff09;是 HTTP 协议的加密版本&#xff0c;它使用 SSL/TLS 协议来加密客户端和服务器之间的通信。具体来说&#xff1a; • 加密通信&#xff1a;在用户请求访问一个 HTTPS 网站时&#xff0c;客户端&#x…

【MySQL笔记】库操作与表操作

&#x1f525;个人主页&#x1f525;&#xff1a;孤寂大仙V &#x1f308;收录专栏&#x1f308;&#xff1a;MySQL &#x1f339;往期回顾&#x1f339;&#xff1a;【MySQL】认识MySQL &#x1f516;流水不争&#xff0c;争的是滔滔不 一、库操作1.1 显示数据库1.2 创建数据库…

SpringBoot3实战(SpringBoot3+Vue3基本增删改查、前后端通信交互、配置后端跨域请求、数据批量删除(超详细))(3)

目录 一、从0快速搭建SpringBoot3工程、SpringBoot3集成MyBatis、PageHelper分页查询的详细教程。(博客链接) 二、实现前端与后端通信对接数据。(axios工具) &#xff08;1&#xff09;安装axios。(vue工程目录) &#xff08;2&#xff09;封装请求工具类。(request.js) <1&…

单播、广播、组播和任播

文章目录 一、单播二、广播三、组播四、任播代码示例&#xff1a; 五、各种播的比较 一、单播 单播&#xff08;Unicast&#xff09;是一种网络通信方式&#xff0c;它指的是在网络中从一个源节点到一个单一目标节点对的传输模式。单播传输时&#xff0c;数据包从发送端直接发…

【实战】deepseek数据分类用户评论数据

在平时的工作中&#xff0c;我们会遇到数据分类的情况&#xff0c;比如将一些文本划分为各个标签。如果人工分类这块的工作量将是非常大&#xff0c;而且分类数据的准确性也不高。我们需要用到一些工具来实现。提高效率的同时也提高准确率。 1.示例数据 用户ID 时间戳 评论场…

【JavaEE】网络编程socket

1.❤️❤️前言~&#x1f973;&#x1f389;&#x1f389;&#x1f389; Hello, Hello~ 亲爱的朋友们&#x1f44b;&#x1f44b;&#xff0c;这里是E绵绵呀✍️✍️。 如果你喜欢这篇文章&#xff0c;请别吝啬你的点赞❤️❤️和收藏&#x1f4d6;&#x1f4d6;。如果你对我的…

第16届蓝桥杯单片机4T模拟赛三

本次模拟赛涉及的模块&#xff1a;基础三件套&#xff08;Led&Relay&#xff0c;按键、数码管&#xff09; 进阶单件套&#xff08;pcf8591的AD模块&#xff09; 附件&#xff1a; 各模块底层代码在文章的结尾 一、数码管部分 1.页面1 页面1要显示的格式是&#xff1a; …

网络华为HCIA+HCIP IPv6

目录 IPv4现状 IPv6基本报头 IPv6扩展报头 IPv6地址 IPv6地址缩写规范 ​编辑 IPv6地址分配 IPv6单播地址分配 IPv6单播地址接口标识 IPv6常见单播地址 - GUA &#xff08;2 / 3 开头&#xff09; IPv6常见单播地址 - ULA IPv6常见单播地址 - LLA IPv6组播地…

基于YOLOv8深度学习的智能小麦害虫检测识别系统

作者简介&#xff1a;Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、多年校企合作经验&#xff0c;被多个学校常年聘为校外企业导师&#xff0c;指导学生毕业设计并参与学生毕业答辩指导&#xff0c;…

Mac:Maven 下载+安装+环境配置(详细讲解)

&#x1f4cc; 下载 Maven 下载地址&#xff1a;https://maven.apache.org/download.cgi &#x1f4cc; 无需安装 Apache官网下载 Maven 压缩包&#xff0c;无需安装&#xff0c;下载解压后放到自己指定目录下即可。 按我自己的习惯&#xff0c;我会在用户 jane 目录下新建…

XSS-labs(反射型XSS) 靶场 1-13关 通关

目录 前言 XSS漏洞概述 XSS漏洞分类 通关日记 level1 分析 解题 ​level2 分析 解题 方法一&#xff1a;闭合标签 方法二&#xff1a;闭合双引号 level3 分析 解题 level4 分析 解题 level5 分析 解题 level6 分析 解题 level7 分析 解体 level8 …

【杂记二】git, github, vscode等

一、前言 暂时空着... 二、git 2.1 可能的疑问 1. VSCode 项目名和 GitHub 仓库名是否需要一致&#xff1f; 不需要一致。 VSCode 项目名&#xff08;也就是你本地的文件夹名字&#xff09;和 GitHub 仓库名可以不一样。 Git 是一个分布式版本控制系统&#xff0c;它主要关…