Dubbo3入门项目搭建
开发环境:jdk8、dubbo3.2.9、nacos2.3.0、springboot2.7.17、dubbo-admin0.6.0。
Dubbo 是一个高性能的 Java RPC(远程调用)框架,最初由阿里巴巴开发并开源,主要用于构建 SOA 架构下的分布式应用系统( soa简单理解就是将重复功能或模块抽成通用组件,对外提供服务,从而实现复用)。 Dubbo提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。Dubbo支持多种通信协议 比如:dubbo、rmi、hessian、http、webservice、rest、redis等。
nacos即是注册中心又是配置中心,注册中心解决服务治理问题,配置中心解决配置文件散乱问题。
一、准备环境
1、mysql
1、在宿主机~/docker_install/mysql/
目录下,创建docker-compose.yml文件:
version: '3.1'
services:mysql: #定义mysql服务image: mysql:8.4 #使用 MySQL 8.4 的官方镜像构建container_name: mysql8 #容器名称restart: always #当Docker服务重启或容器异常退出时,容器会自动重启。ports:- "3307:3306" #端口映射,将宿主机的3307端口映射到容器的3306端口volumes: #挂在目录- "~/docker_install/mysql/my.cnf:/etc/mysql/my.cnf"- "~/docker_install/mysql/data:/var/lib/mysql"- "~/docker_install/mysql/mysql-files:/var/lib/mysql-files"environment:MYSQL_ROOT_PASSWORD: 123456 #设置root用户的密码TZ: Asia/Shanghai #时区LANG: en_US.UTF-8 #语言编码MYSQL_DATABASE: demo #初始化的数据库名称#授权 privileged: true user: root
2、在宿主机~/docker_install/mysql/
目录下,创建my.cnf文件:
#服务端参数配置
[mysqld]
user=root #MySQL启动用户
default-storage-engine=INNODB #创建新表时将使用的默认存储引擎
character-set-server=utf8mb4 #设置mysql服务端默认字符集
collation-server=utf8mb4_general_ci #数据库字符集对应一些排序等规则,注意要和character-set-server对应
default-authentication-plugin=mysql_native_passwordmax_connections=1000 # 允许最大连接数
max_connect_errors=100 # 最大错误连接数[mysql]
default-character-set=utf8mb4[client]
default-character-set=utf8mb4 # 设置mysql客户端默认字符集
3、创建容器
docker-compose -f docker-compose.yml -p mysql8 up -d
命令解释:
- docker-compose :服务编排工具。
- -f docker-compose.yml :指定要使用的yaml文件。
- -p mysql8 :设置项目名称,docker compose 使用项目名称来命名创建的容器、网络和卷等资源。避免在同一主机上运行多个不同的compose项目时出现命名冲突。
- up :用于启动由 docker-compose.yml 文件定义的所有服务。
- -d(–detach):以分离模式(detached mode)运行容器。(后台方式运行)
docker-compose常用命令:
- ps :基于docker-compose拉取的镜像生成的容器
- up :docker-compose 创建和启动容器
- scale :创建容器的数量
- top :显示容器的进程
- logs :看容器的输出日志
- stop start、restart: 停止、启动、重启
- down : 删除容器,网络,数据卷,镜像
2、nacos
基于docker-compose编排方式安装nacos,并使用mysql持久化nacos配置信息。
1、创建docker-compose.yaml:
version: '3'
services:nacos:image: nacos/nacos-server:v2.3.0-slim# 容器名称container_name: nacos# 端口映射ports:- 8848:8848- 9848:9848- 9849:9849# 容器权限privileged: true# 参数设置environment:JVM_XMS: 128mJVM_XMX: 128mJVM_MS: 64mJVM_MMS: 64mMODE: standaloneNACOS_REPLICAS: 1PREFER_HOST_MODE: ip# 挂载目录 volumes: - ./logs:/home/nacos/logs- ./plugins:/home/nacos/plugins- ./data:/home/nacos/data- ./config/application.properties:/home/nacos/conf/application.propertiesnetworks:nacos:aliases:- nacos_2.3.0
networks:nacos:name: nacos_2.3.0driver: bridge
2、在宿主机./config/
目录下,创建application.properties:
# 只需要修改下面MySQL账号密码、连接地址
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3307/nacos_conf?characterEncoding=utf8& connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123456# 随机字符串,要长点
nacos.core.auth.plugin.nacos.token.secret.key=0123321adsfffdasf343134124fasfdfdffas34134343
- 在mysql中执行sql脚本:https://github.com/alibaba/nacos/blob/2.3.0/config/src/main/resources/META-INF/nacos-db.sql
3、创建容器
docker-compose up -d
nacos访问地址:http://ip:8848/nacos
3、dubbo-admin
dubbo-admin:https://github.com/apache/dubbo-admin/archive/refs/tags/0.6.0.zip
dubbo-admin (dubbo可视化后台)它是一个前后的分离项目,基于springboot+vue开发,需要依赖 nodejs、jdk、maven环境。
1、从github拉取代码:git clone https://github.com/apache/dubbo-admin.git
2、使用idea打开dubbo-admin-server,修改application.properties中的nacos配置:
server.port=38080
dubbo.protocol.port=30880
dubbo.application.qos-port=32222# centers in dubbo, if you want to add parameters, please add them to the url
admin.registry.address=nacos://127.0.0.1:8848
admin.config-center=nacos://127.0.0.1:8848
admin.metadata-report.address=nacos://127.0.0.1:8848
#---------------------------------------------------# dubbo-admin 账号密码
admin.root.user.name=root
admin.root.user.password=root#session timeout, default is one hour
admin.check.sessionTimeoutMilli=3600000#compress
server.compression.enabled=true
server.compression.mime-types=text/css,text/javascript,application/javascript
server.compression.min-response-size=10240#token timeout, default is one hour
admin.check.tokenTimeoutMilli=3600000
#Jwt signingKey
admin.check.signSecret=86295dd0c4ef69a1036b0b0c15158d77#dubbo config
dubbo.application.name=dubbo-admin
dubbo.registry.address=${admin.registry.address}
#dubbo.registry.parameters.namespace=70b158a6-7e64-478d-8c5b-699089aa81d1# id generate type
mybatis-plus.global-config.db-config.id-type=nonedubbo.application.logger=slf4j
3、运行dubbo-admin后端项目
通过nacos控制台可以看到dubbo-admin服务实例已成功注册到nacos中。
4、使用vscode或webstorm打开dubbo-admin-ui:(node版本16.20.2)
5、运行dobbo-admin前端项目:
# 安装项目依赖
npm install# 启动前端项目
npm run dev
6、浏览器访问duboo-admin web页面:http://localhost:38082/。账号/密码:root/root
二、项目搭建
项目地址:https://gitee.com/aopmin/dubbo3-demo.git
1、创建maven父工程
1、创建maven父工程,不使用脚手架方式构建:
2、父工程删除src源码目录
3、在父工程pom中管理子模块、锁定依赖版本
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>cn.aopmin</groupId><artifactId>dubbo3-demo</artifactId><version>1.0-SNAPSHOT</version><description>duubo3示例项目父工程</description><modules><module>dubbo3-provider</module><module>dubbo3-consumer</module><module>dubbo3-api</module></modules><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><spring.boot.version>2.7.17</spring.boot.version><nacos.boot.version>0.2.12</nacos.boot.version><dubbo.version>3.2.9</dubbo.version></properties><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>${spring.boot.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>
</project>
最终项目结构:
2、创建公共接口模块
dubbo是一个面向接口的远程调用,消费端如果想要调用生产端的接口,只需引入对应api接口模块jar包即可,所以这里我们偷懒一下把它抽成公用模块方便复用。
创建一个dubbo接口:
package cn.aopmin.api;/*** HelloService* @author aopmin* @since 2024/12/29*/
public interface HelloService {String getMsg();
}
3、创建provider服务提供者
1、服务提供者pom.xml文件配置
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>cn.aopmin</groupId><artifactId>dubbo3-demo</artifactId><version>1.0-SNAPSHOT</version></parent><artifactId>dubbo3-provider</artifactId><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><dependencies><!-- spring boot starter --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- springboot-web依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- dubbo依赖 --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>${dubbo.version}</version><exclusions><exclusion><artifactId>javassist</artifactId><groupId>org.javassist</groupId></exclusion></exclusions></dependency><!-- dubbo整合nacos --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><!-- <version>3.2.9</version> --><version>${dubbo.version}</version></dependency><!-- 公共接口模块 --><dependency><groupId>cn.aopmin</groupId><artifactId>dubbo3-api</artifactId><version>1.0-SNAPSHOT</version><scope>compile</scope></dependency></dependencies></project>
2、创建启动类
package cn.aopmin;import org.apache.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** 服务提供者* @author aopmin* @since 2024/12/29*/
@EnableDubbo // 开启dubbo
@SpringBootApplication
public class ProviderApp {public static void main(String[] args) {SpringApplication.run(ProviderApp.class, args);System.out.println("Provider started successfully!");}
}
4、编写dubbo接口实现类
package cn.aopmin.service;import cn.aopmin.api.HelloService;
import org.apache.dubbo.config.annotation.DubboService;import java.time.LocalDateTime;
import java.util.HashMap;/*** dubbo接口实现类* @author aopmin* @since 2024/12/29*/
@DubboService
public class HelloSericeImpl implements HelloService {@Overridepublic String getMsg() {return new HashMap<String,Object>(){{put("status","200");put("msg","Hello Dubbo!");put("datetime", LocalDateTime.now());}}.toString();}
}
5、创建application.yml文件
server:port: 5656 # 服务端口号spring:application:name: dubbo3-provider # 服务名称# dubbo配置
dubbo:application:name: ${spring.application.name}# 通信规则,dubbo支持多种通信规则,如dubbo、rmi、hessian、http等protocol:name: dubbo #使用dubbo协议port: 20880 # dubbo协议端口,以供消费者访问,-1即为随机端口# 注册中心配置registry:address: nacos://127.0.0.1:8848 #nacos
6、启动服务提供者
启动成功后可以dubbo-admin、nacos中查看:
最终项目结构:
4、创建consumer服务消费者
1、服务消费者pom.xml配置:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>cn.aopmin</groupId><artifactId>dubbo3-demo</artifactId><version>1.0-SNAPSHOT</version></parent><artifactId>dubbo3-consumer</artifactId><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding></properties><dependencies><!-- spring boot starter --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><!-- springboot-web依赖 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- <!–nacos配置中心依赖–> --><!-- <dependency> --><!-- <groupId>com.alibaba.boot</groupId> --><!-- <artifactId>nacos-config-spring-boot-starter</artifactId> --><!-- <version>${nacos.boot.version}</version> --><!-- </dependency> --><!-- dubbo依赖 --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>${dubbo.version}</version><exclusions><exclusion><artifactId>javassist</artifactId><groupId>org.javassist</groupId></exclusion></exclusions></dependency><!-- dubbo整合nacos --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><!-- <version>3.2.9</version> --><version>${dubbo.version}</version></dependency><!-- 公共接口模块 --><dependency><groupId>cn.aopmin</groupId><artifactId>dubbo3-api</artifactId><version>1.0-SNAPSHOT</version><scope>compile</scope></dependency></dependencies>
</project>
2、创建启动类
package cn.aopmin;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;/*** 服务消费者* @author aopmin* @since 2024/12/29*/
@SpringBootApplication
public class ConsumerApp {public static void main(String[] args) {SpringApplication.run(ConsumerApp.class, args);System.out.println("Consumer started successfully!");}
}
3、配置application.yml:
server:port: 5657 # 服务端口号spring:application:name: dubbo3-consumer # 服务名称# dubbo配置
dubbo:application:name: ${spring.application.name}qosPort: 33333 # 服务质量监控中心端口,默认为22222# 通信规则,dubbo支持多种通信规则,如dubbo、rmi、hessian、http等protocol:name: dubbo #使用dubbo协议port: 20881 # dubbo协议端口,以供消费者访问,-1即为随机端口# 注册中心配置registry:address: nacos://127.0.0.1:8848 #nacos
4、编写web接口
package cn.aopmin.controller;import cn.aopmin.api.HelloService;
import org.apache.dubbo.config.annotation.DubboReference;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** web接口* @author aopmin* @since 2024/12/29*/
@RestController
public class HelloController {// 注入远程服务(类似@autowried,只不过autowried注入的是spring容器中的bean对象), 设置超时时间:1s和重试次数:2次@DubboReference(timeout = 1000, retries = 1)private HelloService helloService;@RequestMapping("/hello")public String hello() {return helloService.getMsg();}
}
5、启动服务消费者
6、测试
curl -i -X GET "http://localhost:5657/hello"
最终项目结构:
三、Dubbo运行原理
dubbo一次RPC调用的过程,分为4个角色:Client:消费者Client Stub:客户端存档,由框架实现Server Stub:服务端存档,由框架实现Server:提供者调用过程:1、Client发起远程调用Client发起远程调用,实际上是由它的代理ClientStub实现的ClientStub把要调用目标类、目标方法、实参等等进行序列化,然后通过网络传递给ServerStub。ServerStub接收数据反序列化,再调用对应的目标类、目标方法,得到执行结果ServerStub把目标方法的结果进行序列化,通过网络返回给ClientStubClientStub接收数据反序列化,得到结果。把这个结果返回给Client2、Client得到执行的结果,返回给调用者
相关文章:

Dubbo3入门项目搭建
开发环境:jdk8、dubbo3.2.9、nacos2.3.0、springboot2.7.17、dubbo-admin0.6.0。 Dubbo 是一个高性能的 Java RPC(远程调用)框架,最初由阿里巴巴开发并开源,主要用于构建 SOA 架构下的分布式应用系统( soa简单理解就是…...
形象地理解UE4中的数据结构 TLinkedListBase
大家都熟知链表,但不一定能快速看懂UE4中的数据结构。 TLinkedListBase表示“链接”中的一个结点,有三个成员: 一、ElementType Element; 表示具体的业务,例如int链条中的一个整数。 二、NextLink 表示 “下一个Node”&#…...
Python自然语言处理利器:SnowNLP模块深度解析、安装指南与实战案例
Python自然语言处理之SnowNLP模块介绍、安装与常见操作案例 一、SnowNLP模块介绍 SnowNLP是一个专为中文文本设计的Python库,它基于自然语言处理技术,提供了多种功能,包括分词、词性标注、情感分析、文本转换(简繁转换ÿ…...

Llama系列关键知识总结
系列文章目录 第一章:LoRA微调系列笔记 第二章:Llama系列关键知识总结 第三章:LLaVA模型讲解与总结 文章目录 系列文章目录Llama: Open and Efficient Foundation Language Models关键要点LLaMa模型架构:Llama2分组查询注意力 (G…...

【开源】创建自动签到系统—QD框架
1. 介绍 QD是一个 基于 HAR 编辑器和 Tornado 服务端的 HTTP 定时任务自动执行 Web 框架。 主要通过抓包获取到HAR来制作任务模板,从而实现异步响应和发起HTTP请求 2. 需要环境 2.1 硬件需求 CPU:至少1核 内存:推荐 ≥ 1G 硬盘:推…...

CDP集群安全指南系列文章导读
[一]大数据安全综述 1-认证 身份验证是任何计算环境的基本安全要求。简单来说,用户和服务必须在使用系统功能并获得授权之前,向系统证明其身份(进行身份验证)。身份验证与授权紧密配合,共同保护系统资源。大多数 CDH …...

MT8788安卓核心板_MTK8788核心板参数_联发科模块定制开发
MT8788安卓核心板是一款尺寸为52.5mm x 38.5mm x 2.95mm的高集成度电路板,专为各种智能设备应用而设计。该板卡整合了处理器、图形处理单元(GPU)、LPDDR3内存、eMMC存储及电源管理模块,具备出色的性能与低功耗特性。 这款核心板搭载了联发科的MT8788处理…...

【微软,模型规模】模型参数规模泄露:理解大型语言模型的参数量级
模型参数规模泄露:理解大型语言模型的参数量级 关键词: #大型语言模型 Large Language Model #参数规模 Parameter Scale #GPT-4o #GPT-4o-mini #Claude 3.5 Sonnet 具体实例与推演 近日,微软在一篇医学相关论文中意外泄露了OpenAI及Claud…...

深入理解并发原子性、可见性、有序性与JMM内存模型
1. 并发三大特性 并发编程Bug的源头:原子性、可见性和有序性问题 1.1 原子性 一个或多个操作,要么全部执行且在执行过程中不被任何因素打断,要么全部不执行。在 Java 中,对基本数据类型的变量的读取和赋值操作是原子性操作&…...

电商项目-数据同步解决方案(四)商品下架同步更新ES索引库数据
商品下架索引库删除数据 一、 需求分析和业务逻辑 商品下架后将商品从索引库中移除。 主要应用技术有: 消息队列-RabbitMQ ,分布式搜索引擎-ElasticSearch,Eureka,Canal,Feign远程调用 (1)在…...

vue学习第一阶段
vue 什么是Vue? 概念:Vue是一个构建用户页面的渐进式框架 Vue的两种使用方式 Vue的核心开发 场景: 局部 {\color{red}局部} 局部模块改造Vue核心包& Vue插件 工程化开发场景: 整站 {\color{red}整站} 整站开发Vue2官网 https://v2.cn.vuejs.org/ 资料存放地址 D:\Baidu…...
React虚拟DOM:理解和应用
写在前面 在现代前端开发中,React 是一个非常流行的 JavaScript 库,用于构建用户界面。它引入了一个名为“虚拟 DOM”(Virtual DOM)的概念,这个概念对于 React 的高效性能和易用性至关重要。本文将深入探讨 React Vir…...

用python编写一个放烟花的小程序
import pygame import random # 代码解释及使用说明: # 首先,导入 pygame 和 random 库。pygame 用于创建游戏窗口和图形绘制,random 用于生成随机数。 # 初始化 pygame,并设置屏幕尺寸为 800x600 像素,设置窗口标题为…...
Git 仓库与文件管理笔记
Git 的三种仓库概念 本地仓库 (Local Repository) 位于本地 .git 文件夹中通过 git init 或 git clone 创建存储完整的项目历史和分支信息 远程仓库 (Remote Repository) 位于 GitHub、GitLab 等平台服务器使用 git remote -v 查看所有远程仓库默认远程仓库名通常为 origin 工…...
2024 年 docker 提示index.docker.io
发现 docker 提示以下错误: Error response from daemon: Get "https://index.docker.io/v1/search?qnginx&n25": dialing index.docker.io:443 container via direct connection because has no HTTPS proxy: connecting to index.docker.io:443:…...

TCP粘/拆包----自定义消息协议
今天是2024年12月31日,今年的最后一天,希望所有的努力在新的一年会有回报。❀ 无路可退,放弃很难,坚持很酷 TCP传输 是一种面向二进制的,流的传输。在传输过程中最大的问题是消息之间的边界不明确。而在服务端主要的…...
Modbus知识详解
Modbus知识详解 ## 1.什么是Modbus?**顾名思义**,它是一个Bus(总线),即总线协议。比如串口协议、IIC协议、SPI都是通信协议。你接触到这种协议,相信你所处的行业是工业电子方面或者你的产品用于工业。好了,…...
Java-创建一个结合CompletableFuture和自定义功能的工具类
1.重试机制:当异步任务失败时自动重试。 2.超时重试:在指定时间内未完成的任务进行重试。 3.批量处理:将多个任务批量执行并收集结果。 4.日志记录:为每个异步任务添加日志记录,便于调试和监控。 5.自定义线程池:允许用户传入自定义的线程池配置。 import java.util…...

【MATLAB第111期】基于MATLAB的sobol全局敏感性分析方法二阶指数计算
【MATLAB第111期】基于MATLAB的sobol全局敏感性分析方法二阶指数计算 一、简介 在MATLAB中计算Sobol二阶效应指数通常涉及到全局敏感性分析(Global Sensitivity Analysis, GSA),其中Sobol方法是一种流行的技术,用于评估模型输入…...
C语言-sprintf
sprintf是一个在C语言中用于字符串格式化的函数,其功能是将格式化的数据写入某个字符串中。该函数定义stdio.h在头文件中,原型为: int sprintf(char *string, const char *format, ...); 函数参数 string:指向一个字符数组的指针&#…...
应用升级/灾备测试时使用guarantee 闪回点迅速回退
1.场景 应用要升级,当升级失败时,数据库回退到升级前. 要测试系统,测试完成后,数据库要回退到测试前。 相对于RMAN恢复需要很长时间, 数据库闪回只需要几分钟。 2.技术实现 数据库设置 2个db_recovery参数 创建guarantee闪回点,不需要开启数据库闪回。…...
条件运算符
C中的三目运算符(也称条件运算符,英文:ternary operator)是一种简洁的条件选择语句,语法如下: 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true,则整个表达式的结果为“表达式1”…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解
本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说,直接开始吧! 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...
【决胜公务员考试】求职OMG——见面课测验1
2025最新版!!!6.8截至答题,大家注意呀! 博主码字不易点个关注吧,祝期末顺利~~ 1.单选题(2分) 下列说法错误的是:( B ) A.选调生属于公务员系统 B.公务员属于事业编 C.选调生有基层锻炼的要求 D…...

NLP学习路线图(二十三):长短期记忆网络(LSTM)
在自然语言处理(NLP)领域,我们时刻面临着处理序列数据的核心挑战。无论是理解句子的结构、分析文本的情感,还是实现语言的翻译,都需要模型能够捕捉词语之间依时序产生的复杂依赖关系。传统的神经网络结构在处理这种序列依赖时显得力不从心,而循环神经网络(RNN) 曾被视为…...

Springboot社区养老保险系统小程序
一、前言 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,社区养老保险系统小程序被用户普遍使用,为方…...

浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...

Mysql中select查询语句的执行过程
目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析(Parser) 2.4、执行sql 1. 预处理(Preprocessor) 2. 查询优化器(Optimizer) 3. 执行器…...
pycharm 设置环境出错
pycharm 设置环境出错 pycharm 新建项目,设置虚拟环境,出错 pycharm 出错 Cannot open Local Failed to start [powershell.exe, -NoExit, -ExecutionPolicy, Bypass, -File, C:\Program Files\JetBrains\PyCharm 2024.1.3\plugins\terminal\shell-int…...
DAY 26 函数专题1
函数定义与参数知识点回顾:1. 函数的定义2. 变量作用域:局部变量和全局变量3. 函数的参数类型:位置参数、默认参数、不定参数4. 传递参数的手段:关键词参数5 题目1:计算圆的面积 任务: 编写一…...