搭建cloud项目以及各个依赖和配置说明(二)

简介: 搭建cloud项目以及各个依赖和配置说明

添加网关模块


右击项目–new–添加module,创建普通的manen项目


网关是cloud项目中所有模块的入口,所以它的配置和普通的配置略有不同。


一、添加依赖:


<dependencies>
        <dependency>
            <!--     gateway 注意 此模块不能引入starter-web       -->
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>


pring-cloud-starter-alibaba-nacos-discovery是Spring Cloud Alibaba中关于Nacos服务发现的起步依赖。引入它可以让Spring Cloud应用使用Nacos作为服务注册与发现中心。


配置网关的application.yml文件


server:
#  该模块的端口号
  port: 8080
spring:
  application:
#  网关名称
    name: gateway
  profiles:
#指定环境
    active: local
  cloud:
    gateway:
      discovery:
        locator: 
          enabled: true # 让gateway从nacos中获取服务信息
      rotes:
        - id: user_route            #用户模块路由
          uri: lb://test   #test项目注册到nacos的服务名称,
          order: 1
          predicates:
            - Path=/test/**  #路由断言,用于判断请求是否符合转发条件。这里是判断请求路径是否以/test开头,如果是则转发到test服务
    nacos:
      discovery:
        server-addr: nacos地址+端口号 #nacos地址
        namespace: FilterTest


网关入口


@SpringBootApplication
@EnableDiscoveryClient   //服务注册是否可以被发现
public class GateWayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GateWayApplication.class,args);
    }
}


普通模块


普通模块创建和网关模块创建是一样的。


普通模块的配置文件:


server:
  port: 8082
  servlet:
    context-path: /test
spring:
  application:
    name: test
  profiles:
    active: local
  cloud:
    nacos:
      discovery:
        server-addr: nacos地址+端口号 #nacos地址
        namespace: FilterTest


普通模块的pom文件


<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>


启动类:


@SpringBootApplication
@EnableDiscoveryClient
public class TestApplication {
    public static void main(String[] args) throws UnknownHostException {
        ConfigurableApplicationContext application =SpringApplication.run(TestApplication.class,args);
}


application.yml文件和bootstrap.yml文件的区别


该例子我搭建的cloud项目使用的配置文件使用的是application.yml,这里有一个优先级的问题,bootstrap.yml的优先级要比application.yml的优先级要高,而且一般使用熔断、限流之类的中间件的时候一般使用bootstrap.yml。


总结


本博客文中只是简单的搭建了一个cloud项目,如果在实际开发过程中需要用到其他的组件,在pom文件中引入相关依赖。


最后搭建完毕之后访问此:http://localhost:8080/test/test/TestController/test地址可以访问到自己的项目。需要说明一下,url地址中的第一个“/test”是网关中配置的地址,第二个test是自己模块中的上下文地址。

90ab7ca983f6794f8e2380e83b20de0b_4fc21d30b521482ba52341552cdc6ee0.png


相关文章
|
5月前
|
存储 Dubbo API
SpringCloud工程部署启动
本节笔者带领大家完成了SpringCloud工程从0->1的搭建,当然你不想搭建也可以直接采用方案一,二者等效,至此读者们完成了一个微服务工程的搭建、部署、访问。同时在本节最后一章,笔者基于RestTemplate发起的http请求实现远程调用,实现当A系统想要获取B系统数据时的跨系统数据交互。然而RESTful API访问并不是微服务的唯一解决方案,如Dubbo的交互一样可以实现,希望读者们能不限于此。
|
7月前
|
消息中间件 Java 持续交付
Spring Cloud Alibaba 项目搭建步骤和注意事项
Spring Cloud Alibaba 项目搭建步骤和注意事项
856 0
Spring Cloud Alibaba 项目搭建步骤和注意事项
|
8月前
|
负载均衡 监控 Java
搭建一个简单的SpringCloud环境
搭建一个简单的SpringCloud环境
52 1
|
JSON Java Nacos
需要在你的项目中引入Nacos的依赖
需要在你的项目中引入Nacos的依赖
516 2
|
前端开发 Java 数据库连接
从零开始构建Spring Boot项目时,你需要哪些包?
从零开始构建Spring Boot项目时,你需要哪些包?
|
消息中间件 监控 Java
搭建cloud项目以及各个依赖和配置说明(一)
搭建cloud项目以及各个依赖和配置说明
820 0
|
存储 XML JSON
【Java项目】SpringBoot项目如何从自研配置中心拉取配置
【Java项目】SpringBoot项目如何从自研配置中心拉取配置
234 0
|
Java Maven Docker
spring boot 项目打包镜像方式以及区分环境打包
spring boot 项目打包镜像方式以及区分环境打包
464 0
|
JavaScript Java Maven
微服务中使用Maven BOM来管理你的服务版本
微服务中使用Maven BOM来管理你的服务版本
223 0
|
监控 Java 编译器
spring-cloud开源项目初始化导入
spring-cloud开源项目初始化导入
155 0