SpringCloud之从零搭建项目(1)

本文介绍了如何使用SpringCloud构建分布式项目,包括创建Eureka注册中心和EurekaClient,以及如何利用Feign实现服务间的远程调用。详细步骤包括配置Maven、添加依赖、创建服务实例和调用其他服务。
摘要由CSDN通过智能技术生成

Springcloud项目是由多个SpringBoot项目组成,创建一个分布式的项目,首先先创建一个存放SpringBoot项目的容器。

在这里插入图片描述

在设置里面配置一下maven
在这里插入图片描述

把项目里面多余的东西删掉,留个空壳。
在这里插入图片描述
配置完成之后,再在里面选择创建一个子工程
在这里插入图片描述

可以选择快速创建一个springboot项目,项目的名称就叫做eureka,充当注册中心的功能。

在这里插入图片描述
创建完成之后,子工程的项目结构,多余的文件删除
在这里插入图片描述eureka的pom文件中引入eureka的依赖

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

在eureka的启动类上加上eureka的启动注解

在这里插入图片描述
并且在配置文件中加上项目的基本信息,因为分布式项目可能会有多个注册中心,所以我们在这里创建的注册中心也需要把自己注册进去。

server:
  port: 8848
spring:
  application:
    name: eurekaService
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8848/eureka

项目启动成功之后,
登录进来就能看到eureka的界面,
服务名称eurekaService,
地址前的up表示当前组件现在的状态为正常。

在这里插入图片描述

再创建一个子工程,userService来充当eurekaClient。

在这里插入图片描述

创建完成之后,导入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

配置yml

server:
  port: 8081
spring:
  application:
    name: userService
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8848/eureka

启动userService之后,查看eureka页面可以看到注册进来的服务

在这里插入图片描述

微服务之间的互相调用,是通过feign组件来实现的。

我们再创建一个order订单服务,来模拟一下服务的调用。

创建配置过程与创建用户服务一样。
在这里插入图片描述
1、创建一个conrtoller,随便填点数据。

@RestController
@RequestMapping(value = "/order")
public class OrderController {

    @RequestMapping(value = "/getOrderInfo")
    public Map<String, Object> getOrderInfo(){
        Map<String, Object> result = new HashMap<>();
        result.put("code", "0");
        result.put("msg", "请求成功");
        result.put("data", null);
        return result;
    }

}

2、再返回到userService的pom中加入feign的依赖,创建feign远程服务调用代码,调用订单服务获取数据。

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

@FeignClient 中填订单服务的名称,
下面的请求路径,为订单服务控制器里面的路径

@FeignClient(value = "orderService")
public interface OrderFegin {

    @RequestMapping(value = "/order/getOrderInfo")
    Map<String, Object> getOrderInfo();

}

3、在userService的controller中调用feign获取数据

@RestController
@RequestMapping(value = "/user")
public class UserController {

    @Resource
    private OrderFegin orderFegin;

    @RequestMapping(value = "/getUserOrderInfo")
    public Map<String, Object> getUserOrderInfo(){
        Map<String, Object> result = orderFegin.getOrderInfo();
        return result;
    }

    @RequestMapping(value = "/hello")
    public String getHello(){
        return "请求成功!";
    }

}

4、启动类上面加上Feign的注解
在这里插入图片描述

重新启动两个服务之后,可以看到三个应用的状态都启着。
在浏览器中访问 userService的服务 http://localhost:8081/user/getUserOrderInfo

可以看到成功的返回了数据
在这里插入图片描述
在代码中并没有直接通过orderService的地址来调用方法,这就是项目中feign的作用。

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很高兴回答你关于使用Spring Cloud Alibaba搭建微服务项目的问题!下面是从开始搭建的步骤: 1. 创建父项目:首先,在你的IDE中创建一个空的Maven父项目作为整个微服务项目的容器。 2. 添加依赖:在父项目的pom.xml文件中添加Spring Cloud Alibaba的依赖,包括spring-cloud-starter-alibaba-dependencies和spring-cloud-starter-alibaba-nacos-discovery等。 3. 创建子模块:在父项目下创建子模块,每个子模块代表一个微服务。可以使用Maven的模块化管理。 4. 配置子模块:在每个子模块的pom.xml文件中添加Spring Boot的依赖,并配置相应的插件和属性。 5. 编写业务代码:在每个子模块中编写业务逻辑代码,包括控制器、服务、数据访问等。 6. 配置文件:在每个子模块中添加相应的配置文件,包括数据库配置、Nacos注册中心配置、Feign客户端配置等。 7. 注册中心:在Nacos注册中心中注册微服务,确保微服务能够被其他微服务或客户端发现和调用。 8. 服务调用:使用Spring Cloud Alibaba中的Feign或RestTemplate等方式进行微服务之间的调用,通过Nacos注册中心进行服务发现。 9. 启动微服务:分别启动各个子模块,可以使用IDE的Run或Debug功能,或者使用Maven命令进行启动。 10. 测试和部署:通过Postman或其他方式进行接口测试,确保微服务的正常运行。最后,根据实际需求选择合适的部署方式,如Docker、Kubernetes等。 以上是使用Spring Cloud Alibaba从开始搭建微服务项目的基本步骤。当然,具体的实施细节会根据项目需求和实际情况有所差异,希望对你有所帮助!如果有更多问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值