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

微服务学习-Nacos 注册中心实战

1. 注册中心的设计思路

1.1. 微服务为什么会用到注册中心?

服务与服务之间调用需要有服务发现功能;例如订单服务调用库存服务,库存服务如果有多个,订单服务到底调用那个库存服务呢(负载均衡器),如果某个库存服务不可用了(心跳上报),如何知道不可用呢,这里就牵涉到服务的注册与发现。

1.2. 如何设计一个注册中心?

注册中心肯定需要存储服务的信息,服务的 ip 和端口,健康状态等,服务的注册与发现功能,心跳上报,健康检查功能是必要的。

1.3. 注册中心应该包含哪些常见功能?

服务的注册与发现、服务的健康检查、服务心跳,集群的话可能就需要服务同步。

1.4. 注册中心的设计思路

2. Nacos 注册中心核心概念和功能

2.1. 核心概念

官网 Nacos 的概念及架构:Nacos 概念 | Nacos 官网

  • 服务(Service)

服务是指一个或一组软件功能(例如特定信息的检索或一组操作的执行),其目的是不同的客户端可以为不同的目的重用(例如通过跨进程的网络调用)。

  • 服务注册中心(Service Registry)

服务注册中心,它是服务,其实例及源数据的数据库。

  • 服务元数据(Service Metadata)

服务元数据是指包括服务端点(endpoints)、服务标签、服务版本号、服务实例权重、路由规则、安全策略等描述服务的数据。Nacos数据(如配置和服务)描述信息,如服务版本、权重、容灾策略、负载均衡策略、鉴权配置、各种自定义标签 (label),从作用范围来看,分为服务级别的元信息、集群的元信息及实例的元信息。

  • 命名空间(Namespace)

用来进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 DataID 的配置。

Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。

  • 服务分组(Group)

不同的服务可以归类到同一分组。

2.2. 核心功能

  • 服务注册

Nacos Client 会通过发送 REST 请求的方式向 Nacos Server 注册自己的服务,提供自身的元数据,比如 ip 地址、端口等信息。Nacos Server 接受到注册请求后,就会把这些元数据信息存储在一个双层的内存 Map 中。

  • 服务心跳

在服务注册后,Nacos Client 会维护一个定时心跳来持续通知 Nacos Server,说明服务一直处于可用状态,防止被剔除。默认 5s 发送一次心跳。

  • 服务同步

Nacos Server 集群之间会互相同步服务实例,用来保证服务信息的一致性。

  • 服务发现

服务消费者(Nacos Client)在调用服务提供者的服务时,会发送一个 REST 请求给 Nacos Server,获取上面注册的服务清单,并且缓存在 Nacos Client 本地,同时会在 Nacos Client 本地开启一个定时任务定时拉取服务端最新的注册表信息更新到本地缓存。

  • 服务健康检查

Nacos Server 会开启一个定时任务用来检查注册服务实例的健康情况,对于超过 15s 没有收到客户端心跳的实例会将它的 healthy 属性置为 false (客户端服务发现时不会发现),如果某个实例超过 30s 没有收到心跳,直接剔除该实例(被剔除的实力如果恢复发送心跳则会重新注册)。

3. 微服务整合 Nacos 注册中心常用配置项详解

3.1. 准备测试环境

会员服务:icoolkj-mall-user

订单服务:icoolkj-mall-order01

速通版:git checkout v2.0.0 版本:

icoolkj-microservices-code 标签 - Gitee.com

启动服务,获取会员订单信息:

http://localhost:8580/api/user/getOrderByUserId?userId=1

3.2. 服务逻辑隔离配置

3.2.1. 数据模型

Nacos 数据模型 Key 由三元组唯一确定,Namespace 默认是空串,公共命名空间(public),分组默认是 DEFAULT_GROUP。

3.2.2. Namespace 隔离设计

命名空间(Namespace)用于进行租户(用户)粒度的隔离,Namespace 的常用场景之一是不同环境的隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。

3.2.2.1. 在 nacos 控制台创建一个 dev 的命名空间

3.2.2.2. 配置订单服务 namespace 为 dev
cloud:nacos:discovery:server-addr: icoolkj-mall-nacos-server:8848namespace: dev  # 指定 dev 开发环境命名空间
3.2.2.3. 重启订单服务,测试

用户调用订单接口能否查询到订单信息

问题:无法调用订单服务,提示:No instances available for icoolkj-mall-order01

原因:icoolkj-mall-order01 和 icoolkj-mall-user 使用了不同的 namespace,导致服务隔离,icoolkj-mall-user 无法发现可用的 icoolkj-mall-order01 服务。

3.2.3. group 服务分组隔离

不同的服务可以归类到同一个分组,group 也可以起到服务隔离的作用,yml 中可以通过 spring.cloud.nacos.discovery.group 参数配置。group 更多应用场景是配置分组。

3.2.3.1. 配置订单服务分组为 group1
cloud:nacos:discovery:server-addr: icoolkj-mall-nacos-server:8848namespace: dev  # 指定 dev 开发环境命名空间group: group1 # 指定 group1 分组
3.2.3.2. 重启订单服务,测试

用户调用订单接口能否查询到订单信息

问题:无法调用订单服务,提示:No instances available for icoolkj-mall-order01

原因:icoolkj-mall-order01 和 icoolkj-mall-user 使用了不同的分组,导致服务隔离,icoolkj-mall-user 无法发现可用的 icoolkj-mall-order01 服务。

3.3. 服务领域模型

注册中心的核心数据是服务名称和它对应的网络地址,当服务注册了多个实例时,需要对不健康的实力进行过滤或者对实例的一些特征进行流量的分配,就需要再实例上存储一些例如 IP、端口、健康状态、权重等属性。随着服务的规模扩大,需要再整个服务级别设定一些权限规则,以及对所有实例都生效的一些开关,于是在服务级别又会设立一些属性。我们发现单个服务的实力又会划分为多个子集的需求,例如一个服务是多个机房部署的,可能需要对每个机房的实例做不同的胚子,这样有需要在服务和实例之间再设定一个数据级别。

Nacos 在经过内部多年生产经验,提炼除的数据模型,则是一种服务-集群-实例的三层模型。这样基本可以满足服务在所有场景下的数据存储和管理。

3.3.1. 集群配置
spring:cloud:nacos:discovery:server-addr: icoolkj-mall-nacos-server:8848namespace: dev  # 指定 dev 开发环境命名空间#group: group1 # 指定 group1 分组cluster-name: BJ # 指定集群名称 北京机房

重启订单服务,测试,不同的集群的微服务之间是可以调用的,一般情况不隔离;可以实现本地集群优先调用,例如上海订单先调用上海机房集群,如果上海集群出问题了,可以调用其他地方集群。

3.3.2. 临时实例和持久化实例
3.3.2.1. 健康检查的方式

临时实例使用客户端上报模式,需要能够自动摘除不健康实例,而且无需持久化存储实例。

持久化实例使用服务端探测的健康检查方式,因为客户端不会上报心跳,所以不能自动摘除下线的实例。

3.3.2.2. 适用场景

上层业的业务服务,例如订单服务,库存服务都可以上报心跳,都是临时实例;

一些基础的组件例如数据库、缓存等,这些往往不能上报心跳,这种类型的服务在注册时,就需要作为持久化实例注册。

3.3.2.3. 如何配置
# 持久化实例
spring.cloud.nacos.discovery.ephemeral: false

Nacos 默认注册的都是临时实例。

常见错误:

Current service DEFAULT_GROUP@@icoolkj-mall-order01 is ephemeral service, can't register persistent instance. 在 Nacos2.0 中将是否持久化的数据抽象至服务级别,且不再允许一个服务同时存在持久化实例和非持久化实例,实例的持久化属性继承自服务的持久化属性。

The Raft Group [naming_persistent_service_v2] did not find the Leader node 要配置持久化实例必须得是 nacos 集群模式。

3.4. Nacos 安全配置

官方参考文档:配置鉴权 | Nacos 官网

Nacos 是一个内部微服务组件,需要在可信的内部网络中运行,不可暴露在公网环境,防止带来安全风险。

3.4.1. 如何实现安全配置
3.4.1.1. nacos server 端

nacos-server-2.3.2/nacos/conf/application.properties 添加如下配置:

# 开启认证
nacos.core.auth.enabled=true
# 配置自定义身份识别的key(不可为空)和value(不可为空)
#这两个属性是auth的白名单,用于标识来自其他服务器的请求。
#具体实现见 com.alibaba.nacos.core.auth.AuthFilter
# 用于服务端api鉴权,注意:并不是nacos的用户名密码
nacos.core.auth.server.identity.key=authKey
nacos.core.auth.server.identity.value=nacosSecurty# 默认鉴权插件用于生成用户登陆临时accessToken所使用的密钥,使用默认值有安全风险  (2.2.0.1后无默认值)
#自定义密钥时,推荐将配置项设置为Base64编码的字符串,且原始密钥长度不得低于32字符。
nacos.core.auth.plugin.nacos.token.secret.key=pDEYqLTBvWAp16osN6dxLvZTo9RfNsY3DfhI

注意:在2.2.0.1版本后,社区发布版本需要自行填充nacos.core.auth.plugin.nacos.token.secret.key的值,否则无法启动节点。

随机字符串生产工具:随机字符串生成 - 程序员工具箱 - 在线工具

注意:鉴权开关是修改之后立马生效的,不需要重启服务端。

3.4.1.2. nacos client 端

nacos server 开启鉴权后,微服务提示 user not found!

微服务的 application.yml 中添加如下配置:

spring:application:name: icoolkj-mall-usercloud:nacos:discovery:server-addr: icoolkj-mall-nacos-server:8848namespace: dev  # 指定 dev 开发环境命名空间#group: group1 # 指定 group1 分组#cluster-name: BJ # 指定集群名称 北京机房username: nacospassword: nacos

默认用户名密码都是 nacos,可以在 ncaos 控制台创建新用户。

4. Nacos 高可用集群最佳实践

4.1. nacos 部署方式

单机模式:用于测试和单机使用。默认使用的是 derby 数据库。

注意:单机模式下 Linux 运行Nacos:sh startup.sh -m standalone

集群模式:用于生产环境,确保高可用。

4.2. 官方文档

集群部署说明

4.3. 集群部署架构图

最终方案:nginx + 三个节点 nacos 集群 + mysql

为保证数据一致性,集群环境需要用 mysql(三个节点都可以访问到 mysql)替换内部的 derby 数据库。

4.4. 搭建步骤

官方部署手册:Nacos支持三种部署模式

4.4.1. 前期环境准备
4.4.1.1. 三台 Linux 虚拟机
# 准备三台 centOS7 服务器
200.8.9.16:8848
200.8.9.17:8848
200.8.9.18:8848

安装好 JDK,需要 1.8 及其以上版本;建议:2 核 CPU,4G 内存及其以上。

注意:nacos2.3.2 不能使用 OpenJDK,会出现开启鉴权后控制台无论使用什么密码登录都显示账号密码错误问题。

4.4.1.2. 准备好 Nacos2.3.2 的安装包

下载地址:发布历史 | Nacos 官网

4.4.2. 配置集群配置文件

在 nacos 的解压目录 nacos/的conf 目录下,有配置文件 cluster.conf,请每行配置成 ip:port。

#解压进入nacos 安装目录
unzip nacos-server-2.3.2.zip
cd nacos/
mv conf/cluster.conf.example conf/cluster.conf
vim  conf/cluster.conf# ip:port 
200.8.9.16:8848
200.8.9.17:8848
200.8.9.18:8848

注意:不要使用 localhost 或 127.0.0.1,针对多网卡环境,Nacos 可以指定网卡或 IP

当本地环境比较复杂的时候,Nacos 服务在启动的时候需要选择运行时使用的 IP 或者网卡。

#多网卡IP选择
# ip-address 参数可以直接设置 nacos 的 ip
#该参数设置后,将会使用这个 IP 去 cluster.conf 里进行匹配,请确保这个 IP 的值在 cluster.conf 里是存在的
nacos.inetutils.ip-address=200.8.9.16# use-only-site-local-interfaces 参数可以让nacos使用局域网 ip ,这个在 nacos 部署的机器有多网卡时很有用,可以让 nacos 选择局域网网卡
nacos.inetutils.use-only-site-local-interfaces=true# ignored-interfaces 支持网卡数组,可以让 nacos 忽略多个网卡
nacos.inetutils.ignored-interfaces[0]=eth0
nacos.inetutils.ignored-interfaces[1]=eth1# preferred-networks 参数可以让 nacos 优先选择匹配的 ip,支持正则匹配和前缀匹配
nacos.inetutils.preferred-networks[0]=200.8.9.
nacos.inetutils.preferred-networks[0]=200.8.9.(25[0-5]|2[0-4]\\d|((1d{2})|([1-9]?\\d))),200.8.9.(25[0-5]|2[0-4]\\d|((1d{2})|([1-9]?\\d)))
4.4.3. 开启默认鉴权插件

修改 conf 目录下的 application.properties 文件

nacos.core.auth.enabled=true
nacos.core.auth.server.identity.key=${自定义,保证所有节点一致}
nacos.core.auth.server.identity.value=${自定义,保证所有节点一致}
nacos.core.auth.plugin.nacos.token.secret.key=${自定义,保证所有节点一致}
4.4.4. 配置数据源

使用外置 mysql 数据源,生产使用建议至少主备模式

4.4.4.1. 初始化 mysql 数据库

sql 脚本:nacos-server-2.3.2/nacos/conf/mysql-schema.sql

4.4.4.2. 修改 application.properties 配置
spring.sql.init.platform=mysql
db.num=1
db.url.0=jdbc:mysql://200.8.9.16:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=root
db.password.0=123456
4.4.4.3. 常见错误

java.lang.RuntimeException: [db-load-error]load jdbc.properties error

检查 nacos 的 mysql 连接,数据库的 ip、数据库、用户名和密码。

4.4.5. 分别启动三个 nacos 节点

以 200.8.9.16 为例,进入 nacos 目录,启动 nacos。

sh bin/startup.sh

4.4.6. 访问 nacos 管理界面

登录 200.8.9.16:8848/nacos,用户名和密码默认都是 nacos

5. 小结

通过 Nacos 注册中心可以实现微服务的注册与发现。生产环境搭建高可用集群模式。

相关文章:

微服务学习-Nacos 注册中心实战

1. 注册中心的设计思路 1.1. 微服务为什么会用到注册中心? 服务与服务之间调用需要有服务发现功能;例如订单服务调用库存服务,库存服务如果有多个,订单服务到底调用那个库存服务呢(负载均衡器)&#xff0…...

k8s服务StatefulSet部署模板

java 服务StatefulSet部署模板 vim templates-test.yamlapiVersion: apps/v1 kind: StatefulSet metadata:labels:app: ${app_labels}name: ${app_name}namespace: ${app_namespace} spec:replicas: ${app_replicas_count}selector:matchLabels:app: ${app_labels}template:la…...

07 区块链安全技术

概述 区块链的安全特性 区块链解决了在不可靠网络上可靠地传输信息的难题,由于不依赖与中心节点的认证和管理,因此防止了中心节点被攻击造成的数据泄露和认证失败的风险。 区块链安全防护的三大特点 共识机制代替中心认证机制数据篡改“一发动全身”…...

Adobe的AI生成3D数字人框架:从自拍到生动的3D化身

一、引言 随着人工智能技术的发展,我们见证了越来越多创新工具的出现,这些工具使得图像处理和视频编辑变得更加智能与高效。Adobe作为全球领先的创意软件公司,最近推出了一项令人瞩目的新技术——一个能够将普通的二维自拍照转换成栩栩如生的三维(3D)数字人的框架。这项技…...

dfs专题四:综合练习

key:画出决策树(就是找个简单例子模拟一下的树状决策图) dfs传参 or 全局变量: int, double等常量/比较小的变量,可以dfs参数传递vector等线性O(N)变量,要用全局变量 回溯&#x…...

【线性代数】列主元法求矩阵的逆

列主元方法是一种用于求解矩阵逆的数值方法,特别适用于在计算机上实现。其基本思想是通过高斯消元法将矩阵转换为上三角矩阵,然后通过回代求解矩阵的逆。以下是列主元方法求解矩阵 A A A 的逆的步骤: [精确算法] 列主元高斯消元法 步骤 1&am…...

大写——蓝桥杯

1.题目描述 给定一个只包含大写字母和小写字母的字符串,请将其中所有的小写字母转换成大写字母后将字符串输出。 输入描述 输入一行包含一个字符串。 输出描述 输出转换成大写后的字符串。 输入输出样例 示例 输入 LanQiao输出 LANQIAO评测用例规模与约定 对…...

HTML `<head>` 元素详解

在 HTML 文档中&#xff0c;<head> 元素是一个非常重要的部分&#xff0c;它包含了文档的元数据&#xff08;metadata&#xff09;和其他与文档相关的信息。虽然 <head> 中的内容不会直接显示在网页上&#xff0c;但它对网页的行为、样式和搜索引擎优化&#xff08…...

一文速通stack和queue的理解与使用

CSTL之stack和queue 1.stack1.1.stack的基本概念1.2.stack的接口 2.queue2.1.queue的基本概念2.2.queue的接口 3.priority_queue3.1.priority_queue的基本概念3.2.priority_queue的接口3.3.仿函数 4.容器适配器5.deque5.1.deque的简单了解5.2.deque的优缺点 &#x1f31f;&…...

Antd React Form使用Radio嵌套多个Select和Input的处理

使用Antd React Form使用Radio会遇到嵌套多个Select和Input的处理&#xff0c;需要多层嵌套和处理默认事件和冒泡&#xff0c;具体实现过程直接上代码。 实现效果布局如下图 代码 <Formname"basic"form{form}labelWrap{...formItemLayoutSpan(5, 19)}onFinish{on…...

Vue - toRefs() 和 toRef() 的使用

一、toRefs() 在 Vue 3 中,toRefs()可以将响应式对象的属性转换为可响应的 refs。主要用于在解构响应式对象时&#xff0c;保持属性的响应性。 1. 导入 toRefs 函数 import { toRefs } from vue;2. 将响应式对象的属性转换为 ref const state reactive({count: 0,message:…...

Python3 OS模块中的文件/目录方法说明九

一. 简介 前面文章简单学习了 Python3 中 OS模块中的文件/目录的部分函数。 本文继续来学习 OS 模块中文件、目录的操作方法&#xff1a;os.pipe() 方法、os.popen() 方法。 二. Python3 OS模块中的文件/目录方法 1. os.pipe() 方法 os.pipe() 方法用于创建一个管道, 返回…...

OpenCV文字绘制支持中文显示

OpenCV版本&#xff1a;4.4 IDE&#xff1a;VS2019 功能描述 OpenCV绘制文本的函数putText()不支持中文的显示&#xff0c;网上很多方法推荐的都是使用FreeType来支持&#xff0c;FreeType是什么呢&#xff1f;FreeType的官网上有介绍 FreeType官网 https://www.freetype.or…...

opengrok_windows_多工程环境搭建

目录 多工程的目录 工程代码下载和log配置 工程的索引 工程部署 工程测试 参考列表 多工程的目录 工程代码下载和log配置 工程代码下载 在每个工程的src目录下&#xff0c;下载工程代码&#xff0c;以下载pulseaudio的代码为例。 git clone gitgithub.com…...

基于ollama,langchain,springboot从零搭建知识库三【解析文档并存储到向量数据库】

安装环境 安装pgvector&#xff0c;先设置docker镜像源&#xff1a; vim /etc/docker/daemon.json {"registry-mirrors": ["https://05f073ad3c0010ea0f4bc00b7105ec20.mirror.swr.myhuaweicloud.com","https://mirror.ccs.tencentyun.com",&…...

Elasticsearch 和arkime 安装

安装一定要注意版本号&#xff0c;不然使用不了 这里Ubuntu使用ubuntu-20.04.6-desktop-amd64.iso elasticsearch这里使用Elasticsearch 7.17.5 | Elastic arkime这里使用wget https://s3.amazonaws.com/files.molo.ch/builds/ubuntu-20.04/arkime_3.4.2-1_amd64.deb 大家想…...

git回退

git回退 1、未使用 git add 缓存代码时 git checkout –- filepathname 放弃单个文件的修改 git checkout . 放弃所有的文件修改 此命令用来放弃掉所有还没有加入到缓存区&#xff08;就是 git add 命令&#xff09;的修改&#xff1a;内容修改与整个文件删除。但是此命令不…...

pytest+playwright落地实战大纲

前言 很久没有更新博客&#xff0c;是因为在梳理制作Playwright测试框架实战相关的课程内容。现在课程已经完结&#xff0c;开个帖子介绍下这门课程&#xff08;硬广, o(〃&#xff3e;▽&#xff3e;〃)o&#xff09; 课程放在CSDN学习频道&#xff0c; 欢迎关注~ PyTestPl…...

01-硬件入门学习/嵌入式教程-CH340C使用教程

前言 CH340C广泛应用于DIY项目和嵌入式开发中&#xff0c;用于USB数据转换和串口通信。本文将详细介绍CH340C的基本功能、引脚接线及使用方法。 CH340C简介 CH340C是一款USB转TTL电平转换器&#xff0c;可以将电脑的USB数据转换成串口数据&#xff0c;方便与单片机&#xff…...

小试牛刀调整Prompt,优化Token消耗

在上一篇文章 荒腔走板Mac电脑本地部署 LLM 中介绍过本地部署大模型之后&#xff0c;可以通过定制 prompt 来实现 domain 提取等各种各样的需求。 但是实际上&#xff0c;部署本地大模型 这种方式对于个人开发者来说实在是不太友好。一方面需要投入大量资金确保设备的算力足够支…...

C++初阶-list的底层

目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...

ubuntu搭建nfs服务centos挂载访问

在Ubuntu上设置NFS服务器 在Ubuntu上&#xff0c;你可以使用apt包管理器来安装NFS服务器。打开终端并运行&#xff1a; sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享&#xff0c;例如/shared&#xff1a; sudo mkdir /shared sud…...

练习(含atoi的模拟实现,自定义类型等练习)

一、结构体大小的计算及位段 &#xff08;结构体大小计算及位段 详解请看&#xff1a;自定义类型&#xff1a;结构体进阶-CSDN博客&#xff09; 1.在32位系统环境&#xff0c;编译选项为4字节对齐&#xff0c;那么sizeof(A)和sizeof(B)是多少&#xff1f; #pragma pack(4)st…...

为什么需要建设工程项目管理?工程项目管理有哪些亮点功能?

在建筑行业&#xff0c;项目管理的重要性不言而喻。随着工程规模的扩大、技术复杂度的提升&#xff0c;传统的管理模式已经难以满足现代工程的需求。过去&#xff0c;许多企业依赖手工记录、口头沟通和分散的信息管理&#xff0c;导致效率低下、成本失控、风险频发。例如&#…...

Leetcode 3577. Count the Number of Computer Unlocking Permutations

Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接&#xff1a;3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯&#xff0c;要想要能够将所有的电脑解锁&#x…...

C++使用 new 来创建动态数组

问题&#xff1a; 不能使用变量定义数组大小 原因&#xff1a; 这是因为数组在内存中是连续存储的&#xff0c;编译器需要在编译阶段就确定数组的大小&#xff0c;以便正确地分配内存空间。如果允许使用变量来定义数组的大小&#xff0c;那么编译器就无法在编译时确定数组的大…...

【Android】Android 开发 ADB 常用指令

查看当前连接的设备 adb devices 连接设备 adb connect 设备IP 断开已连接的设备 adb disconnect 设备IP 安装应用 adb install 安装包的路径 卸载应用 adb uninstall 应用包名 查看已安装的应用包名 adb shell pm list packages 查看已安装的第三方应用包名 adb shell pm list…...

day36-多路IO复用

一、基本概念 &#xff08;服务器多客户端模型&#xff09; 定义&#xff1a;单线程或单进程同时监测若干个文件描述符是否可以执行IO操作的能力 作用&#xff1a;应用程序通常需要处理来自多条事件流中的事件&#xff0c;比如我现在用的电脑&#xff0c;需要同时处理键盘鼠标…...

Web后端基础(基础知识)

BS架构&#xff1a;Browser/Server&#xff0c;浏览器/服务器架构模式。客户端只需要浏览器&#xff0c;应用程序的逻辑和数据都存储在服务端。 优点&#xff1a;维护方便缺点&#xff1a;体验一般 CS架构&#xff1a;Client/Server&#xff0c;客户端/服务器架构模式。需要单独…...

Vue 模板语句的数据来源

&#x1f9e9; Vue 模板语句的数据来源&#xff1a;全方位解析 Vue 模板&#xff08;<template> 部分&#xff09;中的表达式、指令绑定&#xff08;如 v-bind, v-on&#xff09;和插值&#xff08;{{ }}&#xff09;都在一个特定的作用域内求值。这个作用域由当前 组件…...