微服务之Rest构建分布式微服务&服务调用Rest和Dubbo(集群版Eureka Server服务注册中心

Spring Cloud:

  • 在SpringBoot基础上提供了一套微服务的解决方案,包括注册、发现、配置中心服务网关、负载均衡、熔断器,是一系列框架的集合,利用springBoot 的开发便利性巧妙的便利简化了分布式开发。比如发现注册、配置总线 ;
  • 在Spring Cloud微服务的实际项目开发中,多个微服务之间不仅是相对独立的,而且也是相对关联的;也就是说,微服务之间需要相互访问,多个微服务之间的接口可能会被互相多次调用,我们称之为微服务;
  • 服务之间的接口实现相互调用,即服务的调用:RPC、Rest;
  • 常规的微服务有两种类型:一种是基于dubbo的微服务架构、另外一种是基于Spring Cloud的微服务架构。Dubbo是一个RPC框架,而Rest可以实现接口相互调用。也就是说,rest与dobbo是服务调用,eureka和zookeeper是服务注册与发现,rest中的服务注册和发现的功能是用eureka来实现的;dubbo 中服务注册和发现的功能是用 zookeeper 来实现的。

Spring Boot 和 Spring Cloud关系:

  • Spring Boot是Spring的一套快速配置,Spring Colud是一个基于Spring Boot实现的云应用开发;
  • Spring Boot 专注于单个个体服务开发,Spring Cloud 关注于全局的部署和开发;
  • Spring Cloud离不开Spring Boot

(目前Spring Cloud 集合21种分布式架构技术

Rest构建分布式微服务实战Demo

项目需求:以商品管理模块,做一个微服务架构的通用案例消费者Consumer(Client),通过Rest调用提供者Provider(Server) 提供商品的管理服务


Eureka服务的注册和发现:是Spring Cloud 提供服务中心来管理服务信息

为什么需要注册中心: 要进行远程调用就需要知道服务端的ip和端口,而注册中心帮助我们管理这些服务端口和ip

Spring Cloud Eureka 是Netfix公司对Eureka的二次封装,实现了服务治理功能,提供EurekaServer、EurekaClient,服务端即是服务注册中心,客户端完成微服务向Eureka服务的注册和发现
 


准备工作

1.开发环境:Spring Boot2.0.7版本+Spring Cloud的版本为Finchley SR2

2.修改Maven配置文件,在apache-maven-3.5.2\conf\settings.xml中

  在<mirrors></mirrors>标签中添加:

        <mirror>
		<id>alimaven</id>
		<mirrorOf>central</mirrorOf>
		<name>aliyun maven</name>
		<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
	</mirror>

  在<profiles></profiles>标签中添加:

    <!--在profiles 标签下指定jdk 版本-->
	<profile>

		<id>jdk-1.8</id>

		<activation>

			<activeByDefault>true</activeByDefault>

			<jdk>1.8</jdk>

		</activation>

		<properties>

			<maven.compiler.source>1.8</maven.compiler.source>

			<maven.compiler.target>1.8</maven.compiler.target>

			<maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>

		</properties>

	</profile>

3.Maven的分模块架构

  1. 父工程
  2. 公共模块(子工程)
  3. 服务提供者(子工程)
  4. 服务消费者(子工程)
  5. 集群版Eureka Server 服务注册中心(子工程,两个)

注:搭建集群版Eureka Server 服务注册中心要修改C:\Windows\System32\drivers\etc下的hosts,因为要集群两个,所以添加连个eureka服务端的实例

127.0.0.1 eureka6001.com
127.0.0.1 eureka6002.com

项目预览


基本步骤

构建父工程(打包方式pom)

构建公共模块(子工程)

构建服务提供者(子工程,打包方式jar)

  1.         pom.xml文件引入依赖
  2. ​        配置application.yml
  3. ​        数据库脚本
  4. ​        创建Mapper接口
  5. ​        Mybatis的配置
  6. ​        创建服务层
  7. ​        控制层---服务者
  8. ​        创建主启动类
  9. ​        功能测试

构建服务消费者(子工程,打包方式jar)

  1. ​        创建module
  2.         pom.xml文件引入依赖
  3. ​        配置application.yml
  4. ​        自定义Rest相关配置类
  5. ​        创建控制层---消费者
  6. ​        主启动类
  7. ​        功能测试

搭建集群版Eureka Server 服务注册中心(子工程,打包方式jar,集群以两个为例)

  1.         创建module
  2.         pom.xml文件引入依赖
  3.         配置application.yml
  4.         主启动类
  5.         测试

实现细节

0.创建数据库、数据表

1.构建microService-parent父工程,pom.xml引入依赖

    <!--打包方式pom-->
    <packaging>pom</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值