dubbo + zookeeper + spring Boot框架整合与dubbo泛型调用演示2

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
云原生网关 MSE Higress,422元/月
简介: dubbo + zookeeper + spring Boot框架整合与dubbo泛型调用演示

 

Repository设置(可选)

修改%MAVEN_HOME%\conf\setting.xml文件

找到以下内容,修改<localRepository>元素内容

 <!-- localRepository

  | The path to the local repository maven will use to store artifacts.

  |

  | Default: ${user.home}/.m2/repository

 <localRepository>/path/to/local/repo</localRepository>

 -->

 <localRepository>D:/Program Files/apache-maven-3.5.4/repo</localRepository>

 

说明:

localRepository元素节点用于配置本地仓库,默认是被注释掉的(默认值为C:\Users\用户名.m2),例中未去掉注释,直接新增了一个节点值,并设置元素值为指定目录

3. 本地仓库起到了一个缓存的作用,当我们从maven中获取jar包的时候,maven首先会在本地仓库中查找,如果本地仓库有则返回;如果没有则从远程仓库中获取包,并在本地库中保存。

此外,我们在maven项目中运行mvn install,项目将会自动打包并安装到本地仓库中

 

配置测试,cmd命令行输入以下命令

mvn help:system

 

等待命令成功执行,可见如下输出,并在配置的本地仓库下生成一携带n多文件的org目录

 

 

参考链接

https://maven.apache.org/install.html

 

 

利用maven打dubbo-admin-0.0.1-SNAPSHOT.jar包

解压incubator-dubbo-master.zip至目标路径(例中为 F:\DownLoads\incubator-dubbo-ops-master)

 

cmd进入目标目录并执行maven编译命令

mvn install -Dmaven.test.skip=true

 

如下图,执行完毕后会看到如下输出

 

 

说明:如上图,maven编译打包成功后,会自动复制jar包及其它一些必备文件到本地仓库。

 

如上说明,我们可以直接进入到目标目录下对应工程的target目录下,获取我们需要的jar包:dubbo-admin-0.0.1-SNAPSHOT.jar (例中为:

F:\DownLoads\incubator-dubbo-ops-master\dubbo-admin\target\dubbo-admin-0.0.1-SNAPSHOT.jar)

 

附下载地址:

https://pan.baidu.com/s/1dm1ftVonqb_8gK4DNwn_gw

 

 

dubbo-admin控制台运行与配置

配置(可选)

修改jar包application.properties(路径 dubbo-admin-0.0.1-SNAPSHOT.jar\BOOT-INF\classes\application.properties),更改zookeeper地址,例中默认如下

dubbo.registry.address=zookeeper://127.0.0.1:2181

 

运行

上传dubbo-admin-0.0.1-SNAPSHOT.jar至linux服务器,执行以下命令

# java -jar dubbo-admin-0.0.1-SNAPSHOT.jar

如下,执行成功后会显示图示命令

 

防火墙开放端口

# firewall-cmd --permanent --zone=public --add-port=7001/tcp

# firewall-cmd --reload

 

验证,浏览器打开服务器地址(例中为 192.168.31.192:7001),如下

 

 

输入账号\密码:root\root

 

 

 

参考链接

http://dubbo.apache.org/en-us/docs/admin/install/admin-console.html

 

 

编码

Maven mirrors配置

如下设置

<mirrors>

   <!-- mirror

    | Specifies a repository mirror site to use instead of a given repository. The repository that

    | this mirror serves has an ID that matches the mirrorOf element of this mirror. IDs are used

    | for inheritance and direct lookup purposes, and must be unique across the set of mirrors.

    |

   <mirror>

     <id>mirrorId</id>

     <mirrorOf>repositoryId</mirrorOf>

     <name>Human Readable Name for this Mirror.</name>

     <url>http://my.repository.com/repo/path</url>

   </mirror>

    -->

   <mirror>

       <id>alimaven</id>

       <mirrorOf>central</mirrorOf>

       <name>aliyun maven</name>

       <url>http://maven.aliyun.com/nexus/content/repositories/central/</url>

   </mirror>

   <mirror>

       <id>alimaven</id>

       <name>aliyun maven</name>

       <url>http://maven.aliyun.com/nexus/content/groups/public/</url>

       <mirrorOf>central</mirrorOf>

   </mirror>

   <mirror>

       <id>central</id>

       <name>Maven Repository Switchboard</name>

       <url>http://repo1.maven.org/maven2/</url>

       <mirrorOf>central</mirrorOf>

   </mirror>

   <mirror>

       <id>repo2</id>

       <mirrorOf>central</mirrorOf>

       <name>Human Readable Name for this Mirror.</name>

       <url>http://repo2.maven.org/maven2/</url>

   </mirror>

   <mirror>

       <id>ibiblio</id>

       <mirrorOf>central</mirrorOf>

       <name>Human Readable Name for this Mirror.</name>

       <url>http://mirrors.ibiblio.org/pub/mirrors/maven2/</url>

   </mirror>

   <mirror>

       <id>jboss-public-repository-group</id>

       <mirrorOf>central</mirrorOf>

       <name>JBoss Public Repository Group</name>

       <url>http://repository.jboss.org/nexus/content/groups/public</url>

   </mirror>

   <mirror>

       <id>google-maven-central</id>

       <name>Google Maven Central</name>

       <url>https://maven-central.storage.googleapis.com

       </url>

       <mirrorOf>central</mirrorOf>

   </mirror>

   <!-- 中央仓库在中国的镜像 -->

   <mirror>

       <id>maven.net.cn</id>

       <name>oneof the central mirrors in china</name>

       <url>http://maven.net.cn/content/groups/public/</url>

       <mirrorOf>central</mirrorOf>

   </mirror>

 </mirrors>

 

Idea maven运行环境配置

可通过如下两种方式打开Settings界面

 

 

如下,设置Maven home directory,User Setting file, Local repository

 

 

 

设置Maven JVM参数

-Xms128m -Xmx512m -Duser.language=zh -Dfile.encoding=UTF-8

 

 

 

如上图,这一步也可以不执行,通过其它方式代替(注:方案未经过验证)

替代方案1:新建 系统环境变量,

变量名:MAVEN_OPTS

变量值:-Xms128m -Xmx512m -Duser.language=zh -Dfile.encoding=UTF-8

 

替代方案2:修改maven启动文件%maven_home%\bin\mvn.cmd(Linux mvn

添加MAVEN_OPTS变量

 

 

 

新建项目

新建父项目

File -> New -> Project -> Maven, 选择Project SDK,不勾选 Create from archetype,点击Next

 

 

如下,填写GroupId,ArtifactId,version,点击Next

 

 

 

如下,填写Project name, Project location,点击Finish

 

 

 

初始代码结构如下

 

 

 

修改上述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>

 

   <groupId>org.apache.dubbo</groupId>

   <artifactId>dubboDemo</artifactId>

   <version>1.0-SNAPSHOT</version>

 

   <!--设置打包类型为pom,目的是为了实现多模块项目-->

   <packaging>pom</packaging>

 

</project>

 

新建模块

新建以下三个模块

dubbo-demo-api: 公共服务api

dubbo-demo-provider: 服务提供者

dubbo-demo-consumer: 消费者

 

右键父项目 -> New -> Module,选择JDK,Next

 

 

 

如下,填写ArtifactId, Next

 

 

 

如下,填写 Module name,其它默认,Next

 

 

 

参考以上,再新建两个模块,模块名称及artifactId分别为dubbo-demo-provider,dubbo-demo-consumer

 

建好模块后,代码结构如下

 

 

 

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
11天前
|
数据采集 监控 前端开发
二级公立医院绩效考核系统源码,B/S架构,前后端分别基于Spring Boot和Avue框架
医院绩效管理系统通过与HIS系统的无缝对接,实现数据网络化采集、评价结果透明化管理及奖金分配自动化生成。系统涵盖科室和个人绩效考核、医疗质量考核、数据采集、绩效工资核算、收支核算、工作量统计、单项奖惩等功能,提升绩效评估的全面性、准确性和公正性。技术栈采用B/S架构,前后端分别基于Spring Boot和Avue框架。
|
20天前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
31 0
|
15天前
|
前端开发 Java 数据库连接
Spring 框架:Java 开发者的春天
Spring 框架是一个功能强大的开源框架,主要用于简化 Java 企业级应用的开发,由被称为“Spring 之父”的 Rod Johnson 于 2002 年提出并创立,并由Pivotal团队维护。
36 1
Spring 框架:Java 开发者的春天
|
2天前
|
Dubbo Java 应用服务中间件
深入探讨了“dubbo+nacos+springboot3的native打包成功后运行出现异常”的原因及解决方案
本文深入探讨了“dubbo+nacos+springboot3的native打包成功后运行出现异常”的原因及解决方案。通过检查GraalVM版本兼容性、配置反射列表、使用代理类、检查配置文件、禁用不支持的功能、查看日志文件、使用GraalVM诊断工具和调整GraalVM配置等步骤,帮助开发者快速定位并解决问题,确保服务的正常运行。
11 1
|
7天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
20 2
|
6天前
|
消息中间件 NoSQL Java
springboot整合常用中间件框架案例
该项目是Spring Boot集成整合案例,涵盖多种中间件的使用示例,每个案例项目使用最小依赖,便于直接应用到自己的项目中。包括MyBatis、Redis、MongoDB、MQ、ES等的整合示例。
52 1
|
14天前
|
Java 数据库连接 开发者
Spring 框架:Java 开发者的春天
【10月更文挑战第27天】Spring 框架由 Rod Johnson 在 2002 年创建,旨在解决 Java 企业级开发中的复杂性问题。它通过控制反转(IOC)和面向切面的编程(AOP)等核心机制,提供了轻量级的容器和丰富的功能,支持 Web 开发、数据访问等领域,显著提高了开发效率和应用的可维护性。Spring 拥有强大的社区支持和丰富的生态系统,是 Java 开发不可或缺的工具。
|
13天前
|
Dubbo 应用服务中间件 Apache
Dubbo 应用切换 ZooKeeper 注册中心实例,流量无损迁移
如果 Dubbo 应用使用 ZooKeeper 作为注册中心,现在需要切换到新的 ZooKeeper 实例,如何做到流量无损?
17 4
|
21天前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
2月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2