SpringCloud(21)之SpringCloud Alibaba Nacos实战应用
一、Nacos安装
1.1 Nacos概述
Nacos是Alibaba微服务生态组件中的重要组件之一,主要用它实现应用的动态服务发现、配置管理、 服务管理。Nacos discovery · alibaba/spring-cloud-alibaba Wiki · GitHub

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。
Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理::
1.Kubernetes Service
2.gRPC & Dubbo RPC Service
3.Spring Cloud RESTful Service
Nacos 的关键特性包括:
- 服务发现和服务健康监测
Nacos 支持基于 DNS 和基于 RPC 的服务发现。服务提供者使用 原生SDK、OpenAPI、或一个独立的Agent TODO注册 Service 后,服务消费者可以使用DNS TODO 或HTTP&API查找和发现服务。
Nacos 提供对服务的实时的健康检查,阻止向不健康的主机或服务实例发送请求。Nacos 支持传输层 (PING 或 TCP)和应用层 (如 HTTP、MySQL、用户自定义)的健康检查。 对于复杂的云环境和网络拓扑环境中(如 VPC、边缘网络等)服务的健康检查,Nacos 提供了 agent 上报模式和服务端主动检测2种健康检查模式。Nacos 还提供了统一的健康检查仪表盘,帮助您根据健康状态管理服务的可用性及流量。
- 动态配置服务
动态配置服务可以让您以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置。
动态配置消除了配置变更时重新部署应用和服务的需要,让配置管理变得更加高效和敏捷。配置中心化管理让实现无状态服务变得更简单,让服务按需弹性扩展变得更容易。
Nacos 提供了一个简洁易用的UI (控制台样例 Demo) 帮助您管理所有的服务和应用的配置。Nacos 还提供包括配置版本跟踪、金丝雀发布、一键回滚配置以及客户端配置更新状态跟踪在内的一系列开箱即用的配置管理特性,帮助您更安全地在生产环境中管理配置变更和降低配置变更带来的风险。
- 动态 DNS 服务
动态 DNS 服务支持权重路由,让您更容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单DNS解析服务。动态DNS服务还能让您更容易地实现以 DNS 协议为基础的服务发现,以帮助您消除耦合到厂商私有服务发现 API 上的风险。
- 服务及其元数据管理
Nacos 能让您从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述、生命周期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略、服务的 SLA 以及最首要的 metrics 统计数据。
1.2 Nacos地图

- 特性大图:要从功能特性,非功能特性,全面介绍我们要解的问题域的特性诉求;
- 架构大图:通过清晰架构,让您快速进入 Nacos 世界;
- 业务大图:利用当前特性可以支持的业务场景,及其最佳实践;
- 生态大图:系统梳理 Nacos 和主流技术生态的关系;
- 优势大图:展示 Nacos 核心竞争力;
- 战略大图:要从战略到战术层面讲 Nacos 的宏观优势;
1.3 Nacos生态图 
1.4 Nacos安装
关于Nacos安装,可以直接参考官网安装 Nacos 快速开始 ,我们接下来 学习基于Docker实现Nacos单机安装和基于Docker实现Nacos集群安装。
采用Docker-Compose安装Nacos要更方便,所以大家可以先学习一下Docker-Compose。
1.4.1 Nacos安装
nacos安装模式有很多种:
单机模式 Derby:这种模式是极简模式,数据没法持久化存储,适合开发环境。
单机模式 MySQL:(支持MySQL5.7和MySQL5.8,我们这里学习MySQL5.7安装模式,因为当前主流还是 MySQL5.7),这种模式支持数据持久化,数据会存储到MySQL中,适合生产环境。
集群模式:这种模式适合生产环境并且服务节点个数较多,不存在单点故障问题。
安装如下:
#克隆项目
git clone https://github.com/nacos-group/nacos-docker.git#进入nacos-docker目录
cd nacos-docker#查看文件列表
cd example
ll
文件列表如下:

1.4.1.1 Nacos Derby安装
安装Nacos生产环境会结合prometheus和grafana实现对Nacos的监控,我们这里不做它们的监控操作,需要将docker-compose的配置注释掉,修改 example/standalone-derby.yaml ,配置如下:

安装命令如下:
docker-compose -f example/standalone-derby.yaml up
安装完成后,我们可以直接访问它的控制台 http://localhost:8848/nacos ,账号密码都是 nacos ,效果如下:

1.4.1.2docker 安装nacos
我们也可以直接采用Docker的方式安装Nacos,这样安装不要克隆项目也不需要修改配置文件,会更方 便,安装命令如下:
clone项目:
git clone https://github.com/nacos-group/nacos-docker.git
cd nacos-docker
运行命令如下:
docker run -d \
-e MODE=standalone \
-e SPRING_DATASOURCE_PLATFORM=mysql \
-e MYSQL_SERVICE_HOST=192.168.211.145 \
-e MYSQL_SERVICE_PORT=3306 \
-e MYSQL_SERVICE_USER=root \
-e MYSQL_SERVICE_PASSWORD=123456 \
-e MYSQL_SERVICE_DB_NAME=nacos_config \
-p 8848:8848 \
--restart=always \
--name nacos nacos/nacos-server
访问 http://localhost:8848/nacos/#/login 效果如下:

二、Nacos功能应用
2.1 Nacos服务注册与发现
服务发现是微服务架构体系中最关键的组件之一。如果尝试着用手动的方式来给每一个客户端来配置所 有服务提供者的服务列表是一件非常困难的事,而且也不利于 服务的动态扩缩容。Nacos Discovery Starter 可以帮助您将服务自动注册到 Nacos 服务端并且能够动态感知和刷新某个服务实例的服务列表。除此之外,Nacos Discovery Starter 也将服务实例自身的一些元数据信息-例如 host ,port,健康检 查URL,主页等-注册到 Nacos 。
接下来我们学习一下如何使用Nacos作为服务的注册中心,并实现服务注册和服务发现。当前项目开发 主流技术是SpringBoot,我们就讲解基于SpringBoot如何使用Nacos实现服务注册与发现。

如上图,我们以打车项目为例,当用户打车成功的时候,会调用 hailtaxi-order , hailtaxi-order 会下订单,同时修改司机状态,修改状态需要调用 hailtaxi-driver ,我们把 hailtaxi-order 服务 和 hailtaxi-driver 服务都注册到Nacos中,并实现服务调用,如果整个调用都没有问题,就说明服务 注册发现没问题。
关于SpringCloud Alibaba和SpringBoot的版本,我们可以通过以下链接查 看。https://start.spring.io/actuator/info
https://start.spring.io/actuator/info 
bootstrap.yml ( bootstrap.properties )用来在程序引导时执行,应用于更加早期配置信息读 取,如可以使用来配置 application.yml 中使用到参数等。
application.yml ( application.properties) 应用程序特有配置信息,可以用来配置后续各个模 块中需使用的公共参数等。
bootstrap.yml 先于 application.yml 加载。
项目中如果使用Nacos,需要使用 bootstrap.yml ,因此我们需要将项目中的 application.yml换成 bootstrap.yml 。
我们修改 hailtaxi-driver 的 application.yml 改名为 bootstrap.yml ,注释掉consul,并且添加 如下配置:
server:port: 18081
#Nacos配置
spring:profiles:active: devapplication:name: hailtaxi-drivercloud:nacos:discovery:#Nacos服务地址server-addr: 192.168.211.145:8848config:#Nacos服务地址server-addr: 192.168.211.145:8848
相同,另外一个项目也加上面的配置,此时我们运行2个项目,可以发现在Nacos中已经注册了相关服务,如下图:

此时用Postman访问打车下单,效果如下:

发现服务正常调用没有问题,说明nacos正常注册。
2.2 负载均衡

如上图,如果此时用户打车成功,会调用订单服务,订单服务会修改司机状态,此时会调用
hailtaxi- driver,如果是生产环境,每个节点一定是集群状态,比如有2个 hailtaxi-driver节点,此时如何 实现负载均衡?

我们可以发现服务注册到Nacos中,有一个权重属性,这个权重属性就是Nacos的负载均衡机制,此时 需要用到Nacos的负载均衡策略 NacosRule ,我们可以在程序中先初始化负载均衡算法,再到bootstrap.yml中配置权重。
/**** Nacos负载均衡算法* @return*/@Bean@Scope(value="prototype")public IRule loadBalanceRule(){return new NacosRule();}
然后再在配置文件中指定每个启动实例的权重,便可以实现根据权重不同的负载均衡。
2.3 配置中心
2.3.1 配置管理
我们可以在Nacos控制台配置项目的配置数据,先打开Nacos控制台,在命名空间 中新建命名空 间 ,如下图:

在配置管理中添加配置文件:

再将项目中的配置内容拷贝到如下表单中,比如我们可以把 hailtaxi-driver原来在apollo中的配置填 写到下面表单中,如下图:

需要注意的是,DATA ID和服务名保持一致,作为程序默认加载配置。
项目中需要先引入依赖包,我们以 hailtaxi-driver 为例,在 pom.xml 中引入如下依赖:
<!--nacos-discovery--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId><version>2.2.5.RELEASE</version></dependency><!--nacos-config--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId><version>2.2.5.RELEASE</version></dependency>
配置文件中添加配置中心地址,在 hailtaxi-driver 的 bootstrap.yml 中添加如下配置:

上图配置和属性说明如下:

我们启动 hailtaxi-driver 服务,默认加载 ${spring.application.name}.${file-extension:properties} 配置,加载完成后,配置数据会生效,并访问 http://localhost:18081/driver/info/1 测试,效果如下:

如果此时配置文件名字如果和当前服务名字不一致,可以使用 name 属性来指定配置文件名字:

2.3.2 多环境切换
spring-cloud-starter-alibaba-nacos-config 在加载配置的时候,不仅仅加载了以 dataid 为
${spring.application.name}.${file-extension:properties} 为前缀的基础配置,还加载了dataid为 ${spring.application.name}- ${profile}.${file-extension:properties} 的基础配置。在日常开发中如果遇到多套环境下的不同配置,可以通过Spring 提供的${spring.profiles.active} 这个配置项来配置。
比如开发环境我们可以在nacos中创建 hailtaxi-driver-dev.yaml ,测试环境可以在配置中创建 hailtaxi-driver-test.yaml ,创建如下:
hailtaxi-driver-test.yaml

hailtaxi-driver-dev.yaml :

修改 hailtaxi-driver 的 bootstrap.yml 配置文件,如下:

测试 http://localhost:18081/trip/message 效果如下:

将 active 换成test,效果如下:

2.3.3 共享配置
在实际的业务场景中应用和共享配置间的关系可能, Spring Cloud Alibaba Nacos Config 从 0.2.1版本后,可支持自定义 Data Id 的配置,通过它可以解决配置共享问题。
我们可以先创建一个配置 datasource.yaml 用于配置数据库连接,如下图:

我们把之前的 hailtaxi-driver-dev.yaml 中的数据库连接池删掉,只保留IP,如下图:

程序中我们读取IP,修改 hailtaxi-driver 的 DriverController 中 info() 方法,注入配置文件中的

在 bootstrap.yml 中引入配置需要使用 extension-configs 属性,配置如下:

这里 extension-configs[n] 中n值越大,优先级越高,它既能解决一个应用多个配置,同时还能解决 配置共享问题。
测试访问 http://localhost:18081/driver/info/1 ,此时能访问数据库,同时也能获取 hailtaxi-driver-dev.yaml 中的配置,效果如下:

2.3.4配置刷新
配置自动刷新对程序来说非常重要,Nacos支持配置自动刷新,并且提供了多种刷新机制。
程序中如果写了 @Value 注解,可以采用 @RefreshScope 实现刷新,只需要在指定类上添加该注解即可,如下代码:

2.3.5 灰度发布
修改配置内容,点击“发布Beta”按钮,即可完成灰度配置的发布,点击“发布Beta”后,“发布Beta”按钮 变灰,此时可以选择“停止Beta”或者“发布”。“停止Beta”表示取消停止灰度发布,当前灰度发布配置的IP 列表和配置内容都会删除,页面回到正常发布的样式。“发布”表示将灰度配置在所有客户端生效,之前 的配置也会被覆盖,同时页面回到正常发布的样式:

三、Nacos集群
在生产环境Nacos一般都不是单节点存在,如果是单节点,很容易存在单点故障,因此生产环境一般都 以集群形式存在。
3.1 集群架构
Nacos集群模式有多种,但其实无论哪种都是将3个Nacos服务进行集群发布,而且必须采用数据共享模 式进行配置信息共享,也就是要将数据存入到同一个数据库中,我们对每种集群模式进行说明:
1)直连模式:
http://ip1:port/openAPI 直连ip模式,机器挂则需要修改ip才可以使用。 比如我现在有3个Nacos,每次操作数据的时候,都需要使用IP:端口的模式,这种模式效率极低,并 且一旦节点故障无法识别,因此官方不推荐这种模式。
2)VIP模式:
http://SLB:port/openAPI 挂载SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),直连SLB即可,下面挂server真实ip,可读性不好。
3)域名模式:
http://nacos.com:port/openAPI 域名 + SLB模式(内网SLB,不可暴露到公网,以免带来安全风险),可读性好,而且换ip方便,推荐模式。

3.2 集群部署
我们搭建Nacos集群环境,集群环境配置如下:

1)服务下载
在 https://github.com/alibaba/nacos/releases/ 下载需要的服务,当前使用的是1.4.1, 我们可以 选择下载1.4.1版本,版本如下:

解压缩后:

2)配置数据库
修改 conf/application.properties 配置数据库,配置如下:

3)集群配置
修改 conf/cluster.conf 配置集群:

4)配置同步
将上面那台服务器配置好的nacos发送到另外两台服务器上:

5)分别启动每一个节点

访问任何一个单节点,信息如下:

一般客户端访问,可以再前置环节访问nginx,然后通过nginx负载到每个nacos节点上,那我们服务配置只需要单独配置nginx的域名地址。
相关文章:
SpringCloud(21)之SpringCloud Alibaba Nacos实战应用
一、Nacos安装 1.1 Nacos概述 Nacos是Alibaba微服务生态组件中的重要组件之一,主要用它实现应用的动态服务发现、配置管理、 服务管理。Nacos discovery alibaba/spring-cloud-alibaba Wiki GitHub Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简…...
Python 基础语法:基本数据类型(元组)
1 元组(Tuples)概述 1.1 元组的定义与特点 元组(Tuples)是Python中的一个内置数据类型,用于存储一系列有序的元素。元组中的元素可以是任何类型,包括数字、字符串、列表等,且元素之间用逗号…...
vuepress-theme-vdoing博客搭建教程
搭建流程 前言 这是笔者搭建个人博客所经历的流程,特附上笔记 笔者个人博客地址:沉梦听雨的编程指南 一、主题介绍 本博客使用的主题为:vuepress-theme-vdoing,相关介绍和使用方法可以参考该主题的官方文档 官方文档快速上手…...
ICC2:create terminal参考脚本
我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 set list "" set i 0 ; set length xx set width xx foreach port $list { if {$i == 0} { set startx 0 set starty 0 } else { set sta…...
并行计算CUDA DEMO
//并行计算CUDA DEMO #include "cuda_runtime.h" #include "device_launch_parameters.h" #include <stdio.h> cudaError_t addWithCuda(int *c, const int *a, const int *b, unsigned int size); __global__ void addKernel(int *c, const int …...
【linux线程(一)】什么是线程?怎样操作线程?
💓博主CSDN主页:杭电码农-NEO💓 ⏩专栏分类:Linux从入门到精通⏪ 🚚代码仓库:NEO的学习日记🚚 🌹关注我🫵带你学更多操作系统知识 🔝🔝 Linux线程 1. 前言2. 什么是线…...
python-0002-linux安装pycharm
下载软件包 下载地址:https://download.csdn.net/download/qq_41833259/88944791 安装 # 解压 tar -zxvf 你的软件包 # 进入软件解压后的路径,如解压到了/home/soft/pycharm cd /home/soft/pycharm cd bin # 执行启动命令 sh pycharm.sh # 等待软件启…...
扭蛋机小程序,扭蛋与互联网结合下的商机
扭蛋机作为一种娱乐消费模式,受众群体不再局限于儿童,也吸引了众多的年轻消费者。扭蛋机具有较大的随机性,玩具商品随机掉落,在购买前消费者完全不知道扭蛋中的商品是什么,这种未知性带来的惊喜感是吸引众多消费者的主…...
pytorch CV入门3-预训练模型与迁移学习
专栏链接:https://blog.csdn.net/qq_33345365/category_12578430.html 初次编辑:2024/3/7;最后编辑:2024/3/8 参考网站-微软教程:https://learn.microsoft.com/en-us/training/modules/intro-computer-vision-pytorc…...
Swift SwiftUI 学习笔记 2024
Swift SwiftUI 学习笔记 2024 一、资源 视频资源 StanfordUnivercity 公开课 2023: https://cs193p.sites.stanford.edu/2023 教程 Swift 初识:基础语法:https://docs.swift.org/swift-book/documentation/the-swift-programming-language/guidedtour/…...
【Stable Diffusion】入门:原理简介+应用安装(Windows)+生成步骤
【Stable Diffusion】入门:原理简介应用安装(Windows)生成步骤 原理简介应用安装 原理简介 稳定扩散生成模型(Stable Diffusion)是一种潜在的文本到图像扩散模型,能够在给定任何文本输入的情况下生成照片般逼真的图像。 应用安…...
【栈】第十二届蓝桥杯省赛第一场C++ B组/研究生组《双向排序》(c++)
【题目描述】 给定序列 (a1,a2,⋅⋅⋅,an)(1,2,⋅⋅⋅,n),即 aii。 小蓝将对这个序列进行 m 次操作,每次可能是将 a1,a2,⋅⋅⋅,aqi 降序排列,或者将 aqi,aqi1,⋅⋅⋅,an 升序排列。 请求出操作完成后的序列。 【输入格式】 输入的第一行…...
Gitea 安装和配置
Gitea 安装和配置: http://coffeelatte.vip.cpolar.top/post/software/applications/gitea/gitea_安装和配置/ 文章目录 Gitea 安装和配置: <http://coffeelatte.vip.cpolar.top/post/software/applications/gitea/gitea_%E5%AE%89%E8%A3%85%E5%92%8C%E9%85%8D%E7%BD%AE/>…...
CEF JS与c++能够交互的原理 以及 JS 调用C++的流程分析
相关章节:CEF 之 Render进程 与 Browser进程通信 目录 一、JS与c++能够交互的原理 二、JS调用C++ 流程梳理...
关于比特币的AI对话
【ChatGPT】 比特币源码开源吗? 是的,比特币的源码是开源的。比特币项目是在MIT许可证下发布的,这意味着任何人都可以查看、修改、贡献和分发代码。比特币的源码托管在GitHub上,可以通过下面的链接进行访问: https://g…...
Linux查看磁盘命令df-h详解
df -h 是一个常用的 Linux 命令,用于查看文件系统的磁盘使用情况并以易于阅读的方式显示。以下是 df -h 命令的详细解释: -h:以人类可读的格式显示磁盘空间大小。例如,使用 GB、MB、KB 等单位代替字节。 执行 df -h 命令后&…...
nginx-排查一次大文件无法正常下载问题
目录 问题现象&报错信息 问题现象以及分析 nginx报错信息 问题解决 方法1:配置proxy_max_temp_file_size 方法2:关闭proxy_buffering 参考文档 问题现象&报错信息 问题现象以及分析 文件正常从后端服务器直接下载时,一切正常…...
基于yolov5的草莓成熟度检测系统,可进行图像目标检测,也可进行视屏和摄像检测(pytorch框架)【python源码+UI界面+功能源码详解】
功能演示: 基于yolov5的草莓成熟度检测系统,系统既能够实现图像检测,也可以进行视屏和摄像实时检测_哔哩哔哩_bilibili (一)简介 基于yolov5的草莓成熟度系统是在pytorch框架下实现的,这是一个完整的项目…...
Kubesphere 保姆级分析
应用场景 KubeSphere 适用于多种场景,为企业提供容器化的环境,借助完善的管理和运维功能,让企业在数字化转型过程中从容应对各种挑战和各类业务场景,如多云多集群管理、敏捷软件开发、自动化运维、微服务治理、流量管理以及 DevO…...
力扣hot100:240.搜索二维矩阵II(脑子)
吉大21级算法分析与设计的一道大题,由于每一行都是排好序的直接逐行二分 可以达到:O(mlogn)。但是这里追求更广的思路可以使用其他方法。 矩阵四分: 在矩阵中用中心点比较,如果target大于中心点的值,则由于升序排列&am…...
使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...
Zustand 状态管理库:极简而强大的解决方案
Zustand 是一个轻量级、快速和可扩展的状态管理库,特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...
Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...
关于nvm与node.js
1 安装nvm 安装过程中手动修改 nvm的安装路径, 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解,但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后,通常在该文件中会出现以下配置&…...
FastAPI 教程:从入门到实践
FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,支持 Python 3.6。它基于标准 Python 类型提示,易于学习且功能强大。以下是一个完整的 FastAPI 入门教程,涵盖从环境搭建到创建并运行一个简单的…...
postgresql|数据库|只读用户的创建和删除(备忘)
CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...
Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...
Redis的发布订阅模式与专业的 MQ(如 Kafka, RabbitMQ)相比,优缺点是什么?适用于哪些场景?
Redis 的发布订阅(Pub/Sub)模式与专业的 MQ(Message Queue)如 Kafka、RabbitMQ 进行比较,核心的权衡点在于:简单与速度 vs. 可靠与功能。 下面我们详细展开对比。 Redis Pub/Sub 的核心特点 它是一个发后…...
C++:多态机制详解
目录 一. 多态的概念 1.静态多态(编译时多态) 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1).协变 2).析构函数的重写 5.override 和 final关键字 1&#…...
虚拟电厂发展三大趋势:市场化、技术主导、车网互联
市场化:从政策驱动到多元盈利 政策全面赋能 2025年4月,国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》,首次明确虚拟电厂为“独立市场主体”,提出硬性目标:2027年全国调节能力≥2000万千瓦࿰…...
