用springcloud创建分布式框架

创建Maven项目

  1. groupId:公司名+项目名,com.wsh.springcloudFramework
  2. artifactId: 项目名+模块名称, springcloudframework

一.搭建注册中心

  • 添加pom.xml,注意版本问题,这个应该是最新的了
<groupId>com.wsh.springcloudFramework</groupId>
    <artifactId>springcloudframework</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <!--eureka server -->
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>

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

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.M7</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <repositories>
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
            <snapshots>
            <enabled>false</enabled>
            </snapshots>
        </repository>
    </repositories>
  • 增加application.yml,idea直接创建file文件,然后更改后序
#端口号
server:
  port: 8888
#eureka配置
eureka:
  instance:
    #注册中心ip地址
    hostname: localhost
  client:
    #是否注册到eureka
    registerWithEureka: false
    #是否检测服务信息
    fetchRegistry: false
    #注册地址
    serviceUrl:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

  • 创建运行类
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;

@SpringBootApplication
@EnableEurekaServer
public class mainApplication {

    public static void main(String[] args) {
        SpringApplication.run(mainApplication.class, args);
    }
}
  • 然后访问http://localhost:8888/,就可以看到效果了

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一种基于Spring框架的开源分布式架构解决方案,它提供了一系列工具和组件,用于简化构建分布式系统的过程。 搭建Spring Cloud分布式架构主要包括以下几个步骤: 1. 环境准备:首先要准备好需要的开发环境,包括Java开发环境、Eclipse或者IntelliJ IDEA等开发工具,以及Maven项目管理工具。 2. 创建项目:通过Maven创建一个Spring Boot项目作为基础项目。可以使用Spring Initializr或者手动创建一个基本的Spring Boot项目。 3. 添加依赖:在创建的Spring Boot项目中,添加Spring Cloud的相关依赖,如spring-cloud-starter-netflix-eureka-server、spring-cloud-starter-config等,这些依赖将提供各种分布式系统所需的功能。 4. 配置服务注册中心:通过在配置文件中配置服务注册中心,可以使用Eureka或Consul等作为服务注册中心。服务注册中心用于服务的发现与注册,确保每个服务的可用性。 5. 编写业务代码:在项目中编写对应的微服务业务代码,如提供用户服务、订单服务等。每个微服务都是独立的应用程序,可以通过服务间的调用来实现不同微服务之间的协作。 6. 配置服务间的通信:通过使用Feign或Ribbon等组件,可以方便地实现服务间的通信。Feign提供了声明式的HTTP客户端,而Ribbon可以实现客户端负载均衡等功能。 7. 配置服务网关:使用Zuul等组件配置服务网关,可以实现对外部的请求进行路由和负载均衡。服务网关可以提供统一的API入口,并且可以进行安全认证等操作。 8. 配置分布式配置中心:通过使用Spring Cloud Config,可以将所有的配置文件放在统一的配置中心,实现动态的配置管理。 9. 配置服务容错保护:使用Hystrix等组件,可以实现对服务的容错保护。Hystrix可以控制对依赖服务的访问,防止级联故障并提供故障恢复机制。 10. 部署和运行:最后,将编写好的项目打包成JAR包,并进行部署和运行,可以使用Docker等技术进行容器化部署,提高项目的可扩展性和可维护性。 通过以上步骤,就可以搭建起一个基于Spring Cloud的分布式架构。Spring Cloud提供了丰富的组件和功能,可以帮助开发人员快速构建和部署分布式系统,并提高系统的可用性和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值