SpringCloud01——项目演变、微服务远程调用三种方式、springcloud介绍、nacos注册中心

发布于:2025-07-30 ⋅ 阅读:(42) ⋅ 点赞:(0)

目录

一、项目架构演变过程

1、单体应用架构

2、垂直应用架构

3、分布式服务架构

4、流动计算架构(SOA架构)

5、微服务架构

二、如何实现微服务远程调用

1、HttpClient工具类(springboot中)

形式1:调用第三方的公开服务

形式2:创建两个微服务,两个服务之间进行远程服务调用

2、RestTemplate工具类(springboot中)

3、openFeign组件(springcloud中)

三、微服务架构的实现方式

1、dubbo(都是java语言开发的)

2、springcloud(不限制语言)

四、SpringCloud的简介

4.1初识SpringCloud

4.2 为什么使用SpringCloud

4.3 SpringCloud相关组件(框架)

五、nacos注册中心

1、搭建nacos注册中心

2、注册微服务到nacos注册中心


一、项目架构演变过程

1、单体应用架构

当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此

时,用于简化增删改查工作量的数据访问框架(ORM)是关键。

适用于小型网站,小型管理系统,将所有功能都部署到一个功能里,简单易用。

缺点:1、性能扩展比较难 2、协同开发问题 3、不利于升级维护

2、垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个

应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。

通过切分业务来实现各个模块独立部署降低了维护和部署的难度,团队各司其职更易管

理,性能扩展也更方便,更有针对性。

缺点:公用模块无法重复利用,开发性的浪费

3、分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐

形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务

复用及整合的分布式服务框架是关键。

4、流动计算架构(SOA架构)

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中

心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调

度和治理中心(SOA)[Service Oriented Architecture]是关键

5、微服务架构

微服务架构的特点

单一职责:微服务架构中每一个服务(模块项目)都对应唯一的业务能力,做到单一职责

:微服务的服务拆分粒度很小,例如一个用户管理就可以作为一个服务。每个服务虽小,但“五脏俱全”。

面向服务:面向服务是说每个服务都要对外暴露Restful风格服务接口API。并不关心服务的

技术实现,做到与平台和语言无关,也不限定用什么技术实现,只要提供Restful的接口即可。

自治:自治是说服务间互相独立,互不干扰

  • 团队独立:每个服务都是一个独立的开发团队,人数不能过多。
  • 技术独立:因为是面向服务,提供Restfule接口,使用什么技术没有别人干涉
  • 前后端分离:采用前后端分离开发,提供统一Rest接口,后端不用再为PC、移动段开发不同接口
  • 数据库分离:每个服务都使用自己的数据源
  • 部署独立,服务间虽然有调用,但要做到服务重启不影响其它服务。有利于持续集成和持续交付。每个服务都是独立的组件,可复用,可替换,降低耦合,易维护

二、如何实现微服务远程调用

1、HttpClient工具类(springboot中)

<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
</dependency>

形式1:调用第三方的公开服务

package com.hl.web;
​
import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.util.EntityUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
​
import java.io.IOException;
​
@RestController
public class HelloController {
    @RequestMapping("/hello")
    public Object hello() throws IOException {
        //发起网络请求,调用百度接口
        //1、构建一个HttpClient对象
        CloseableHttpClient client = HttpClientBuilder.create().build();
        //2、封装一个httpGet 或者 post请求
        HttpGet request = new HttpGet("http://www.baidu.com");
        //3、发起网络请求,获取响应对象
        CloseableHttpResponse response = client.execute(request);
        //4、解析响应结果
        Integer code = response.getStatusLine().getStatusCode();
        System.out.println("响应状态码:"+code);
        HttpEntity entity = response.getEntity();
        return EntityUtils.toString(entity);
    }
}

形式2:创建两个微服务,两个服务之间进行远程服务调用

http://localhost:8081/user/info

@RestController
@RequestMapping("/user")
public class UserController {
    @RequestMapping("/info")
    public User info(){
        return new User(1,"admin");
    }
}
@RequestMapping("/info")
public Object info() throws IOException {
    //发起网络请求,调用百度接口
    //1、构建一个HttpClient对象
    CloseableHttpClient client = HttpClientBuilder.create().build();
    //2、封装一个httpGet 或者 post请求
    HttpGet request = new HttpGet("http://localhost:8081/user/info");
    //3、发起网络请求,获取响应对象
    CloseableHttpResponse response = client.execute(request);
    //4、解析响应结果
    Integer code = response.getStatusLine().getStatusCode();
    System.out.println("响应状态码:"+code);
    HttpEntity entity = response.getEntity();
    String s = EntityUtils.toString(entity);
    User user = JSONObject.parseObject(s,User.class);
    return user;
}

2、RestTemplate工具类(springboot中)

@SpringBootApplication
public class ProjectAApplication {
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}
@RestController
public class HelloController {
    @Autowired
    private RestTemplate restTemplate;
​
    @RequestMapping("/getUser")
    public User getUser(){
        return restTemplate.getForObject("http://localhost:8081/user/info", User.class);
    }
}

3、openFeign组件(springcloud中)

三、微服务架构的实现方式

1、dubbo(都是java语言开发的)

有Alibaba研发,后转给apache维护。

2、springcloud(不限制语言)

spring组织提供的。 http协议远程调用

四、SpringCloud的简介

4.1初识SpringCloud

微 服 务 是 一 种 架 构 方 式 , 最 终 肯 定 需 要 技 术 架 构 去 实 施 。
微 服 务 的 实 现 方 式 很 多 , 但 是 最 火 的 莫 过 于 Spring Cloud了 。 为 什 么 ?

  • 后台硬:作为Spring家族的一员,有整个Spring全家桶靠山,背景十分强大。
  • 技术强:Spring作为Java领域的前辈,可以说是功力深厚。有强力的技术团队支撑,一般人还真比不了
  • 群众基础好:可以说大多数程序员的成长都伴随着Spring框架,试问:现在有几家公司开发不用Spring?SpringCloud与Spring的各个框架无缝整合,对大家来说一切都是熟悉的配方,熟悉的味道。
  • 使用方便:相信大家都体会到了SpringBoot给我们开发带来的便利,而SpringCloud完全支持SpringBoot的开发,用很少的配置就能完成微服务框架的搭建

4.2 为什么使用SpringCloud

  • SpringCloud是Spring旗下的项目之一,官网地址:http://projects.spring.io/spring-cloud/
  • Spring最擅长的就是集成,把世界上最好的框架拿过来,集成到自己的项目中。
  • SpringCloud也是一样,它将现在非常流行的一些技术整合到一起,实现了诸如:配置管理,服务发现,智能路由,负载均衡,熔断器,控制总线,集群状态等等功能。

4.3 SpringCloud相关组件(框架)

  • Eureka:服务治理组件,包含服务注册中心,服务注册与发现机制的实现。(服务治理,服务注册/发现) ,类似的产品还有Consul、Nacos
  • Spring Cloud GateWay:网关组件,提供智能路由,访问过滤功能 ,类似产品还有Zuul
  • Ribbon:客户端负载均衡的服务调用组件(客户端负载均衡)
  • Feign:服务调用,给予Ribbon和Hystrix的声明式服务调用组件 (声明式服务调用) (发送Http请求访问)
  • Hystrix:容错管理组件,实现断路器模式,帮助服务依赖中出现的延迟和故障提供强大的容错能力。(熔断、断路器,容错)

nacos注册中心

loadBalancer

openFeign

gateway

nacos配置中心

sentinel

五、nacos注册中心

1、搭建nacos注册中心

下载解压缩到非中文目录

启动nacos服务(默认集群模式启动)

以单机版模式启动服务
​startup.cmd -m standalone

http://localhost:8848/nacos/

用户名nacos 密码nacos

2、注册微服务到nacos注册中心

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
@SpringBootApplication
@EnableDiscoveryClient //启用服务发现组件的客户端
public class ProjectCApplication {
​
    public static void main(String[] args) {
        SpringApplication.run(ProjectCApplication.class, args);
    }
​
}
# Nacos帮助文档: https://nacos.io/zh-cn/docs/concepts.html
#当前项目在nacos注册中心暴漏的服务名
spring.application.name=projectC
# Nacos认证信息
spring.cloud.nacos.discovery.username=nacos
spring.cloud.nacos.discovery.password=nacos
# Nacos 服务发现与注册配置,其中子属性 server-addr 指定 Nacos 服务器主机和端口
spring.cloud.nacos.discovery.server-addr=localhost:8848
# 注册到 nacos 的指定 namespace,默认为 public
spring.cloud.nacos.discovery.namespace=public
# 应用服务 WEB 访问端口
server.port=8082


网站公告

今日签到

点亮在社区的每一天
去签到