zoukankan      html  css  js  c++  java
  • 一、服务注册中心

    本系列文章主要展示的是整合后的微服务框架,所以客户端部分不拆分来一一实现,具体请查看 客户端

    一、构建项目

    我是使用eclispe+sts构建的 SpringBoot/SpringStarterProject

    Springboot版本:1.5.8.RELEASE

    SpringCloud版本:Edgware.SR3

    因为使用的时Sts,所以构建时候可以勾选方式,选择EurekaServer

    展示一下pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>cnex.cloud</groupId>
        <artifactId>registry</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <packaging>jar</packaging>
    
        <name>cloud-registry</name>
        <description>registry-center</description>
    
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>1.5.8.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>
            <spring-cloud.version>Edgware.SR3</spring-cloud.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-eureka-server</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
        </dependencies>
    
        <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>
            </dependencies>
        </dependencyManagement>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    
    </project>

    二、配置文件

    使用yml各式,配置文件名:application.yml,#风格注释,具体看注释,有一点说明一下。

    因为我是运行在docker环境内的,但是懒,没有去编排容器,遇到过问题:

    客户端注册到服务中心,如果没有 prefer-ip-address: true 一种是通过别名,即容器名/PC名等等。

    如果有,是使用ip注册上去的,但是Docker内部网络和宿主机不在一个网段,所以通过IP是不能访问的。

    所以 ip-address: 10.180.206.254   instance-id: ${eureka.instance.ip-address}:${server.port} 强制指定了他的注册地址。

    后期最好还是使用容器的编排,这个只是demo

    #端口
    server:  
       port: 9000  
    
    eureka:
      client:   
        #不注册自身
        register-With-Eureka: false  
        fetch-Registry: false
         
         #服务中心地址,即自身
        serviceUrl:
          defaultZone: http://10.180.206.254:9000/eureka/
      instance:    
        ip-address: 10.180.206.254
        #使用iP地址注册
        prefer-ip-address: true
        #注册到服务中心的ip:端口
        instance-id: ${eureka.instance.ip-address}:${server.port}
          

    三、开启注册中心

    使用@EnableEurekaServer

    package cnex.cloud.registry;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
    
    @SpringBootApplication
    @EnableEurekaServer  //开启注册中心
    public class CloudRegistryApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(CloudRegistryApplication.class, args);
        }
    }

    四、访问管理界面

    ip:port

    五、客户端

    具体请查看 客户端

  • 相关阅读:
    动态改变shiro的Principal属性
    有邻App覆盖3000多个小区成杭州用户量最大的邻里分享经济平台 杨仁斌:开创新社区时代
    "有邻"创始人:APP覆盖杭州千余小区 却还没认真想过赚钱的事
    Shell if 条件判断
    大关小学和卖鱼桥小学哪个好 杭州重点小学对比
    测试覆盖率 Java 覆盖率 Jacoco 插桩的不同形式总结和踩坑记录
    使用Jacoco获取 Java 程序的代码执行覆盖率
    Android Studio Error running app: No target device found 问题
    android studio连接雷电模拟器
    Android Studio 下载Gradle 超时解决方案
  • 原文地址:https://www.cnblogs.com/ggwow/p/9327647.html
Copyright © 2011-2022 走看看