springcloud简单入门

本文深入探讨了Monolith和MicroService两种架构模式的特点与适用场景,详细介绍了SpringCloud作为微服务框架的核心组件及其在实际项目中的应用。通过具体步骤演示了如何搭建SpringCloud环境,包括注册中心、服务提供者和服务消费者的创建与测试。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 Monolith和MicroService

Monolith:单体应用架构
项目被打包成许多jar包,最终合并在一起形成一个war包,并将war包上传到web容器中解压然后重启服务器。这种将所有代码及功能都包含在一个war包中的项目组织方式称为Monolith。一般适用于中小型项目。
优点:项目很小的情况下开发比较容易,结构简单;
缺点:项目较大的情况下编译难、部署难、测试难,技术兼容难(多种开发语言之间兼容问题),扩展难(极大浪费资源、负载不均衡)
MicroService:微服务架构
微服务就是把一个单体项目,拆分为多个微服务,每个微服务可以独立技术选型,独立开发,独立部署,独立运维.并且多个服务相互协调,相互配合,最终完成用户的价值.它可以解决单体应用架构的问题。适用于大型项目。springcloud就是一款非常优秀的微服务框架。

2 springcloud介绍

Spring cloud是一个基于Spring Boot实现的服务治理工具包,在微服务架构中用于管理和协调服务的。
核心组成部分:五大神兽
服务发现——Netflix Eureka
客服端负载均衡——Netflix Ribbon/Feign
服务网关——Netflix Zuul
断路器——Netflix Hystrix
分布式配置——Spring Cloud Config

3 spring入门程序

3.1 springboot准备
idea创建普通maven项目springcloud_parent
pom.xml配置 导入springboot支持

<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.SR1</spring-cloud.version>
        <springboot.version>2.0.5.RELEASE</springboot.version>
    </properties>

    <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>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${springboot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

3.2注册中心
创建maven子Module springcloud_eureka7001
pom.xml配置

<dependencies>
        <!--springboot支持-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>

        <!--Eureka服务端支持-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
    </dependencies>

application.yml配置<resources下>

server:
  port: 7001
eureka:
  instance:
    hostname: eureka-7001.com
  client:
    registerWithEureka: false #是否要注册到eureka
    fetchRegistry: false #表示是否从Eureka Server获取注册信息
  serviceUrl:
     defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #单机配置

EurekaServerApp_7001.java启动类创建

@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApp_7001 {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApp_7001.class);
    }
}

启动并测试:http://localhost:7001/
成功页面
在这里插入图片描述3.3服务提供者
maven子module springcloud_provider8001
pom,xml

 <dependencies>
        <!--公共代码依赖-->
        <dependency>
            <groupId>com.yqq</groupId>
            <artifactId>user_interface</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

        <!--springboot支持-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>

        <!--eureka客户端支持 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>

application.yml

server:
  port: 8001
spring:
  application:
    name: USER-PROVIDER #不要使用下划线
eureka:
  client:
    service-url:
      #defaultZone: http://localhost:7001/eureka #告诉服务提供者要把服务注册到哪儿
      defaultZone: http://eureka-7001.com:7001/eureka,http://eureka-7002.com:7002/eureka
  instance:
    prefer-ip-address: true #显示客户端真实ip

ProviderServerApp_8001.java

@SpringBootApplication
@EnableEurekaClient
public class ProviderServerApp_8001 {
    public static void main(String[] args) {
        SpringApplication.run(ProviderServerApp_8001.class);
    }
}

UserController暴露服务

@Controller
@RequestMapping("/provider")
public class UserController {
    @ResponseBody
    @RequestMapping("/user/{id}")
    public User getUser(@PathVariable("id") Long id){
        return new User(id,"yqq");
    }
}

启动并测试
在这里插入图片描述
注册成功
3.4服务消费者
maven子module springcloud_consumer9001
pom.xml

<dependency>
            <groupId>com.yqq</groupId>
            <artifactId>user_interface</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!--springboot支持-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>

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

application.yml

server:
  port: 9001
eureka:
  client:
    registerWithEureka: false #不注册到Eureka,不在注册中心显示
    service-url:
      defaultZone: http://localhost:7001/eureka

ConsumerApp_9001.java

@SpringBootApplication
@EnableEurekaClient
public class ConsumerApp_9001 {
    public static void main(String[] args) {
        SpringApplication.run(ConsumerApp_9001.class);
    }
}

controller调用provider服务

@Configuration
public class CfgBean {
    @Bean
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}

@Controller
@RequestMapping("/consumer")
public class UserController {
    //服务提供方的名字
    public static final String URL="http://USER-PROVIDER";
    @Autowired
    private RestTemplate restTemplate;
    @ResponseBody
    @RequestMapping("/user/{id}")
    public User getUser(@PathVariable("id") Long id){
        String url=URL+"/provider/user/"+id;
        return restTemplate.getForObject(url,User.class );
    }
}

启动并测试:localhost:9001/consumer/user/8

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值