RestTemplate微服务项目

前言

因为要运用 Spring Cloud Alibaba 开源组件到分布式项目中,所以这里先搭建一个不通过 Spring Cloud只通过 RestTemplate 来让SpringBoot和Mybatis进行模块之间

通讯,之后会在此基础上再添加Spring Cloud Alibaba框架及各个组件。

一、项目整体概述

这里整理了一张图,代表接下来这个项目的模块划分,同时用到的一些组件

从这幅图可以看出整个项目所需要用到的组件有:

 GateWay(网关),
Feign(服务调用),
Nacos(注册中心+配置中心),
Zipkin(链路追踪组件),
Sentinel(流量控制组件)

一共创建了三个服务

商品微服务
订单微服务
用户微服务

这篇博客的目的就是搭建上面三个服务,而不添加任何微服务的组件。

二、项目环境和数据库设计

上面已经说过,一共有三个微服务(商品微服务,订单微服务,用户微服务),所以这里也一共有三个数据库。

1、商品微服务

1).创建商品微服务的数据库

CREATE DATABASE mall_goods

2).创建商品表

CREATE TABLE `goods` (
`id` int unsigned NOT NULL AUTO_INCREMENT,
`goods_name` varchar(524) DEFAULT NULL COMMENT '商品名称',
`price` int DEFAULT NULL COMMENT '商品价格(分)',
`goods_img` varchar(524) DEFAULT NULL COMMENT '商品封⾯图',
`summary` varchar(1026) DEFAULT NULL COMMENT '概述',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

3).表里插入几条模拟商品数据

INSERT INTO `goods` (`id`, `goods_name`, `price`, `goods_img`, `summary`, `create_time`)
VALUES
(1,'男士纯棉短袖T恤',1800,'www.txun.com','很休闲的一款T恤','2021-04-03 11:48:46'),
(2,'2021秋季风衣女装',7200,'www.fy.com','很好的一件风衣','2021-04-03 11:48:46'),
(3,'2021春装新款简约显瘦圆领连衣裙',3600,'www.lyq.com','很好一件连衣裙','2021-04-03 11:48:46');

2、订单微服务

1).创建订单微服务的数据库

CREATE DATABASE mall_orders

2).创建订单表

CREATE TABLE `goods_order` (
`id` int unsigned NOT NULL AUTO_INCREMENT,
`order_no` varchar(64) DEFAULT NULL COMMENT '订单号',
`total_fee` int DEFAULT NULL COMMENT '⽀付⾦额,单位分',
`goods_id` int DEFAULT NULL COMMENT '商品ID',
`goods_title` varchar(256) DEFAULT NULL COMMENT '商品标题',
`goods_img` varchar(256) DEFAULT NULL COMMENT '商品图⽚',
`user_id` int DEFAULT NULL COMMENT '⽤户id',
`state` int DEFAULT NULL COMMENT '0表示未⽀付,1表示已⽀付',
`create_time` datetime DEFAULT NULL COMMENT '订单⽣成时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

3).表里插入几条模拟订单数据

INSERT INTO `goods_order` (`id`, `order_no`, `total_fee`, `goods_id`, `goods_title`, `goods_img`, `user_id`, `state`, `create_time`)
VALUES
(1,'2021033000001-1',1800,1,'男士纯棉短袖T恤','www.txun.com',1,1,'2021-04-03 11:48:46'),
(2,'2021033000001-2',7200,2,'2021秋季风衣女装','www.fy.com',2,1,'2021-04-03 11:48:46');

3、用户微服务

1).创建用户微服务的数据库

CREATE DATABASE mall_user

2).创建用户表

CREATE TABLE `user` (
`id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`phone` varchar(32) DEFAULT NULL COMMENT '手机号',
`pwd` varchar(128) DEFAULT NULL COMMENT '密码',
`sex` int(2) DEFAULT NULL COMMENT '性别',
`img` varchar(128) DEFAULT NULL COMMENT '头像',
`username` varchar(128) DEFAULT NULL COMMENT '用户名',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
PRIMARY KEY (`id`)
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARSET = utf8mb4;

3).表里插入几条用户数据

INSERT INTO `user` (`id`, `phone`, `pwd`, `sex`, `img`, `username`, `create_time`)
VALUES
(1,'18812345678','123456',1,'www.touxiang.com','小小','2021-04-03 11:48:46'),
(2,'18887654321','654321',2,'www.touxiang.com','张三','2021-04-03 11:48:46');

三、项目搭建

1、技术架构

项目总体技术选型

SpringBoot2.3.3 + Maven3.5.4 +JDK8

2、项目整体结构

mall-parent  #父工程
|
---mall-common #公共模块
|
---mall-goods #商品服务(端口:6001)
|
---mall-order #订单服务(端口:7001)
|
---mall-user #用户服务(端口:8001)

说明 有关项目具体的代码我这边就不放上去了,文章最下面会附上GitHub地址。

四、测试

这里主要测试两点

1)各模块连接数据库是否成功
2)订单服务调商品服务接口能否成功

1、订单接口代码

@RestController
@RequestMapping("api/v1/goods_order")
public class OrderController { @Autowired
private RestTemplate restTemplate; @RequestMapping("getGoods")
public Object getGoods(int goodsId) {
Goods goods = restTemplate.getForObject("http://localhost:6001/api/v1/goods/findByGoodsId?goodsId=" + goodsId, Goods.class);
return goods;
}
}

2、测试

通过postMan测试

通过图片可以说明

1)商品服务连接数据库成功
2)订单服务调商品服务成功

说明 这只是一个学习的项目,所以比较简单,下面就是一步一步添加spring cloud alibaba 框架及相应组件。

github地址RestTemplateStudy

少说多做,句句都会得到别人的重视;多说少做,句句都会受到别人的忽视。(3)

Spring Cloud Alibaba(2)---RestTemplate微服务项目的更多相关文章

  1. Spring Cloud Alibaba+Nacos搭建微服务架构

    1. Spring Cloud Alibaba 简介    Spring Cloud Alibaba是阿里巴巴为分布式应用提供的一站式解决方案,能够更方便快捷地搭建分布式平台,nacos拥有着替换eu ...

  2. 阿里巴巴开源 Spring Cloud Alibaba,加码微服务生态建设

    本周,Spring Cloud联合创始人Spencer Gibb在Spring官网的博客页面宣布:阿里巴巴开源 Spring Cloud Alibaba,并发布了首个预览版本.随后,Spring Cl ...

  3. Spring Cloud Alibaba 使用RestTemplate进行服务消费

    创建服务提供者工程 创建spring-cloud-alibaba-service-member工程,会员中心服务该服务提供用户会员信息. pom.xml <?xml version=" ...

  4. 【spring cloud】子模块module -->导入一个新的spring boot项目作为spring cloud的一个子模块微服务,怎么做/或者 每次导入一个新的spring boot项目,IDEA不识别子module,启动类无法启动/右下角没有蓝色图标

    如题:导入一个新的spring boot项目作为spring cloud的一个子模块微服务,怎么做 或者说每次导入一个新的spring boot项目,IDEA不识别,启动类无法启动,怎么解决 下面分别 ...

  5. 【译文】用Spring Cloud和Docker搭建微服务平台

    by Kenny Bastani Sunday, July 12, 2015 转自:http://www.kennybastani.com/2015/07/spring-cloud-docker-mi ...

  6. SpringCloud(1)---基于RestTemplate微服务项目案例

    基于RestTemplate微服务项目 在写SpringCloud搭建微服务之前,我想先搭建一个不通过springcloud只通过SpringBoot和Mybatis进行模块之间额通讯.然后在此基础上 ...

  7. Spring Cloud和Docker搭建微服务平台

    用Spring Cloud和Docker搭建微服务平台 This blog series will introduce you to some of the foundational concepts ...

  8. 手把手教你使用spring cloud+dotnet core搭建微服务架构:服务治理(-)

    背景 公司去年开始使用dotnet core开发项目.公司的总体架构采用的是微服务,那时候由于对微服务的理解并不是太深,加上各种组件的不成熟,只是把项目的各个功能通过业务层面拆分,然后通过nginx代 ...

  9. spring cloud+dotnet core搭建微服务架构:服务发现(二)

    前言 上篇文章实际上只讲了服务治理中的服务注册,服务与服务之间如何调用呢?传统的方式,服务A调用服务B,那么服务A访问的是服务B的负载均衡地址,通过负载均衡来指向到服务B的真实地址,上篇文章已经说了这 ...

随机推荐

  1. Yarn框架的一般过程

    基本过程图: Clinet向ResouceManager发送Job请求 ResouceManager接受到请求后在自身开启一个Container 来运行的ApplicationManager组件,Ap ...

  2. 微信小程序(七)-项目实例(原生框架 MINA转云开发)==02-云开发-配置

    云开发:1.就是用云函数的型式来使用云存储和云数据库完成各种操作!     2.只关注调什么函数,完成什么功能即可,无需关心HTTP请求哪一套!     3.此模式不代表没有服务器,只是部署在云环境中 ...

  3. js 表格插入指定行

    js在table指定tr行上或下面添加tr行 function onAddTR(trIndex)         {             var tb = document.getElementB ...

  4. R语言学习4:函数,流程控制,数据框重塑

    本系列是一个新的系列,在此系列中,我将和大家共同学习R语言.由于我对R语言的了解也甚少,所以本系列更多以一个学习者的视角来完成. 参考教材:<R语言实战>第二版(Robert I.Kaba ...

  5. linux 查询登陆成功、失败的用户

    查询登陆成功的用户: last 单独执行last指令时,它会读取位于/var/log/wtmp的文件,并把该给文件的内容记录的登录系统的用户名单全部显示出来. 如果使用tail.cat命令查看这文件, ...

  6. C语言经典88案例,我文科妹妹说她都学会了!

    案例ex01: 将字符串转换为一个整数 1 题目 函数:fun() 功能:将字符串转换为一个整数 描述: [不能使用C语言提供的字符串函数] 输入:字符串"-1234" 输出:整型 ...

  7. 浅谈.Net Core后端单元测试

    目录 1. 前言 2. 为什么需要单元测试 2.1 防止回归 2.2 减少代码耦合 3. 基本原则和规范 3.1 3A原则 3.2 尽量避免直接测试私有方法 3.3 重构原则 3.4 避免多个断言 3 ...

  8. FreeBSD 中文TTY控制台

    freebsd新型终端VT,支持cjk,所以丢个字体进去,就能显示中文了1,首先你没有改过控制台程序,使用的是默认的,,2,最新版本,本说明是以freebsd12.1release字体格式为.fnt命 ...

  9. C# 通过ServiceStack 操作Redis——List类型的使用及示例

    Redis list的实现为一个双向链表,即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销, /// <summary> /// Redis list的实现为一个双向链表 ...

  10. 想了很久,一道Microsoft的笔试题目 —— Reversing Linked List

    Reversing Linked List Given a constant K and a singly linked list L, you are supposed to reverse the ...