微服务 Spring Cloud 7,Nacos配置中心的Pull原理,附源码

在这里插入图片描述

目录

    • 一、本地配置
    • 二、配置中心
      • 1、以Nacos为例:
      • 2、Pull模式
      • 3、也可以通过Nacos实现注册中心
    • 三、配置中心提供了哪些功能
    • 四、如何操作配置中心
      • 1、配置注册
      • 2、配置反注册
      • 3、配置查看
      • 4、配置变更订阅
    • 五、主流的微服务注册中心有哪些,如何选择?
      • 1、在选择微服务注册中心时,可以考虑以下因素:
      • 2、主流注册中心
        • (1)Eureka
        • (2)Consul
        • (3)Zookeeper
        • (4)Nacos
      • 3、如何选择?
    • 微服务 Spring Cloud系列

大家好,我是哪吒。

在单体服务时代,关于配置信息,管理一套配置文件即可。

而拆分成微服务之后,每一个系统都会有自己的配置,并且都各不相同,有些配置还需要动态改变,以达到动态降级、切流量、扩缩容等目的。

一、本地配置

在Spring Boot开发中,可以把配置项放到config文件中,把配置当代码使用。比如:

public class AppConfig {public static final String static_SUCCESS_CODE = "0000";public static final String static_ERROR_CODE = "0001";
}

也可以通过@Value加载yaml配置文件中的配置。

@Component
public class HttpConfig {// 核心线程数public static String config_CORE_POOL_SIZE;@Value("${async.corePoolSize}")public void setSaveUrl(String corePoolSize) {HttpConfig.config_CORE_POOL_SIZE = corePoolSize;}
}

无论是将配置定义在代码中,还是将配置写在yaml配置文件中,都相当于把配置存在应用程序的本地。

如果想修改配置,就需要将在Linux服务器中部署的程序停止,然后手动修改其配置,再进行重启。

如果修改的配置项较多,这也是一项容易出错,而且繁琐的事情,长期运维的小伙伴应该深有体会。

当时,我就在想,作为世界上使用人数最多的语言,更新一个配置,需要这么复杂吗?

答案肯定不是的。

二、配置中心

配置中心(Configuration Center)通常用于集中管理应用程序的配置信息。这些配置信息可以包括数据库连接信息、外部服务地址、日志级别、超时设置等。配置中心可以提高应用部署的灵活性和可维护性。

程序启动时,可以自动从配置中心拉取所需要的配置项,配置中心中配置有所改变时,同样可以自动从配置中心拉取最新的配置信息,服务不需要重新发布。

1、以Nacos为例:

  1. 配置中心的信息一般都是放在bootstrap.yml 中;
  2. 初始化的时候,Bootstrap Context负责从外部源加载配置属性并解析配置;
  3. Bootstrap属性有高优先级,默认情况下,它们不会被本地配置覆盖;
  4. 然后再读取application.yml中的配置,进行配置合并,完成项目的启动。

在这里插入图片描述
项目的核心配置,需要热更新的配置才有放到nacos管理的必要。基本不会变更的一些配置还是保存在微服务本地比较好。

在这里插入图片描述

2、Pull模式

Nacos采用的是Pull模式获取服务端数据,客户端采用长轮询的方式定时的发起Pull请求,去检查服务端配置信息是否发生了变化。

  1. 客户端发起长轮询请求,监听变更的dataId+group;
  2. 服务端收到客户端的请求,这时会挂起客户端的请求;
  3. 如果在服务端设计的29.5s之内都没有发生变更,触发自动检查机制,此时不管是否有变化,服务端都会返回响应到客户端
  4. 如果在29.5s之内配置项发生了变更,则会触发一个事件机制,将变更的数据推送的客户端。

在这里插入图片描述

3、也可以通过Nacos实现注册中心

这种是最简单的Nacos注册中心,有若干个服务,都注册到Nacos注册中心,调用之前,先到Nacos获取对应接口,然后进行实际的调用。

服务1和服务2和Nacos之间维护一个心跳关系,每5秒跳一次,频率不能太快或者太慢,否者会嗝屁的。

如果Nacos在5秒内没有收到心跳,则表示服务挂了,Nacos会下线此服务。

对于超过15秒没有收到客户端心跳的服务实例,会将它的healthy属性置为false,客户端无法调用healthy为false的服务。

如果超过30秒没有收到心跳,Nacos会直接将此服务剔除。

也可以通过服务端主动注销的方式,停止注册。

服务1调用服务2时,服务1会通过定时任务到Nacos中获取在线的服务,保证所调用的服务一直都是健康在线的状态。

获取到之后,用缓存将其保存起来,然后通过负载均衡器调用服务2,此时,将不再使用服务端的负载均衡Nginx了。

在这里插入图片描述

三、配置中心提供了哪些功能

  1. 配置项管理:支持添加、发布、修改配置项以及配置项的分组,可以实现版本管理,支持热发布、灰度发布、环境隔离,提供API接口与可视化操作页面。
  2. 权限控制:配置项访问控制,读权限和写权限。
  3. 操作审计:支持记录用户的操作行为。
  4. 配置变更:当有新的配置项或是现有的配置项发生变动时,配置中心能够进行实时的监控并做出相应的处理。
  5. 配置推送:通过订阅/发布的模式,将配置信息推送给各个服务的消费者。
  6. 历史版本管理:保存所有的配置历史版本,并提供查询和对比的功能,可以轻松的回滚到任何一个版本。
  7. 灰度发布:通过配置中心可以实现在部分环境中先发布新的配置项,观察一段时间没有问题后再推送给其他所有的环境。
  8. 配置变更审计:记录每次配置的修改记录,方便追踪和管理。

这些功能可以帮助降低分布式系统中管理配置信息的成本,降低因错误的配置信息变更带来可用性下降甚至发生故障的风险。

四、如何操作配置中心

1、配置注册

配置中心的配置注册通常包括以下步骤:

  1. 服务提供者在启动时,将自己的配置信息注册到配置中心。这些信息可能包括服务的IP地址、端口号、数据库连接信息等。
  2. 配置中心接收并存储这些配置信息。一般来说,配置中心会提供一个统一的接口或者界面,让服务提供者能够方便地进行注册。
  3. 服务消费者在需要使用某个服务时,会从配置中心获取相应的配置信息。这样,即使服务提供者的地址等信息发生变化,服务消费者也能通过配置中心获取到最新的配置信息,而无需手动修改。

通过这种方式,配置中心实现了配置的统一管理和动态更新。服务提供者和消费者都可以通过配置中心来进行配置的注册和获取,大大提高了配置的灵活性和便利性。同时,也减少了因为手动配置错误而导致的问题,提高了系统的稳定性和可用性。

要通过Java代码实现配置注册到配置中心,你可以遵循以下步骤。这里继续提供一个通用的示例代码,以展示基本的流程和步骤。请注意,实际的代码可能会因所使用的具体配置中心而有所不同。

import com.configcenter.sdk.ConfigCenterClient;  
import com.configcenter.sdk.exception.ConfigCenterException;  
import com.configcenter.sdk.model.Configuration;  public class ConfigurationRegistration {  public static void main(String[] args) {  // 配置中心的服务器URL和认证令牌  String serverUrl = "configcenter_server_url";  String authToken = "your_auth_token";  // 创建配置对象  Configuration configuration = new Configuration();  configuration.setId("your_configuration_id");  configuration.setKey("your_configuration_key");  configuration.setValue("your_configuration_value");  // 可选:设置其他配置项属性,如描述、标签等  try {  // 初始化配置中心的客户端  ConfigCenterClient client = ConfigCenterClient.init(serverUrl, authToken);  // 调用配置中心的注册API  boolean success = client.registerConfiguration(configuration);  if (success) {  System.out.println("配置注册成功");  } else {  System.out.println("配置注册失败");  }  } catch (ConfigCenterException e) {  System.out.println("配置注册出现异常: " + e.getMessage());  e.printStackTrace();  }  }  
}

在这个示例中:

  1. 我们首先创建了一个Configuration对象,设置了配置项的ID、键(key)和值(value)。你可以根据需要设置其他属性,如描述、标签等;
  2. 然后,我们初始化配置中心的客户端,并调用client.registerConfiguration()方法来执行配置注册操作,传入创建好的Configuration对象。
  3. 该方法将返回一个布尔值,表示注册是否成功,我们根据返回结果打印相应的消息;
  4. 如果发生异常,我们进行异常处理并打印异常信息。

2、配置反注册

配置中心的配置反注册是指从配置中心中移除或注销某个配置项的过程。当某个服务或应用不再需要使用某个配置项时,可以进行配置反注册操作。这个操作通常通过配置中心提供的接口来完成,它会将指定的配置项从配置中心中删除或标记为注销状态。

配置反注册可以是手动触发的,也可以是自动触发的。在手动触发方式下,管理员或开发者可以通过调用配置中心提供的反注册接口,指定需要反注册的配置项。而自动触发方式下,通常会在服务或应用停止时,自动触发配置反注册操作。

配置反注册是配置中心的一个重要功能,它可以帮助管理员或开发者更好地管理配置项的生命周期,确保配置中心中的数据与实际应用需求保持一致。同时,通过反注册不再需要的配置项,也可以减少配置中心的存储空间和资源消耗。

要通过Java代码实现配置反注册,你需要使用配置中心提供的Java SDK或API。以下是一个示例代码,展示了如何使用Java来实现配置反注册。

import com.configcenter.sdk.ConfigCenterClient;  
import com.configcenter.sdk.exception.ConfigCenterException;  public class ConfigurationDeregistration {  public static void main(String[] args) {  // 配置中心的服务器URL和认证令牌  String serverUrl = "configcenter_server_url";  String authToken = "your_auth_token";  // 初始化配置中心的客户端  ConfigCenterClient client = ConfigCenterClient.init(serverUrl, authToken);  // 配置项的ID  String configurationId = "your_configuration_id";  try {  // 调用配置中心的反注册API  boolean success = client.deregisterConfiguration(configurationId);  if (success) {  System.out.println("配置反注册成功");  } else {  System.out.println("配置反注册失败");  }  } catch (ConfigCenterException e) {  System.out.println("配置反注册出现异常: " + e.getMessage());  e.printStackTrace();  }  }  
}

在这个示例中:

  1. 我们首先通过ConfigCenterClient.init()初始化配置中心的客户端,传入服务器URL和认证令牌;
  2. 然后,我们调用client.deregisterConfiguration()方法来执行配置反注册操作,传入配置项的ID;
  3. 该方法将返回一个布尔值,指示反注册是否成功;
  4. 根据返回结果,我们打印相应的消息;
  5. 如果发生异常,我们捕获并打印异常信息。

3、配置查看

通过配置中心的用户界面和API接口,你可以方便地查看和管理配置项。

import com.configcenter.sdk.ConfigCenterClient;  
import com.configcenter.sdk.exception.ConfigCenterException;  
import com.configcenter.sdk.model.Configuration;  public class ConfigurationViewer {  public static void main(String[] args) {  // 配置中心的服务器URL和认证令牌  String serverUrl = "configcenter_server_url";  String authToken = "your_auth_token";  // 配置项的ID或键(key)  String configurationId = "your_configuration_id";  // 或者使用配置项的键(key)来获取配置项,根据配置中心API的要求而定  // String configurationKey = "your_configuration_key";  try {  // 初始化配置中心的客户端  ConfigCenterClient client = ConfigCenterClient.init(serverUrl, authToken);  // 调用配置中心的API接口获取配置项  Configuration configuration = client.getConfiguration(configurationId);  // 或者使用配置项的键(key)来获取:  // Configuration configuration = client.getConfigurationByKey(configurationKey);  // 输出配置项的信息  if (configuration != null) {  System.out.println("配置项ID: " + configuration.getId());  System.out.println("配置项键(key): " + configuration.getKey());  System.out.println("配置项值(value): " + configuration.getValue());  // 输出其他配置项属性,如描述、标签等  } else {  System.out.println("未找到配置项");  }  } catch (ConfigCenterException e) {  System.out.println("查看配置项出现异常: " + e.getMessage());  e.printStackTrace();  }  }  
}

在上面的示例代码中:

  1. 我们首先初始化配置中心的客户端;
  2. 然后调用相应的API接口来获取配置项;
  3. 在获取到配置项后,我们可以输出配置项的各种属性,如ID、键(key)、值(value)等;
  4. 如果发生异常,我们进行异常处理并打印相应的异常信息。

4、配置变更订阅

配置中心通常支持配置变更订阅功能,允许应用程序或其他服务订阅配置项的变更通知。当配置项发生变化时,配置中心会向订阅者发送通知,以便订阅者能够及时获取最新的配置项。

要通过Java代码实现配置变更订阅,你可以按照以下步骤进行操作:

  1. 首先,确保你已经初始化了配置中心的客户端,如上述示例代码所示。
  2. 创建一个订阅者(listener)类,实现配置中心提供的订阅接口。这个类将负责处理配置项的变更通知。
  3. 在订阅者类中,实现接口中定义的方法,以处理配置项的变更事件。该方法通常会在配置项发生变化时被调用,并且会接收包含变更信息的参数。
  4. 在你的应用程序或服务中,创建一个订阅请求(subscription request)对象,指定你希望订阅的配置项或配置项的过滤条件。
  5. 使用配置中心的客户端对象,调用订阅方法,将订阅请求对象和订阅者对象作为参数传递给该方法。这将向配置中心注册你的订阅请求,并指定订阅者类来处理变更通知。
  6. 一旦注册成功,当配置项发生变更时,配置中心将调用订阅者类中的方法,将变更信息传递给订阅者。你可以在这个方法中编写逻辑来处理配置项的变更,如更新本地缓存、重新加载配置等。

下面是一个简单的示例代码,展示如何实现配置变更订阅:

import com.configcenter.sdk.ConfigCenterClient;  
import com.configcenter.sdk.exception.ConfigCenterException;  
import com.configcenter.sdk.listener.ConfigurationChangeListener;  
import com.configcenter.sdk.model.Configuration;  public class ConfigurationSubscriber {  public static void main(String[] args) {  // 初始化配置中心的客户端(省略代码)  // 创建订阅者类  ConfigurationChangeListener listener = new ConfigurationChangeListener() {  @Override  public void onConfigurationChanged(Configuration configuration) {  // 处理配置项变更事件  System.out.println("配置项发生变化: " + configuration.getKey() + " = " + configuration.getValue());  // 在这里可以更新本地缓存、重新加载配置等  }  };  try {  // 创建订阅请求对象(根据配置中心API的要求而定)  // 指定你希望订阅的配置项过滤条件,如配置项的键(key)或其他属性  // 调用配置中心的订阅方法  ConfigCenterClient client = ConfigCenterClient.init(serverUrl, authToken);  client.subscribeToConfigurationChanges(filter, listener);  } catch (ConfigCenterException e) {  System.out.println("配置变更订阅出现异常: " + e.getMessage());  e.printStackTrace();  }  }  
}

五、主流的微服务注册中心有哪些,如何选择?

1、在选择微服务注册中心时,可以考虑以下因素:

  1. 功能和特性:不同的注册中心可能具有不同的功能和特性,需要根据自己的需求来选择。例如,一些注册中心可能更侧重于服务发现,而另一些可能提供更全面的配置管理功能。
  2. 性能和稳定性:注册中心作为微服务架构的核心组件,其性能和稳定性至关重要。需要对候选的注册中心进行性能测试和稳定性评估,确保它们能够满足你的业务需求。
  3. 易用性和开发体验:注册中心的易用性和开发体验也是选择的重要因素。选择一个提供良好开发文档、客户端库和工具的注册中心,可以使开发过程更加顺畅高效。
  4. 社区支持和生态系统:一个活跃和健康的社区可以为注册中心提供持续的支持和改进。同时,一个丰富的生态系统可以提供更多的集成选项和解决方案。因此,需要评估候选注册中心的社区活跃度和生态系统成熟度。
  5. 安全性和合规性:安全性和合规性对于任何系统都至关重要。需要确保所选的注册中心能够提供足够的安全保障,并满足你的合规性要求。

最终,选择微服务注册中心是一个权衡的过程,需要根据自己的实际需求、技术栈、团队熟悉度等因素进行综合考虑。

2、主流注册中心

在Eureka、Consul、Zookeeper和Nacos这几个微服务注册中心中,选择最适合的一个取决于你的具体需求和环境。

(1)Eureka
  • 是Netflix开发的服务注册中心,与Spring Cloud集成良好。
  • 保证了高可用性和最终一致性,服务注册相对较快。
  • 在数据不一致时,每个Eureka节点仍能正常对外提供服务,保证了可用性。
(2)Consul
  • 使用Go语言编写,具有较好的跨平台性。
  • 提供了丰富的功能和强大的一致性保证。
  • 支持多数据中心和分布式部署,适合大规模环境。
(3)Zookeeper
  • 最初是一个分布式协调服务,后来被用于服务注册和发现。
  • 提供了强一致性和高可用性,但相对较复杂,需要自行实现一些服务发现功能。
(4)Nacos
  • 是阿里巴巴开源的项目,支持基于DNS和基于RPC的服务发现。
  • 除了服务注册和发现,还支持动态配置服务。
  • 在Spring Cloud中使用较为简单,只需简单的配置即可完成服务的注册和发现。

3、如何选择?

  • 如果你使用Spring Cloud作为微服务框架,Eureka可能是一个自然的选择,因为它与Spring Cloud集成良好。
  • 如果你需要强大的跨平台支持和一致性保证,Consul是一个不错的选择。
  • 如果你已经在使用Zookeeper或其他Apache项目,并且希望在同一生态系统中解决服务注册和发现问题,那么Zookeeper可能适合你。
  • 如果你在寻找一个简单且与阿里巴巴技术栈集成的解决方案,Nacos是一个值得考虑的选项。

最终的选择应基于你的技术需求、团队熟悉度和业务场景。


微服务 Spring Cloud系列

微服务 Spring Cloud 1,服务如何拆分?使用微服务的注意事项?

微服务 Spring Cloud 2,一文讲透微服务核心架构(注册中心、服务通信、服务监控、服务追踪、服务治理)

微服务 Spring Cloud 3,如何对微服务进行有效的监控?

微服务 Spring Cloud 4,分布式系统如何进行数据分区

微服务 Spring Cloud 5,一图说透Spring Cloud微服务架构

微服务 Spring Cloud 6,用了这么多年Docker容器,殊不知你还有这么多弯弯绕


🏆哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师

华为OD机试 2023B卷题库疯狂收录中,刷题点这里

刷的越多,抽中的概率越大,每一题都有详细的答题思路、详细的代码注释、样例测试,发现新题目,随时更新,全天CSDN在线答疑。

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

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

相关文章

为何公司强调流程员工总是觉得反感?

在企业管理中,流程设计对于提高效率和降低风险至关重要。然而,很多企业在流程设计时常犯一些常见的错误,导致基层员工对流程感到烦扰,甚至产生抵触情绪。本文将通过分析一个企业的报销流程问题,探讨如何优化流程以提高…

开关电源测试方法分享:开关电源关机维持时间的测试步骤、测试标准

开关电源关机维持时间是指切断电源后输出电压下降到稳压范围外为止的时间。关机维持时间是开关电源测试项目之一,测试时需要用到交流电源、电子负载、示波器等测试设备。那么开关电源测试系统要如何测试关机维持时间呢? 开关电源关机维持时间的测试步骤 关机维持时…

[C/C++]数据结构 LeetCode:用栈实现队列

题目描述: 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty): 实现 MyQueue 类: void push(int x) 将元素 x 推到队列的末尾int pop() 从队列的开头移除并返回元素int peek() 返…

java基础练习缺少项目?看这篇文章就够了(上)!

公众号:全干开发 。 专注分享简洁但高质量的动图技术文章! 项目概述 本教程适合刚学习完java基础语法的同学,涉及if语句、循环语句、类的封装、集合等基础概念,使用大量gif图帮助读者演示代码操作、效果等,是一个非常…

如何在 Linux 上部署 RabbitMQ

如何在 Linux 上部署 RabbitMQ 文章目录 如何在 Linux 上部署 RabbitMQ安装 Erlang从预构建的二进制包安装从源代码编译 Erlang RabbitMQ 的安装使用 RabbitMQ Assistant 连接 RabbitMQ Assistant 是一款优秀的RabbitMQ 可视化管理工具,提供丰富的管理功能。下载地址…

9、传统计算机视觉 —— 边缘检测

本节介绍一种利用传统计算机视觉方法来实现图片边缘检测的方法。 什么是边缘检测? 边缘检测是通过一些算法来识别图像中物体之间,或者物体与背景之间的边界,也就是边缘。 边缘通常是图像中灰度变化显著的地方,标志着不同区域的分界线。 在一张图像中,边缘可以是物体的…

2024有哪些免费的mac苹果电脑内存清理工具?

在我们日常使用苹果电脑的过程中,随着时间的推移,可能会发现设备的速度变慢了,甚至出现卡顿的现象。其中一个常见的原因就是程序占用内存过多,导致系统无法高效地运行。那么,苹果电脑内存怎么清理呢?本文将…

【SpringCloud】Eureka基于Ribbon负载均衡的调用链路流程分析

文章目录 前言1.调用形式2.LoadBalancerInterceptor3.负载均衡流程分析3.1 调用流程图3.2 intercept()方法3.3 execute()方法3.4 getServer()方法3.4 子类的chooseServer()方法3.5 getLoadBalancerStats().…

基于Spring Boot 框架的试卷自动生成系统的设计与实现

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。你想解决的问题,今天给大家介绍…

2024年测试工程师必看系列之fiddler设置手机端抓包全套教程

fiddler设置手机端抓包 安卓手机抓包 第一步:配置电脑和安卓的相关设置 1、手机和fiddler位于同一个局域网内;首先从fiddler处获取到ip地址和端口号: ,点击online,最后一行就是ip地址 2、路径:Tools》Op…

基于单片机的智能家居安保系统(论文+源码)

1.系统设计 本次基于单片机的智能家居安保系统设计,在功能上如下: 1)以51单片机为系统控制核心; 2)温度传感器、人体红外静释电、烟雾传感器来实现检测目的; 3)以GSM模块辅以按键来实现远/近程…

SpringCloud微服务 【实用篇】| Eureka注册中心、Ribbon负载均衡

目录 一:Eureka注册中心 1. Eureka原理 2. 动手实践 ①搭建EurekaServer ②服务注册 ③服务发现 二:Ribbon负载均衡 1. 负载均衡原理 2. 负载均衡策略 3. 懒加载 一:Eureka注册中心 前面已经分析了,无论是SpringCloud还…

【前端学java】复习巩固-Java中的对象比较(14)

往期回顾: 【前端学java】JAVA开发的依赖安装与环境配置 (0)【前端学 java】java的基础语法(1)【前端学java】JAVA中的packge与import(2)【前端学java】面向对象编程基础-类的使用 &#xff08…

南京--ChatGPT/GPT4 科研实践应用

2023年随着OpenAI开发者大会的召开,最重磅更新当属GPTs,多模态API,未来自定义专属的GPT。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义,不亚于互联网和个人电脑的问世。360创始人周鸿祎认为未来各行各业如果不能搭上这班车…

云计算赛项容器云2023搭建

部署容器云平台[5 分] 使 用 OpenStack 私 有 云 平 台 创 建 两 台 云 主 机 , 云 主 机 类 型 使 用 4vCPU/12G/100G 类型,分别作为 Kubernetes 集群的 Master 节点和 node 节点, 然后完成 Kubernetes 集群的部署,并完成 Istio …

澳洲猫罐头真实水平如何?我家亲自喂养过的优质猫罐头推荐给大家

当我们选择猫罐头时,要关注它的营养配方是否完整均衡、原料是否新鲜优质以及生产工艺是否科学可靠。只有满足这三个条件的猫罐头,才能称得上是高品质的。 猫罐头要营养均衡,好的配方不能少;猫罐头成品要优质,原材料要…

查询数据库DQL

DQL 查询基本语法 -- DQL :基本语法; -- 1查询指定的字段 name entrydate 并返回select name , entrydate from tb_emp;-- 2 查询 所有字段 并返回select id, username, password, name, gender, image, job, entrydate, create_time, update_time from tb_emp;-- 2 查询…

C++ 继承和派生 万字长文超详解

本文章内容来源于C课堂上的听课笔记 继承和派生基础 继承是一种概念,它允许一个新创建的类(称为子类或派生类)获取另一个已经存在的类(称为父类或基类)的属性和行为。这就好比是子类继承了父类的特征。想象一下&…

【文末附资料链接】2023年第十三届亚太杯数学建模竞赛(APMCM)优秀参考论文思路指导(持续更新中ing)

一、赛事介绍 数学建模作为一门跨学科的科学,不仅需要对数学知识的熟练掌握,还需要对实际问题的深刻理解和解决问题的创新思维。亚太杯数学建模竞赛旨在激发青年学子的创造力和团队协作精神,培养其在实际问题中运用数学方法解决现实挑战的能力…

HarmonyOS ArkTS开发语言介绍(三)

1 引言 Mozilla创造了JS,Microsoft创建了TS,Huawei进一步推出了ArkTS。 从最初的基础的逻辑交互能力,到具备类型系统的高效工程开发能力,再到融合声明式UI、多维状态管理等丰富的应用开发能力,共同组成了相关的演进脉…