本项目用到的组件技术可以参考我上一篇博客,来学习。
项目需求:
客户端:针对普通用户,用户登录,用户退出,菜品订购,我的订单
后台管理系统:针对管理员,管理员登录,管理员退出,添加菜品,查询菜品,修改菜品,订单处理,添加用户,查询用户,删除用户

微服务架构思路:
account提供账户服务:用户和管理的登录退出
menu 提供菜品服务:添加,删除,修改,查询
order 提供订单服务:添加订单,查询订单,删除订单,处理订单
user 提供用户服务: 添加用户,查询用户,删除用户
分离出一个服务消费者,调用以上四个服务提供者,。其包含了客户端的前端页面和后台接口,后台管理系统的前端界面和后台借口。用户、管理员直接访问的资源都保存在服务消费者中,服务消费者根据具体的四个服务提供者的业务逻辑,通过feign和Ribbon和Eureka实现负载均衡。其实在本项目中没有过多的体现。电脑实在耗不动,就不加更多的服务搭集群测试了,这些都是写个注解就好了,没啥实货。

实操步骤:

第一步:创建父工程:
(1)创建父工程ordersystem-master。
(2)修改pom.xml,添加依赖。、
我讲一下需要添加哪些内容的依赖
1.父依赖:引入SpringBoot依赖
<groupId>org.springframework.boot</groupId>
<artfactId>spring-boot-starter-parent</artfactId>
<version>2.0.7.RELEASE</version>
2.依赖;
<!--web依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
3.依赖管理:使用SpringCloud依赖,guanliCpringCloud生态各个组件
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.SR2</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
第二步:添加注册中心Rureka。
(1)添加子工程Module。registrycenter。
(2)修改pom.xml
1.引入eureka依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
(3)添加配置文件application.yml
1.配置端口:
server:
port: 8761
2.配置Rereka信息:
eureka:
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://localhost:8761/eureka/ (4)添加启动类。
并且在启动类上面添加@SpringBootApplication,@EnableEurekaServer。
启动后在http://localhost:8761/eureka/可看到Eureka管理界面,目前没有服务注册进来,故没有服务。接下来新增menu服务。 第三步(这里我就写一个menu菜单管理即可,其他微服务与menu一样,都是一个SpringBoot小项目):
(1)添加子工程Module。
(2) 修改pom.xm。
1.把该服务注册进rureka中,需要导入client依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
<version>2.0.0.RELEASE</version>
</dependency>
2.本项目利用Mybatis框架作为ORM,数据库使用Mysql。
<!-- MyBatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.0</version>
</dependency>
<!-- MySQL驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.11</version>
</dependency>
3.添加配置中心依赖,下一步讲这个配置中心,先导入依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
(3)添加配置文件bootstrap.yml.
这个配置文件主要是用配置中心,每次启动的时候会从Git仓库下下载读取。
pring:
cloud:
config:
name: menu #对应的配置文件名称
label: master #git仓库分支名
discovery:
enabled: true
serviceId: configserver #连接的配置中心名称
eureka:
client:
serviceUrl:
defaultZone: http://localhost:8761/eureka/
(4)开发人员在本地Git库编写menu.yml然后可以上传到Git仓库。
(1)首先是微服务端口号
server:
port: 8020
(2)微服务名字,数据库,数据池。Eureka。
spring:
application:
name: menu
datasource:
name: orderingsystem
url: jdbc:mysql://localhost:3306/orderingsystem?useUnicode=true&characterEncoding=UTF-8
username: root
password: root
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka/
instance:
prefer-ip-address: true
mybatis:
mapper-locations: classpath:mapping/*.xml
type-aliases-package: com.southwind.entity
(5)接下来就是SpringBoot都学过的MVC开发模式了;这个大家都会了,我就不多说了。 第四步:添加配置中心SpringCloudConfig
(1)添加子工程Module。configserver.
(2)修改pom.xml文件。
1.引入config依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
2.引入EurekaClient的依赖(前面都说了)。
(3)添加配置文件。application.yml。
1.配置端口,服务名字,Eureka信息。(前面都说了)
2.config信息。利用Git统一管理。
spring:
application:
config:
server:
git:
uri: https://github.com/lele-Chang/order.git #git仓库地址
# searchPaths: config #仓库路径,在那个路径下就写那个,第一层就不写了。
username: lele-Chang #git仓库用户名
password: ******... #git仓库密码
label: master #仓库的分支
3.本地建立Git库,编写所有微服务的配置文件,利用Git上传到Git库。 第五步:配置客户端
(1)创建子工程Module。clientfeign。
(2)修改pom.xml文件
1.添加Eurekaclient,配置中心的依赖。这些前面都配过了。
2.集成feign,以及thymeleaf(这其实就是服务消费者了,我们直接利用html做前台界面)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
(3)添加bootstrap.yml文件读取Git统一管理的配置文件。
(4)本地Git添加clientfeign.yml文件。
1.配置端口,服务名,Rureka.
2.配置thymeleaf.
spring:
thymeleaf:
prefix: classpath:/static/
suffix: .html
(5)利用feign统一调用各大服务接口。
1.建一个Feign的文件夹,在新建MenuFegin接口。
在接口上@FeignClient(value=''微服务定义的名字''),这样就可以通过Eureka找到该服务。使用该微服务所定义的接口了。
2.但是需要建立实体类,类作为对象调用。
(6)建立启动类。
@SpringBootApplication,@EnableFeignClients,@ServletComponentScan (7)至于前台使用的是layui框架,thymeleaf.
这个我就不演示了,有官网可以学习了解。

具体代码可到我的Git上下载:https://github.com/lele-Chang/order.git

SpringCloud做的微服务项目--外卖订餐系统的更多相关文章

  1. SpringCloud:搭建微服务项目框架 microservicecloud

    1.搭建整体父工程 microservicecloud 新建父工程microservicecloud,切记是Packageing是pom模式 主要是定义POM文件,将后续各个子模块公用的jar包等统一 ...

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

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

  3. 毕业设计代做,各种系统微服务项目ssm项目,员工管理系统,微信小程序,购物商城,二手商城系统,销售系统,等等

    毕业设计代做,各种系统,微服务项目,ssm项目 小程序,商城等,期末作业等都可以,价格好说,长期接单, 有项目说明书,软件介绍相关文档,答辩的时候包过,知识点对接好,给你讲解等, 毕业设计代做,各种系 ...

  4. springboot+springcloud微服务项目全套资料(笔记+源码+代码)

    最近好几天没有写博客了,由于时间的太忙了,项目要做.各种资格证要考试,实在没有时间写了,今天正好赶上有闲暇的一刻,应许多的爱好者的要求发一份微服务项目的资料,此资料十分完整,且是最新的.希望各位读者能 ...

  5. SpringCloud微服务项目实战 - API网关Gateway详解实现

    前面讲过zuul的网关实现,那为什么今天又要讲Spring Cloud Gateway呢?原因很简单.就是Spring Cloud已经放弃Netflix Zuul了.现在Spring Cloud中引用 ...

  6. 十一、Docker搭建部署SpringCloud微服务项目Demo

    环境介绍 技术选型:SpringCloud&SpringCloud Alibaba&Docker 微服务模块划分: 员工模块:ems-employees 部门模块:ems-depart ...

  7. 【spring colud】spring cloud微服务项目搭建【spring boot2.0】

    spring cloud微服务项目搭建 =================================== 示例版本: 1.spring boot 2.0版本 2.开发工具 IntellJ IDE ...

  8. 一. SpringCloud简介与微服务架构

    1. 微服务架构 1.1 微服务架构理解 微服务架构(Microservice Architecture)是一种架构概念,旨在通过将功能分解到各个离散的服务中以实现对解决方案的解耦.你可以将其看作是在 ...

  9. java框架之SpringCloud(2)-Rest微服务案例

    在上一章节已经对微服务与 SpringCloud 做了介绍,为方便后面学习,下面以 Dept 部门模块为例做一个微服务通用 Demo —— Consumer 消费者(Client) 通过 REST 调 ...

  10. springcloud与docker微服务架构实战--笔记

    看了<微服务那些事>之后,Spring boot和Spring Cloud的关系理清楚了,Spring cloud各个模块的作用也了解了. 但是,Spring cloud 与Docker的 ...

随机推荐

  1. liunx 设置默认python版本方法,

    Linux 中把Python3设为默认Python版本的几种方法 由于工作中要用到到python3.6  而服务器是2.7 ,这个低版本的2.7很多系统都要依赖,还不能删,同事建议建一个虚拟环境,但是 ...

  2. Spring事务(四)-事务失效场景

    有时候,我们明明在类或者方法上添加了@Transactional注解,却发现方法并没有按事务处理.其实,以下场景会导致事务失效. 1.事务方法所在的类没有加载到Spring IOC容器中. Sprin ...

  3. translate speaker 翻译朗读者API - vscode 插件推荐 单词发音

    translate speaker 翻译朗读者API - vscode 插件推荐 单词发音 有个小bug,就是发音发两次,改个配置就好了. "translateSpeaker.mode&qu ...

  4. Vue3 写业务逻辑不适合用TS(TypeScript)

    TypeScript 最重要的就是装饰器 Vue3最重要更新就是Setup 装饰器就是为了打散功能点,Vue3的Setup功能也是打散功能点,那用Vue3上TS,感觉就是自己给自己多一层工作量. 我这 ...

  5. stm32文件系统读写操作调试总结

    一 问题 最近使用到了文件系统的读写,中间遇到了一些问题值得深思.   二 源码解析 创建文件: FRESULT res; do { sprintf(filename,"/sensor_si ...

  6. Rancher 2.5.x 证书过期报错 x509: certificate has expired or is not yet valid 解决方案

    Rancher 的证书过期会出现什么状况?不可以继续通过Rancher UI访问你的集群 查看Rancher Server日志报错:x509: certificate has expired or i ...

  7. Android中同步类Mutex(AutoMutex)与Condition

    在Android中,封装的同步类主要有Mutex(AutoMutex)与Condition. 这两个类在android中被大量的使用,这也说明这两个类是非常重要的. 一.Mutex(AutoMutex ...

  8. Redis安装(Linux CentOS)

    1. 环境介绍 主机系统:CentOS Redis版本:7.0.10 2. 安装过程 检查 GCC 版本 gcc -v redis 6.0 以上需要 gcc 5.3,升级 gcc.如果安装的redis ...

  9. 【2310. 个位数字为 K 的整数之和】背包

    import java.util.*; class Solution { public static void main(String[] args) { Solution solution = ne ...

  10. 3DCAT v2.1.3新版本发布,这三大功能更新你不容错过!

    3DCAT实时渲染云在近期发布了新的公有云v2.1.3的版本,本次主要更新了应用页的三项功能「语音交互设置」.「多点触控」.「音频信号位深」. 小编将对这三项更新进行讲解: 1. 调整语音通讯机制 新 ...