• 【Eureka】springCloud项目搭建


    新建父maven项目

    groupId:pers.xzp.springCloud
    artifactId:springCloud

    父项目中仅仅需要一个pom文件,用于管理模块的依赖统一、继承等

    编辑pom文件

    首先项目包结构为:pom

    添加依赖声明:依赖声明,不会引入依赖,只有当模块引入依赖坐标的时候才会引入响应依赖

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <!--springcloud版本-->
        <spring-cloud.version>Finchley.SR2</spring-cloud.version>
        <springboot.version>2.0.6.RELEASE</springboot.version>
    </properties><!-- dependencyManagement:帮助我们去管理坐标的版本:仅仅声明,不引入依赖-->
    <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><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>
        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--Devtools-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <!-- optional=true,依赖不会传递,该项目依赖devtools;之后依赖boot项目的项目如果想要使用devtools,需要重新引入 -->
            <!--<optional>true</optional>-->
        </dependency>
    </dependencies><build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <fork>true</fork>  <!-- 如果没有该生效标志,热部署的devtools不生效 -->
                </configuration>
            </plugin>
        </plugins>
    </build>
    View Code

    创建Eureka注册中心模块

    Eureka服务端作为服务注册中心

    模块名:eureka-registryCenter,端口:7001

    引入Eureka服务端依赖

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

    编辑核心配置文件

    server:
     #端口
    port: 7001
    eureka:
    instance:
       #服务注册中心实列的主机名
      hostname: localhost
    server:
       #关闭自我保护机制,防止失效的服务也被访问
    #   enable-self-preservation: false
       #该配置可以修改检查失效的服务器,每隔5s去扫描检查失效的服务 默认60s
      eviction-interval-timer-in-ms: 5000
    client:
       #是否向服务注册中心注册自己 自己注册了自己就是有毛病
      register-with-eureka: false
       #是否监测服务 翻译:获取注册
      fetch-registry: false
       #服务注册中心的配置内容,指定服务注册中心的位置
      service-url:
         #单机配置 就是访问注册中心的路径
        defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

    创建项目引导类

    作为Eureka服务端的引导类,需要被@EnableEurekaServer标注

    //@EnableEurekaServer:标注的类表示Eureka服务端,作为注册中心
    @EnableEurekaServer
    @SpringBootApplication
    public class RegistryCenter_7001 {
        public static void main(String[] args) {
            SpringApplication.run(RegistryCenter_7001.class);
        }
    }

    创建Eureka客户端:服务提供者

    模块名字:provider-payment8001 端口号:8001

    引入Eureka客户端依赖

    <!--eureka客户端支持  我们去写支付功能 服务-->
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>

    编辑核心配置文件

    server:
    port: 8001
    # Eureka客户端取别名
    spring:
    application:
      name: payment
    eureka:
    client:
      service-url:
         # 注册Eureka客户端到服务注册中心 需要与注册中心配置对应
        defaultZone: http://localhost:7001/eureka

    编码

    实体类
    @Data
    public class User implements Serializable {
        private int id;
        private String name;
        @DateTimeFormat(pattern = "yyyy-MM-dd")
        private Date birthday;
    ​
        public User(int id, String name, Date birthday) {
            this.id = id;
            this.name = name;
            this.birthday = birthday;
        }
    ​
        public User() {
        }
    }
    Controller控制器
    //@Slf4j:使用log4j日志需要,默认生成log实例
    @Slf4j
    @Controller
    public class UserController {
    ​
        private static SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        @GetMapping("/getalluser")
        @ResponseBody
        public  String getAllUser(){
            User user = null;
            try {
                user = new User(1,"张三",sdf.parse("2020-10-10"));
            } catch (ParseException e) {
                log.debug("日期类型转换失败");
            }
            return user.toString();
        }
    }

    测试

    有服务端和客户端,类似WebSocket编程,需要我们先启动服务端;

    因此,我们需要先启动Eureka注册中心eureka-registryCenter,然后在启动Eureka客户端provider-payment8001

    浏览器输入:http://localhost:7001,会进入了Eureka服务注册中心

    输入:http://localhost:8001/getalluser,会访问到服务提供者的数据

     

    小结

    • 注册中心可以类比tomcat管理javaweb应用
    • Eureka有服务端和客户端概念,可以参考WebSocket编程
  • 相关阅读:
    C#下实现ping功能
    Telnet Chat Daemon
    ADO.NET连接池
    很好使的MAIL CLASS
    实例看多态
    完整的TCP通信包实现
    使用C#进行点对点通讯和文件传输(通讯基类部分)(转)
    特洛伊木马服务器源代码(C#)
    [C#] 如何选择一个目录
    如何使用C#压缩文件及注意的问题!
  • 原文地址:https://www.cnblogs.com/xzp-blog/p/13793999.html
Copyright © 2020-2023  润新知