微服务框架Dubbo环境部署实战

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
日志服务 SLS,月写入数据量 50GB 1个月
云原生网关 MSE Higress,422元/月
简介: 微服务框架Dubbo环境部署的实战指南,涵盖了Dubbo的概述、服务部署、以及Dubbo web管理页面的部署,旨在指导读者如何搭建和使用Dubbo框架。

一.dubbo概述

1.什么是微服务

微服务(Microservices Architecture)是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。在所有情况下,每个任务代表着一个小的业务能力。

微服务是指开发一个单个小型的但有业务功能的服务,每个服务都有自己的处理和轻量通讯机制,可以部署在单个或多个服务器上。

微服务也指一种种松耦合的、有一定的有界上下文的面向服务架构。也就是说,如果每个服务都要同时修改,那么它们就不是微服务,因为它们紧耦合在一起;如果你需要掌握一个服务太多的上下文场景使用条件,那么它就是一个有上下文边界的服务。

2.dubbo介绍

Apache Dubbo是一款高性能,轻量级的开源服务框架。

Apache提供六大核心能力:
    - 面向接口代理的高性能RPC调用
    - 智能容错和负载均衡
    - 服务自动注册和发现
    - 高度可扩展性
    - 运行期间流量调度
    - 可视化的服务治理与运维


阿里云微服务:
    https://promotion.aliyun.com/ntms/act/edasdubbo.html

Dubbo官网:
    https://cn.dubbo.apache.org/zh/index.html

SDK手册:
    https://cn.dubbo.apache.org/zh/docs3-v2/

Golang编程SDK接口:
       https://cn.dubbo.apache.org/zh/docs3-v2/golang-sdk/refer/use_dubbogo_cli/

3.dubbo架构

角色 角色说明
Provider 暴露服务的服务提供方
Consumer 调用远程服务的服务消费方
Registry 服务注册与发现的注册中心
Monitor 统计服务的调用次数和调用时间的监控中心
Container 服务运行容器
如上图所示,调用关系说明如下:
    - 服务容器负责启动,加载,运行服务提供者;
    - 服务提供者在启动时,向注册中心注册自己提供的服务;
    - 服务消费者在启动时,想注册中心订阅自己所需的服务;
    - 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长链接推送变更数据给消费者;
    - 服务消费者,同提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用;
    - 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到注册中心;


Dubbo服务框架的工作流程如下:
    - 提供者在启动时,在注册中心注册服务;
    - 消费者在起订是,在注册中心订阅所需的服务;
    - 注册中心返回提供者地址列表给消费者,如果提供者发生变更,注册中心将推送变更数据给消费者;
    - 消费者基于软负载均衡算法,从提供者地址列表中选一个提供者进行调用;


对于注册中心,我们不仅仅可以选择zookeeper,当然nacos也是一个不错的选择哟。
    - https://zookeeper.apache.org/
    - https://nacos.io/zh-cn/

二.部署dubbo服务

1.部署JDK环境

- Ubuntu系统:
    - apt -y install openjdk-8-jdk


- CentOS系统:
    - yum -y install java-1.8.0-openjdk-devel nc

2.部署provider组件

    (1)解压provider软件包
tar xf dubbo-demo-provider-2.1.5-assembly.tar.gz -C /usr/local/


    (2)编辑"dubbo.properties"文件
vim /usr/local/dubbo-demo-provider-2.1.5/conf/dubbo.properties 
...
# 禁用默认的组播注册中心。
# dubbo.registry.address=multicast://224.5.6.7:1234
...
# 将默认的单个节点的配置注释掉
#dubbo.registry.address=zookeeper://127.0.0.1:2181
# 配置zookeeper集群地址
dubbo.registry.address=zookeeper://10.0.0.31:2181 | zookeeper://10.0.0.32:2181 | zookeeper://10.0.0.33:2181


    (3)如上图所示,启动provider
/usr/local/dubbo-demo-provider-2.1.5/bin/start.sh 




官方测试dubbo样例:
    https://github.com/apache/dubbo/tree/master/dubbo-demo

3.验证zookeeper的znode信息

如上图所示,会自动创建一个/dubbo的znode哟,最后一层的子节点是一个临时znode哟。

4.部署consumer环境

    (1)解压consumer的软件包
tar xf dubbo-demo-consumer-2.1.5-assembly.tar.gz -C /usr/local/


    (2)编辑"dubbo.properties"文件
# 禁用默认的组播注册中心。
# dubbo.registry.address=multicast://224.5.6.7:1234
...
...
# 将默认的单个节点的配置注释掉
#dubbo.registry.address=zookeeper://127.0.0.1:2181
# 配置zookeeper集群地址
dubbo.registry.address=zookeeper://10.0.0.31:2181 | zookeeper://10.0.0.32:2181 | zookeeper://10.0.0.33:2181


    (3)启动consumer服务,启动成功后可以看到如上图所示的配置哟
/usr/local/dubbo-demo-consumer-2.1.5/bin/start.sh


温馨提示:
    如下图所示,当我们的消费者启动成功后,这意味着生产者也会得到响应哟,会有日志生成!可以明显看到日志来自哪个节点。

5.启动多个消费者并查看生产者日志

如上图所示,我在dubbo33节点上启动了新启动了consumer服务。在此之前,我已经在dubbo31节点启动过消费者啦。


如下图所示,当有多个消费启动时,可以观察生产者日志,有多个消费者请求哟。

三.部署dubbo web管理页面

1.下载dubbo-admin的软件包

如上图所示,需要下载"dubbo-admin"的软件包哟。

官网地址:
    https://github.com/apache/dubbo-admin

2.安装maven环境

    (1)安装maven环境
apt -y install maven

注意,Linux如果直接使用yum安装的话后期编译时可能会提示版本过低,建议手动下载较高的版本安装哟!(会提示报错, 根据报错选择大于该版本安装即可)

    (2)配置镜像加速
vim /etc/maven/settings.xml
...
146   <mirrors>
147     <!-- 添加阿里云镜像加速 -->
148     <mirror>
149        <id>nexus-aliyun</id>
150        <mirrorOf>*</mirrorOf>
151        <name>Nex aliyun</name>
152        <url>http://maven.aliyun.com/nexus/content/groups/public</url>
153     </mirror>
...
166   </mirrors>

3.编译安装dubbo-admin

    (1)解压压缩包(或者直接去官网git clone拉取代码也可以哟~)
unzip dubbo-admin-develop.zip 


    (2)切换到源码目录
cd dubbo-admin-develop/


    (3)修改zookeeper的实际IP地址
vim dubbo-admin-server/src/main/resources/application.properties 
...
# 修改zk集群地址
admin.registry.address=zookeeper://10.0.0.31:2181,10.0.0.32:2181,10.0.0.33:2181
admin.config-center=zookeeper://10.0.0.31:2181,10.0.0.32:2181,10.0.0.33:2181
admin.metadata-report.address=zookeeper://10.0.0.31:2181,10.0.0.32:2181,10.0.0.33:2181


    (4)优化maven配置
echo 'export MAVEN_OPTS="-Xmx2g -Xms2g"' >> /etc/profile.d/maven.sh
source  /etc/profile.d/maven.sh


    (5)部署nodejs环境
apt update
apt -y install npm
npm config get registry
npm config set registry http://registry.npm.taobao.org
npm config get registry


    (6)执行JAVA编译并跳过单元测试,如上图所示,出现了成功字样,用时7分钟左右哈。
mvn clean install package -Dmaven.test.skip=true

4.启动dubbo-admin服务

java -jar dubbo-admin-distribution/target/dubbo-admin-0.5.0-SNAPSHOT.jar --server.port=8888


温馨提示:
    如上图所示,默认的初始用户名和密码均为"root/root"。

5.访问dubbo-admin的WebUI

如上图所示,咱们的服务部署成功啦。
相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
1月前
|
运维 Kubernetes Cloud Native
云原生时代下,如何高效构建与部署微服务
【9月更文挑战第8天】随着云计算技术的飞速发展,云原生已成为现代软件架构的重要趋势。本文将深入浅出地介绍云原生概念、微服务架构的优势以及如何在云平台上高效构建和部署微服务。我们将通过实际的代码示例,展示在Kubernetes集群上部署一个简单的微服务应用的过程,帮助读者理解云原生环境下的微服务开发和运维实践。
|
5天前
|
Kubernetes Docker 微服务
微服务实践k8s&dapr开发部署实验(1)服务调用(一)
微服务实践k8s&dapr开发部署实验(1)服务调用(一)
29 2
|
1月前
|
负载均衡 Dubbo NoSQL
Dubbo框架的1个核心设计点
Java领域要说让我最服气的RPC框架当属Dubbo,原因有许多,但是最吸引我的还是它把远程调用这个事情设计得很有艺术。
Dubbo框架的1个核心设计点
|
18天前
|
运维 持续交付 API
深入理解并实践微服务架构:从理论到实战
深入理解并实践微服务架构:从理论到实战
52 3
|
20天前
|
负载均衡 监控 Dubbo
分布式框架-dubbo
分布式框架-dubbo
|
21天前
|
缓存 负载均衡 Dubbo
Dubbo技术深度解析及其在Java中的实战应用
Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java分布式服务框架,它致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
43 6
|
2天前
|
Kubernetes 持续交付 Docker
利用 Docker 和 Kubernetes 实现微服务部署
【10月更文挑战第2天】利用 Docker 和 Kubernetes 实现微服务部署
|
4天前
|
Kubernetes Docker 微服务
微服务实践k8s&dapr开发部署实验(1)服务调用(二)
微服务实践k8s&dapr开发部署实验(1)服务调用(二)
28 0
|
1月前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
64 3
|
1月前
|
自然语言处理 Java 网络架构
解锁跨平台微服务新纪元:Micronaut与Kotlin联袂打造的多语言兼容服务——代码、教程、实战一次打包奉送!
【9月更文挑战第6天】Micronaut是一款轻量级、高性能的Java框架,适用于微服务开发。它支持Java、Groovy和Kotlin等多种语言,提供灵活的多语言开发环境。本文通过创建一个简单的多语言兼容服务,展示如何使用Micronaut及其注解驱动特性实现REST接口,并引入国际化支持。无论是个人项目还是企业应用,Micronaut都能提供高效、一致的开发体验,成为跨平台开发的利器。通过简单的配置和代码编写,即可实现多语言支持,展现其强大的跨平台优势。
39 2