springcloud的微服务

本文介绍了如何创建一个Spring Boot父工程,配置相关依赖,并创建了用户微服务和订单微服务。用户微服务包括创建模块、Mapper层、主控制类、Service接口和实现,以及Controller类。订单微服务涉及创建模块、Mapper接口、主控制类、Service接口和实现,以及使用RestTemplate调用商品微服务的Controller。整个过程详细展示了微服务间的通信和数据库操作。

1.创建父工程(maven项目)

1.删除src(无用),只留下pom.xml

2.配置相关依赖

<!--打包方式: jar: java工程   war:web工程  pom:父工程-->
<packaging>pom</packaging>

<!--继承springboot的父工程-->
<parent>
    <artifactId>spring-boot-starter-parent</artifactId>
    <groupId>org.springframework.boot</groupId>
    <version>2.3.2.RELEASE</version>
</parent>
<!--定义版本号-->
<properties>
    <java.version>1.8</java.version>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF- 8</project.reporting.outputEncoding>
    <spring-cloud.version>Hoxton.SR8</spring-cloud.version>
    <spring-cloud-alibaba.version>2.2.5.RELEASE</spring-cloud-alibaba.version>
</properties>
<!--dependencyManagement:它只负责jar的管理  不负责jar的下载,如果想下载需要再子工程中引入依赖来下载。 -->
<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>${spring-cloud.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

3.创建父工程的基础模块

4.配置pom文件

5.创建实体类

2.创建用户微服务

1.创建一个名为 shop_product2 的模块,并添加依赖

2.创建工程的mapper层

3.创建工程的主控制类,添加包扫描

4.创建 ProductService 接口

5.创建 ProductServiceImpl 实现类

6.创建 ProductController

 

7.书写配置类application.yml

8.在数据库创建好相对应的数据库表,并加入数据

9.在浏览器进行测试

3.创建订单微服务

1.创建一个名为 shop-order2 的模块,并添加依赖

<dependencies>
    <!--shop-common2-->
    <dependency>
        <groupId>com.yjq</groupId>
        <artifactId>shop-common2</artifactId>
        <version>1.0-SNAPSHOT</version>
    </dependency>
    <!--web-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>

2.书写mapper层接口

3.创建主控制类,添加包扫描

4.创建service层

OrderService接口:

OrderService接口的实现:

5.创建controller层

package com.yjq.order.controller;

import com.yjq.entry.Order;
import com.yjq.entry.Product;
import com.yjq.order.service.OrderService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

import javax.annotation.Resource;

@RestController
@RequestMapping("order")
public class OrderController {
    @Autowired
    private OrderService orderService;
    @Resource
    private RestTemplate restTemplate;

    @GetMapping("saveOrder")
    public String saveOrder(Integer pid,Integer num){
        Order order=new Order();
        order.setNumber(num);
        order.setUid(2);
        order.setUsername("张三");

        order.setPid(pid);
        //需要根据商品id查询商品对应的信息---->调用远程商品微服务。
        //基于TCP协议------>RPC调用速度快非常耗资源 因为tcp连接属于常连接---jdbc----dubbo
        //基FHttp协议----->httpClient调用速度慢 但是资源消耗少属于短连接。 请求头 相应体参数 微服 务都是基于http-些调用。
        //可以自己封装http工具类来完成调用关系-----复杂
        //springboot封装了一个工具可以完成服务之间的调用RestTemplate

        Product product = restTemplate.getForObject("http://localhost:8081/product/findById/" + pid, Product.class);
        order.setPname(product.getPname());
        order.setPprice(product.getPprice());

        orderService.saveOrder(order);

        return "下单成功";
    }
}

6.书写配置类application.yml

7.在主控制类创建RestTemplate并交于spring管理(不写运行时会显示找不到RestTemplate)

8.在浏览器运行测试

最后在数据库查看相应数据的变化

分布式微服务企业级系统是一个基于Spring、SpringMVC、MyBatis和Dubbo等技术的分布式敏捷开发系统架构。该系统采用微服务架构和模块化设计,提供整套公共微服务模块,包括集中权限管理(支持单点登录)、内容管理、支付中心、用户管理(支持第三方登录)、微信平台、存储系统、配置中心、日志分析、任务和通知等功能。系统支持服务治理、监控和追踪,确保高可用性和可扩展性,适用于中小型企业的J2EE企业级开发解决方案。 该系统使用Java作为主要编程语言,结合Spring框架实现依赖注入和事务管理,SpringMVC处理Web请求,MyBatis进行数据持久化操作,Dubbo实现分布式服务调用。架构模式包括微服务架构、分布式系统架构和模块化架构,设计模式应用了单例模式、工厂模式和观察者模式,以提高代码复用性和系统稳定性。 应用场景广泛,可用于企业信息化管理、电子商务平台、社交应用开发等领域,帮助开发者快速构建高效、安全的分布式系统。本资源包含完整的源码和详细论文,适合计算机科学或软件工程专业的毕业设计参考,提供实践案例和技术文档,助力学生和开发者深入理解微服务架构和分布式系统实现。 【版权说明】源码来源于网络,遵循原项目开源协议。付费内容为本人原创论文,包含技术分析和实现思路。仅供学习交流使用。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值