继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

SpringBoot微服务入门教程

三国纷争
关注TA
已关注
手记 445
粉丝 51
获赞 178
概述

本文介绍了如何快速搭建SpringBoot项目并创建微服务应用,涵盖了服务发现与注册、服务间通信以及应用部署与测试的全过程,帮助读者全面了解Spring Boot微服务入门的相关知识。

SpringBoot简介
SpringBoot的作用与优势

Spring Boot是基于Spring框架的一个项目,旨在简化Spring应用程序的开发。它提供了一种快速构建独立的、生产级别的基于Spring的应用程序的方式。通过配置约定优于配置的原则,Spring Boot使得开发者可以从繁杂的配置中解脱出来,专注于编写应用代码。

Spring Boot的主要优势包括:

  1. 自动化配置:Spring Boot通过约定优于配置的方式自动配置应用程序的大部分常见场景,减少了开发者需要写大量配置代码的工作量。
  2. 嵌入式服务器:支持内嵌Tomcat、Jetty或Undertow等Web服务器,无需手动部署到外部服务器。
  3. 起步依赖:通过一系列的起步依赖(Starters),使得引入第三方库变得非常容易。
  4. 自动装配:自动装配所需的Bean,减少手动配置。
  5. 命令行接口:提供了一个非常方便的命令行界面,可以用来运行Spring Boot应用程序或在生产环境中使用shell脚本。
  6. 内置的健康检查:提供了健康检查端点,方便监控和维护应用程序。
  7. 外部化配置:支持从不同来源(如环境变量、命令行参数、系统属性、YAML或属性文件等)加载配置。

示例代码

例如,以下代码展示了如何使用Spring Boot的起步依赖来添加Web支持:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>
快速搭建SpringBoot项目

使用Spring Initializr快速创建项目

Spring Initializr是一个在线的依赖管理工具,提供了快速创建Spring Boot项目的能力。访问 Spring Initializr,选择合适的项目设置,如构建器(Maven/Gradle)、语言(Java/Kotlin)、Java版本、项目元数据等,然后点击“生成”按钮下载压缩包。

使用IDE创建项目

使用IntelliJ IDEA创建SpringBoot项目

  1. 打开IntelliJ IDEA,选择“File” -> “New” -> “Project”。
  2. 在打开的窗口中,选择“Spring Initializr”。
  3. 在“Group”和“Artifact”中输入你的项目名称和版本信息。
  4. 选择语言(Java)和版本。
  5. 选择操作系统(Linux/Mac/Windows)。
  6. 选择构建器(Maven/Gradle)。
  7. 勾选需要的依赖,例如Spring Web。
  8. 点击“Finish”按钮,等待IntelliJ IDEA创建项目。

添加依赖

pom.xmlbuild.gradle中添加所需的依赖,例如Spring Web。

pom.xml示例:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

build.gradle示例:

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

运行SpringBoot应用

编写一个简单的Spring Boot应用,例如创建一个简单的REST控制器。

HelloController.java示例:

package com.example.demo;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {

    @GetMapping("/hello")
    public String hello() {
        return "Hello, World!";
    }
}

运行此应用,可以通过IDE的运行工具或者使用命令行命令。

命令行运行示例:

mvn spring-boot:run

测试应用

在浏览器中访问:http://localhost:8080/hello,应显示Hello, World!

微服务概念介绍
微服务的基本概念

微服务架构是一种将应用程序构建为一组小型、独立的服务的方式。每个服务都可以独立部署、升级、扩展和重启,而不会影响到其他服务。这种架构使得团队能够更快速地开发、测试和部署应用程序,提高开发效率和应用的灵活性。

示例代码

以下是一个简单的微服务应用示例,展示如何使用Spring Boot创建一个微服务:

package com.example.microservice;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class MicroserviceApplication {
    public static void main(String[] args) {
        SpringApplication.run(MicroserviceApplication.class, args);
    }
}

微服务架构的特点包括:

  1. 模块化:每个微服务都是一个独立的模块,具有明确的职责边界。
  2. 独立部署:每个服务可以独立部署,仅需维护相关依赖。
  3. 轻量级通信:服务间的通信通常通过HTTP/REST、gRPC、消息队列等方式实现。
  4. 容错性:每个服务具有独立的故障处理机制,有利于系统整体的稳定性。
  5. 松耦合:服务之间尽量保持低耦合,降低依赖关系。
微服务架构的优势
  1. 快速部署:微服务可以快速迭代和部署,无需等待其他服务的改动。
  2. 易扩展性:可以根据业务需求灵活扩展服务功能。
  3. 维护简便:每个服务可以独立维护,简化了软件维护工作。
  4. 容错性好:单个服务出现问题不会影响整个系统。
  5. 技术多元化:可以使用不同的技术栈来开发和部署不同的服务。
创建第一个SpringBoot微服务应用
使用IntelliJ IDEA创建SpringBoot项目

创建项目

  1. 打开IntelliJ IDEA,选择“File” -> “New” -> “Project”。
  2. 在打开的窗口中,选择“Spring Initializr”。
  3. 在“Group”和“Artifact”中输入你的项目名称和版本信息。
  4. 选择语言(Java)和版本。
  5. 选择操作系统(Linux/Mac/Windows)。
  6. 选择构建器(Maven/Gradle)。
  7. 勾选需要的依赖,例如Spring Web。
  8. 点击“Finish”按钮,等待IntelliJ IDEA创建项目。

添加依赖

pom.xmlbuild.gradle中添加所需的依赖,例如Spring Web。

pom.xml示例:

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

build.gradle示例:

dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
}

编写微服务应用

创建一个简单的Spring Boot控制器,提供一个简单的HTTP接口。

HelloController.java示例:

package com.example.demo;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloController {

    @GetMapping("/hello")
    public String hello() {
        return "Hello, World!";
    }
}

运行应用

在IDE中运行项目,或者使用命令行命令。

命令行运行示例:

mvn spring-boot:run

测试应用

在浏览器中访问:http://localhost:8080/hello,应显示Hello, World!

微服务中的服务发现与注册
使用Eureka实现服务注册与发现

Eureka是Netflix开源的一个服务注册与发现组件,广泛应用于微服务架构中。它提供了服务的注册、发现和负载均衡等功能,支持在微服务架构中进行服务治理。

安装Eureka Server

  1. 添加Eureka依赖到pom.xmlbuild.gradle

pom.xml示例:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

build.gradle示例:

implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
  1. 设置Eureka Server的配置文件application.yml

application.yml示例:

server:
  port: 8761

spring:
  application:
   name: eureka-service

eureka:
  client:
   register-with-eureka: false
   fetch-registry: false
   # 配置eureka服务地址
   service-url:
     defaultZone: http://localhost:8761/eureka/

运行Eureka Server

将Eureka Server作为Spring Boot应用运行。

启动类示例:

package com.example.eurekaserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

配置服务注册

在微服务中添加Eureka的依赖,并配置服务注册到Eureka Server。

pom.xml示例:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

build.gradle示例:

implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'

配置服务注册到Eureka Server。

application.yml示例:

server:
  port: 8081

spring:
  application:
    name: demo-service
eureka:
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/

运行微服务

将微服务应用作为Spring Boot应用运行,并观察Eureka Server界面,确认服务注册成功。

启动类示例:

package com.example.demoservice;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DemoServiceApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoServiceApplication.class, args);
    }
}
实现服务间通信
使用Feign实现服务间远程调用

Feign是Netflix开源的一个声明式Web服务客户端,使得编写服务客户端变得更加容易。它可以在微服务架构中用于服务间调用,简化了HTTP请求的编写和维护。

添加Feign依赖

在微服务中添加Feign的相关依赖。

pom.xml示例:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

build.gradle示例:

implementation 'org.springframework.cloud:spring-cloud-starter-openfeign'

配置Feign Client

在微服务中配置Feign Client,通过注解@FeignClient定义服务间的接口。

FeignClient示例:

package com.example.demoservice;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;

@FeignClient(name = "demo-service", url = "http://localhost:8081")
public interface DemoServiceClient {
    @GetMapping("/hello")
    String sayHello(@RequestParam("name") String name);
}

调用服务

在微服务中调用其他服务提供的接口。

调用示例:

package com.example.demoservice;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class DemoController {

    @Autowired
    private DemoServiceClient demoServiceClient;

    @GetMapping("/call")
    public String call() {
        return demoServiceClient.sayHello("Feign");
    }
}

测试服务调用

在浏览器中访问:http://localhost:8080/call,应显示Hello, Feign!

应用部署与测试
使用Docker部署微服务应用

Docker是一种容器化技术,可以将应用和其依赖关系打包成一个可移植的、自包含的容器,使得应用在不同的环境中都能保持一致的行为。使用Docker部署微服务应用可以简化部署流程,提高部署的效率和一致性。

创建Dockerfile

为微服务应用创建一个Dockerfile,定义构建镜像的指令。

Dockerfile示例:

# 使用官方的Java运行时镜像作为基础镜像
FROM openjdk:11-jre-slim

# 设置工作目录
WORKDIR /app

# 将JAR包复制到容器中
COPY target/*.jar app.jar

# 容器启动后执行的命令
ENTRYPOINT ["java", "-jar", "app.jar"]

构建镜像

使用Docker构建指定的镜像。

docker build -t demo-service:latest .

运行容器

运行容器,指定端口映射。

docker run -d -p 8080:8080 --name demo-service demo-service:latest
使用Postman测试微服务接口

Postman是一个强大的API测试工具,支持HTTP请求的发送和结果的查看,适合用来测试微服务接口。

创建请求

在Postman中创建一个新的请求,指定URL和请求方法。

请求示例:

  • URLhttp://localhost:8080/call
  • MethodGET

发送请求

点击“Send”按钮发送请求,查看返回的响应。

示例

在Postman中,发送请求后,查看响应结果,应显示:Hello, Feign!

通过以上步骤,我们了解了如何快速搭建Spring Boot项目,创建微服务应用,实现服务发现与注册,以及使用Feign进行服务间通信。此外,我们还学习了如何使用Docker部署微服务应用,并使用Postman测试微服务接口,为实际生产环境中的应用部署提供了有力支持。

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP