- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章springcloud初体验(真香)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
微服务是软件开发的一种架构方式,由单一的应用小程序构成的小服务;一个软件系统由多个服务组成;在微服务中,服务是细粒度的,协议是轻量级的(部署简单、性能开销小) 。
随着时代的发展,单体架构(MVC三层模型)越来越不能满足企业的要求;业务规模的不断扩大、团队开发人员的增多,使得单体架构出现了以下几个问题: (1)部署效率低(比如代码量非常多,依赖的包非常多,那么每一次编译打包、部署测试的时间就会很久) (2)团队开发成本高(如果某个模块出现问题,可能就要多人修改) (3)高可用性低(打成war包部署之后,如果某一块出现了问题,其他模块都会受到影响) (4)一旦代码膨胀(简单了说你写的代码量大,但功能没实现几个,浪费资源),上线就会变慢 。
SOA(面向服务编程)便出现了 。
SOA简介 。
SOA是一个组件模型,它将应用程序的不同功能单元(称为服务)进行拆分,并通过这些服务之间定义良好的接口和协议联系起来.
虽然解决了服务的启动时间,但服务化也有很大的缺点 。
1、耦合度较高(一个依赖可能另一个模块,另外一个模块又可能依赖其他模块) 2、公司成本高(每一个模块都要由相应的人员或者团队维护) 。
2014年,随着容器化技术的成熟以及 DevOps 文化的兴起,微服务便应运而生了 。
微服务的特点 。
1.服务细粒度 2.协议轻量级 3.部署简单 4.服务的独立维护性 。
springcloud是分布式微服务架构的一站式解决方案,是多种微服务架构落地技术的集合体.
1.分布式/版本化配置 2.服务注册和发现 3.路由 4.服务到服务的通话 5.负载均衡 6.断路器 7.全局锁 8.领导选举和集群状态 9.分布式消息传递 。
SpringCloud的官网地址:https://spring.io/projects/spring-cloud#overview 。
1.进入springcloud官方页面:https://spring.io/projects/spring-cloud#learn 。
2. LEARN->Reference Doc. 。
3. 版本选择 。
最近发现网络上很多springcloud入门体验都是关于消费-订单的小Demo,那我当然不能落后了(菜是原罪?) 。
1、创建一个父项目(统一管理子模块依赖版本) 2、创建第一个子模块-----》订单服务模块 3、创建第二个子模块-----》客户消费模块 。
编写代码之前应该先构思好流程,如果直接就去码代码,码了一会可能又要添添改改;还有可能做完项目之后又要对项目进行重构,这就是没有构思好流程。 1、技术选型 2、业务流程 3、核心业务分析 4、代码优化 … 。
删除多余的文件,留下一个pom.xml文件 。
pom文件依赖 。
<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>
。
右键->New->Module 。
PaymentApplication启动类 。
public class PaymentApplication { public static void main(String[] args) { SpringApplication.run(PaymentApplication.class,args); }}
。
Ⅲ.Ⅰ、pom.xml 。
<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 配置文件编写 。
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/*.xml type-aliases-package: com.cloud.entity
Ⅲ.Ⅲ、Controller层编写 。
import com.cloud.Service.PaymentService;import com.cloud.entity.Payment;import com.cloud.entity.Result;import io.swagger.annotations.Api;import io.swagger.annotations.ApiModel;import io.swagger.annotations.ApiModelProperty;import io.swagger.annotations.ApiOperation;import lombok.extern.slf4j.Slf4j;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.PathVariable;import org.springframework.web.bind.annotation.PostMapping;import org.springframework.web.bind.annotation.RestController;import javax.annotation.Resource;/** * @author:抱着鱼睡觉的喵喵 * @date:2021/4/18 * @description: */@RestController@Slf4j@Api(value = "《----订单模块----》")public class PaymentController { private static final Logger logger = LoggerFactory.getLogger(PaymentController.class); @Resource private PaymentService paymentService; /** * 创建订单模块 * @api /payment/create * @param payment Payment实体类 * @return Result<></> */ @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); } } /** * 订单查询模块 * @api /payment/get/{id} * @param id 编号 * @return Payment实体类 */ @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层 。
int create(Payment payment); Payment getPaymentById(@Param("id") Integer id);}
public 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层 。
public interface PaymentMapper { int create(Payment payment); Payment getPaymentById(@Param("id") Integer id);}
Ⅲ.Ⅵ、mapper.xml 。
<!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>
public 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; }}
@AllArgsConstructor@NoArgsConstructor@ApiModel(value = "Payment实体类")public class Payment { @ApiModelProperty(value = "id") private Integer id; @ApiModelProperty(value = "订单信息") private String orders;}
消费模块项目结构图 。
Payment、Result以及ConsumerApplication启动类和上面类似.
PRE:RestTemplate详解 。
RestTemplate是spring封装的一个服务端远程HTTP请求工具,支持常见的Rest请求(get、post等) 简单了说就是用来远程调用的,因为你订单模块是一个服务,消费模块又是一个单独的服务,两个服务端的端口号要进行交互,所以就有了RestTemplate 。
RestTemplate是服务端HTTP调用的 Jsonp是客户端调用的 。
port: 80
public class ApplicationContextConfig { @Bean public RestTemplate getRestTemplate() { return new RestTemplate(); }}
@Configuration : 该注解类似于beans 。
@Bean:当然就类似于bean了 。
@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初体验(真香)的文章就介绍到这了,更多相关springcloud初体验内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持! 。
原文链接:https://blog.csdn.net/Kevinnsm/article/details/115770105 。
最后此篇关于springcloud初体验(真香)的文章就讲到这里了,如果你想了解更多关于springcloud初体验(真香)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Why can't Python handle true/false values as I expect?
我是不是遗漏了什么或者这是 ruby 中的错误? a = %w(foo bar baz) a.include? "foo" # => true a.size == 3
从 Modelica 文档来看,注释 Evaluate 似乎只对参数有影响: https://build.openmodelica.org/Documentation/ModelicaReferenc
为了避免嵌套的 if 语句并提高可读性,我想创建一个switch(true){ ... } Coldfusion 中的声明。我在 php 中经常使用这个,但是当我在 Coldfusion 中尝试这个时
嗨,我正在尝试处理 ajax json 响应 这是我的代码 success: function (j) { switch(true) { case (j.cho
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
这个问题在这里已经有了答案: How can I return pivot table output in MySQL? (10 个答案) 关闭 5 年前。 我正在尝试构建一个以唯一列值作为列名的表
我制作了一个简单的 JDialog,其中包含一个标签和一个按钮,它基本上相当于信息对话框。所以在对话框中,有一个方法 display() 我在其中调用了 setVisible(true) 五次。 据我
在 bash 4.2.8(1)-release (x86_64-pc-linux-gnu) 在 Ubuntu 11.04 上这个命令 [ $(wc -l /var/www/some.log|cut -
我正在使用 c 语言进行并发处理,我有一个进程池。为此,我让每个 child 都在一个 While (True) 循环中。为了杀死 child ,我正在使用一个全局变量和一个信号处理程序来修改它来打破
我正在尝试选择填写了字段的数据库条目。数据库有两种插入数据的方式,一种输入评论,一种不输入,我希望只选择填写了评论的行。 $requete = "SELECT * FROM daysoff WHER
如何在 JavaMail session 中setDebug(true) 捕获流并在我的日志记录框架中使用它? (缺少下载源代码,更改接受流作为参数的方法,重新编译它,...) 更一般地说,Java
我是 JavaScript 的新手,我刚刚发现了我无法理解的奇怪行为: var magicVar = Math.sin; magicVar == true; // it returns false m
对此感到困惑。 在两台服务器上运行相同版本的 MySQL。 (从完全相同的 rpm 构建)- 沿线的某个地方,一些开发人员改变了一些东西...... 服务器 1: mysql> select ( no
我在查看 OpenSSL 中使用的一些预处理器宏时,从 crypto/stack/safestack.h 中发现了以下内容: #define CHECKED_STACK_OF(type, p) \
所以我遇到了一个问题,我的正则表达式看起来像这样:/true|false/。 当我检查单词 falsee 时,我从这个正则表达式中得到一个 true,有没有办法将它限制为确切的 true 或 fals
我正在对这个恶意 JavaScript 行进行一些试验:var undefined = true; JavaScript 中每个未初始化的变量都有 undefined 的值,这只是一个保存特殊值 'u
我想将 PHP 的微时间存储为我在 MySQL 中的时间戳。 我去过told最好用 DECIMAL 存储它,但我找不到理想的大小。 有谁知道 microtime(true) 返回的最大大小是多少,所以
在 PHP 中,当您在 URL 中包含诸如“var=true”之类的内容时,URL 中的“true”和“false”是否被转换为 boolean 变量,或者它们是否等于文本“true”还是“假”?例如
我是一名优秀的程序员,十分优秀!