iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >如何正确的使用springcloud
  • 681
分享到

如何正确的使用springcloud

2023-06-14 18:06:13 681人浏览 独家记忆
摘要

这期内容当中小编将会给大家带来有关如何正确的使用SpringCloud,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、微服务简介 Ⅰ、我对微服务的理解微服务是软件开发的一种架构方式,由单一的应用小程序构

这期内容当中小编将会给大家带来有关如何正确的使用SpringCloud,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

一、微服务简介

Ⅰ、我对微服务的理解

微服务是软件开发的一种架构方式,由单一的应用小程序构成的小服务;一个软件系统由多个服务组成;在微服务中,服务是细粒度的,协议是轻量级的(部署简单、性能开销小)

Ⅱ、为什么要使用微服务?

随着时代的发展,单体架构(mvc三层模型)越来越不能满足企业的要求;业务规模的不断扩大、团队开发人员的增多,使得单体架构出现了以下几个问题:

(1)部署效率低(比如代码量非常多,依赖的包非常多,那么每一次编译打包、部署测试的时间就会很久)
(2)团队开发成本高(如果某个模块出现问题,可能就要多人修改)
(3)高可用性低(打成war包部署之后,如果某一块出现了问题,其他模块都会受到影响)
(4)一旦代码膨胀(简单了说你写的代码量大,但功能没实现几个,浪费资源),上线就会变慢

SOA(面向服务编程)便出现了

如何正确的使用springcloud

SOA简介

SOA是一个组件模型,它将应用程序的不同功能单元(称为服务)进行拆分,并通过这些服务之间定义良好的接口和协议联系起来。

虽然解决了服务的启动时间,但服务化也有很大的缺点

耦合度较高(一个依赖可能另一个模块,另外一个模块又可能依赖其他模块)
2、公司成本高(每一个模块都要由相应的人员或者团队维护)

2014年,随着容器化技术的成熟以及 devops 文化的兴起,微服务便应运而生了

微服务的特点

服务细粒度
2.协议轻量级
3.部署简单
4.服务的独立维护性


二、spring cloud

Ⅰ、springcloud介绍

sprinGCloud是分布式微服务架构的一站式解决方案,是多种微服务架构落地技术的集合体。

分布式/版本化配置
2.服务注册和发现
3.路由
4.服务到服务的通话
5.负载均衡
6.断路器
7.全局
8.领导选举和集群状态
9.分布式消息传递

SpringCloud的官网地址:https://spring.io/projects/spring-cloud#overview

Ⅱ、boot和cloud的版本选型

进入springcloud官方页面:Https://spring.io/projects/spring-cloud#learn


2. LEARN->Reference Doc.

如何正确的使用springcloud

版本选择

如何正确的使用springcloud


三、springcloud初级项目体验

最近发现网络上很多springcloud入门体验都是关于消费-订单的小Demo,那我当然不能落后了(菜是原罪?)

PRE: 模拟服务间调用之流程分析

创建一个父项目(统一管理子模块依赖版本)
2、创建第一个子模块-----》订单服务模块
3、创建第二个子模块-----》客户消费模块

3.1、订单服务模块

编写代码之前应该先构思好流程,如果直接就去码代码,码了一会可能又要添添改改;还有可能做完项目之后又要对项目进行重构,这就是没有构思好流程。
1、技术选型
2、业务流程
3、核心业务分析
4、代码优化

Ⅰ、数据库表设计

如何正确的使用springcloud

Ⅱ、创建一个父工程

如何正确的使用springcloud

删除多余的文件,留下一个pom.xml文件

如何正确的使用springcloud

pom文件依赖

<?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>com.cloud</groupId>    <artifactId>springcloud_all</artifactId>    <version>1.0-SNAPSHOT</version>    <modules>    ## 创建了子模块之后会自动加入     ##   <module>payment-module</module>    </modules>    <packaging>pom</packaging>    <properties>        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>        <maven.compiler.source>1.8</maven.compiler.source>        <maven.compiler.target>1.8</maven.compiler.target>        <junit.version>4.13</junit.version>        <log4j.version>1.2.17</log4j.version>        <lombok.version>1.16.18</lombok.version>        <mysql.version>8.0.19</Mysql.version>        <druid.version>1.2.4</druid.version>        <mybatis.spring.boot.version>2.1.4</mybatis.spring.boot.version>        <druid.spring.boot.version>1.2.4</druid.spring.boot.version>        <springfox-swagger-ui.version>2.9.2</springfox-swagger-ui.version>        <springfox-swagger2.version>2.9.2</springfox-swagger2.version>    </properties>    <dependencyManagement>        <dependencies>            <dependency>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-dependencies</artifactId>                <version>2.4.3</version>                <type>pom</type>                <scope>import</scope>            </dependency>            <!--      spring-cloud 2020.0.2-->            <dependency>                <groupId>org.springframework.cloud</groupId>                <artifactId>spring-cloud-dependencies</artifactId>                <version>2020.0.2</version>                <type>pom</type>                <scope>import</scope>            </dependency>            <!--      spring-cloud alibaba-->            <dependency>                <groupId>com.alibaba.cloud</groupId>                <artifactId>spring-cloud-alibaba-dependencies</artifactId>                <version>2021.1</version>                <type>pom</type>                <scope>import</scope>            </dependency>            <dependency>                <groupId>mysql</groupId>                <artifactId>mysql-connector-java</artifactId>                <version>${mysql.version}</version>            </dependency>            <dependency>                <groupId>com.alibaba</groupId>                <artifactId>druid</artifactId>                <version>${druid.version}</version>            </dependency>            <dependency>                <groupId>org.mybatis.spring.boot</groupId>                <artifactId>mybatis-spring-boot-starter</artifactId>                <version>${mybatis.spring.boot.version}</version>            </dependency>            <dependency>                <groupId>com.alibaba</groupId>                <artifactId>druid-spring-boot-starter</artifactId>                <version>${druid.spring.boot.version}</version>            </dependency>            <dependency>                <groupId>io.springfox</groupId>                <artifactId>springfox-swagger-ui</artifactId>                <version>${springfox-swagger-ui.version}</version>            </dependency>            <dependency>                <groupId>io.springfox</groupId>                <artifactId>springfox-swagger2</artifactId>                <version>${springfox-swagger2.version}</version>            </dependency>        </dependencies>    </dependencyManagement>    <build>        <plugins>            <plugin>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-maven-plugin</artifactId>                <configuration>                    <fork>true</fork>                    <addResources>true</addResources>                </configuration>            </plugin>        </plugins>    </build></project>
Ⅲ、创建子订单模块

如何正确的使用springcloud

右键->New->Module

如何正确的使用springcloud
如何正确的使用springcloud
如何正确的使用springcloud

PaymentApplication启动类

@SpringBootApplicationpublic class PaymentApplication {    public static void main(String[] args) {        SpringApplication.run(PaymentApplication.class,args);    }}
Ⅲ、子模块代码编写

Ⅲ.Ⅰ、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">    <parent>        <artifactId>springcloud_all</artifactId>        <groupId>com.cloud</groupId>        <version>1.0-SNAPSHOT</version>    </parent>    <modelVersion>4.0.0</modelVersion>    <groupId>com.pay</groupId>    <artifactId>payment-module</artifactId>    <dependencies><!--        WEB+监控-->        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-actuator</artifactId>        </dependency><!--        mybatis-->        <dependency>            <groupId>org.mybatis.spring.boot</groupId>            <artifactId>mybatis-spring-boot-starter</artifactId>        </dependency>        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>druid-spring-boot-starter</artifactId>        </dependency><!--        mysql-->        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>        </dependency><!--        jdbc-->        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-jdbc</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-devtools</artifactId>        </dependency>        <dependency>            <groupId>org.projectlombok</groupId>            <artifactId>lombok</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>        </dependency>        <dependency>            <groupId>io.springfox</groupId>            <artifactId>springfox-swagger-ui</artifactId>        </dependency>        <dependency>            <groupId>io.springfox</groupId>            <artifactId>springfox-swagger2</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-devtools</artifactId>            <scope>runtime</scope>            <optional>true</optional>        </dependency>    </dependencies></project>

Ⅲ.Ⅱ、application.yml 配置文件编写

server:  port: 8081spring:  application:    name: payment-module  datasource:    type: com.alibaba.druid.pool.DruidDataSource    driver-class-name: com.mysql.cj.jdbc.Driver    url: jdbc:mysql://localhost:3306/cloud?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC    username: root    passWord: hao20001010mybatis:  mapper-locations: classpath:mapper@RestController@Slf4j@api(value = "《----订单模块----》")public class PaymentController {    private static final Logger logger = LoggerFactory.getLogger(PaymentController.class);    @Resource    private PaymentService paymentService;        @ApiOperation(value = "创建订单")    @PostMapping(value = "/payment/create")    public Result create(@RequestBody Payment payment) {        int result = paymentService.create(payment);        logger.info("插入结果========》" +result);        if (result > 0) {            return new Result(200,"插入成功", result);        } else {            return new Result(500, "插入失败", null);        }    }        @GetMapping(value = "/payment/get/{id}")    @ApiModelProperty(value = "订单查询")    public Result getPaymentById(@PathVariable(value = "id") Integer id) {        Payment payment = paymentService.getPaymentById(id);        logger.info("订单查询结果=========>"+payment);        if (payment != null) {            return new Result(200, "查询成功", payment);        } else {            logger.error("订单插叙失败!请排查原因");            return new Result(500, "查询失败,无该订单ID:"+id, null);        }    }}

Ⅲ.Ⅳ、service层

public interface PaymentService {    int create(Payment payment);    Payment getPaymentById(@Param("id") Integer id);}
@Servicepublic class PaymentServiceImpl implements PaymentService {    @Resource    private PaymentMapper paymentMapper;    @Override    public int create(Payment payment) {        return paymentMapper.create(payment);    }    @Override    public Payment getPaymentById(Integer id) {        return paymentMapper.getPaymentById(id);    }}

Ⅲ.Ⅴ、mapper层

@Mapperpublic interface PaymentMapper {    int create(Payment payment);    Payment getPaymentById(@Param("id") Integer id);}

Ⅲ.Ⅵ、mapper.xml

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"        "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.cloud.mapper.PaymentMapper">    <insert id="create" parameterType="payment" keyProperty="id" useGeneratedKeys="true">        insert into payment(orders)values(#{orders})    </insert>    <select id="getPaymentById" parameterType="payment" resultMap="BaseResultMap" >        select * from payment where id=#{id}    </select>    <resultMap id="BaseResultMap" type="payment">        <id column="id" property="id" jdbcType="INTEGER"/>        <id column="orders" property="orders" jdbcType="VARCHAR"/>    </resultMap></mapper>

Ⅳ、统一结果封装类及其实体类

@Datapublic class Result<T> implements Serializable {    private Integer code;    private String message;    private T data;    public Result(){}    public Result(Integer code, String msg) {        this(code, msg, null);    }    public Result(Integer code, String msg, T data) {        this.code = code;        this.message = msg;        this.data = data;    }}
@Data@AllArgsConstructor@NoArgsConstructor@ApiModel(value = "Payment实体类")public class Payment {    @ApiModelProperty(value = "id")    private Integer id;    @ApiModelProperty(value = "订单信息")    private String orders;}

3.2、消费服务模块

Payment、Result以及ConsumerApplication启动类和上面类似。

PRE:RestTemplate详解

RestTemplate是spring封装的一个服务端远程HTTP请求工具,支持常见的Rest请求(get、post等)
简单了说就是用来远程调用的,因为你订单模块是一个服务,消费模块又是一个单独的服务,两个服务端的端口号要进行交互,所以就有了RestTemplate

RestTemplate是服务端HTTP调用的
JSONp是客户端调用的

Ⅰ、消费模块application.yml配置

server:  port: 80

Ⅱ、配置类注入RestTemplate

@Configurationpublic class ApplicationContextConfig {    @Bean    public RestTemplate getRestTemplate() {        return new RestTemplate();    }}

Ⅲ、ConsumerController

@RestController@Api(value = "消费模块")public class ConsumerController {    private static final String CONSUMER_URL = "http://localhost:8081";    @Resource    private RestTemplate restTemplate;    @GetMapping("/consumer/payment/create")    @ApiOperation(value = "模拟添加")    public Result<Payment> create(Payment payment) {        return restTemplate.postForObject(CONSUMER_URL + "/payment/create", payment, Result.class);    }    @ApiOperation(value = "模拟获取")    @GetMapping("/consumer/payment/get/{id}")    public Result<Payment> getPayment(@PathVariable(value = "id") Integer id) {        return restTemplate.getForObject(CONSUMER_URL + "/payment/get/" + id, Result.class);    }}

上述就是小编为大家分享的如何正确的使用springcloud了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: 如何正确的使用springcloud

本文链接: https://www.lsjlt.com/news/274191.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何正确的使用springcloud
    这期内容当中小编将会给大家带来有关如何正确的使用springcloud,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、微服务简介 Ⅰ、我对微服务的理解微服务是软件开发的一种架构方式,由单一的应用小程序构...
    99+
    2023-06-14
  • 如何正确的使用WeakHashMap
    这篇文章给大家介绍如何正确的使用WeakHashMap,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 在学习WeakHashMap时了解到,如果map里面的key只有map本身引用时,就会将key对应的Entry清除掉...
    99+
    2023-05-30
    weakhashmap
  • 如何正确的使用JDBC
    今天就跟大家聊聊有关 如何正确的使用JDBC,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。什么是JDBCJDBC(Java Database Connectivity),即Java数...
    99+
    2023-05-31
    jdbc jdb
  • 如何正确的使用 jsonpath
    今天就跟大家聊聊有关如何正确的使用 jsonpath,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。java项目demo:注意: 其中他的max,min,avg,stddev函数只能类...
    99+
    2023-06-06
  • 如何正确的使用supervisor
    这期内容当中小编将会给大家带来有关如何正确的使用supervisor,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。软硬件环境centos7.6.1810 64bitcat /etc/redhat...
    99+
    2023-06-06
  • 如何正确的使用JAXB
    这期内容当中小编将会给大家带来有关如何正确的使用JAXB,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、jaxb是什么     JAXB是Java Archite...
    99+
    2023-05-31
    jaxb
  • 如何正确的使用TypeScript
    如何正确的使用TypeScript,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、TypeScript 是什么TypeScript 是一种由微软开发的自由和开源的编程语言...
    99+
    2023-06-17
  • 如何正确的使用Puppet
    今天就跟大家聊聊有关如何正确的使用Puppet,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. 概述 puppet是一个开源的软件自动化配置和部署工具,它使用简单且功能强大,正得到...
    99+
    2023-06-12
  • 如何正确的使用pytest
    本篇文章为大家展示了如何正确的使用pytest,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、安装pytest,打开dos窗口输入:pip install pytest2、通过pycharm工具下...
    99+
    2023-06-07
  • 如何正确的使用CMake
    如何正确的使用CMake?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。CMake是一个比make更高级的编译配置工具,它可以根据不同平台、不同的编译器,生成相应的Makef...
    99+
    2023-06-08
  • 如何正确的使用numpy.sum()
    这篇文章给大家介绍如何正确的使用numpy.sum(),内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。numpy的sum函数可接受的参数是:sum(a, axis=None, dtype=None,&...
    99+
    2023-06-15
  • 如何正确的使用Gradle
    本篇文章为大家展示了如何正确的使用Gradle,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、Gradle相比Maven的优势配置简洁Maven是用pom.xml管理,引入一个jar包至少5行代码...
    99+
    2023-06-06
  • 如何正确的使用javascript
    本篇文章为大家展示了如何正确的使用javascript,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用javascript的方法:可以用script标签引入<script type...
    99+
    2023-06-14
  • 如何正确的使用ArrayList
    今天就跟大家聊聊有关如何正确的使用ArrayList,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。ArrayList简介ArrayList 是一个数组队列,相当于 动态数组。与Jav...
    99+
    2023-05-31
    arraylist
  • 如何正确使用@property
    本篇内容主要讲解“如何正确使用@property”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何正确使用@property”吧!他们是这样说的:class People: ...
    99+
    2023-06-15
  • 如何正确使用WideCharToMultiByte
    要正确使用WideCharToMultiByte函数,需要按照以下步骤操作:1. 确定要转换的宽字符编码方式。WideCharToM...
    99+
    2023-09-26
    使用
  • 如何正确使用MVCC
    这篇文章主要讲解了“如何正确使用MVCC”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何正确使用MVCC”吧! 简单理解版以下先引用我之前写过的...
    99+
    2024-04-02
  • 如何正确的使用Class类
    这篇文章给大家介绍如何正确的使用Class类,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。任何一个类都是Class类的实例对象,这个实例对象有三种表示方式第一种表示方式(任何一个类都有一个隐含的静态成员变量class)...
    99+
    2023-05-31
    class类
  • 如何正确的使用Docker Machine
    本篇文章给大家分享的是有关如何正确的使用Docker Machine,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Docker 是一个 Client-Server 架构的应用,...
    99+
    2023-06-06
  • 如何正确的使用puppeteer库
    如何正确的使用puppeteer库,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1.初始化项目注: 这里我们会使用到 es6/7 的新特性...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作