美文网首页SpringCloudJava 杂谈程序员
SpringCloud 广告系统实战(五) - 广告检索系统(微

SpringCloud 广告系统实战(五) - 广告检索系统(微

作者: 紫霞等了至尊宝五百年 | 来源:发表于2019-02-11 10:21 被阅读58次

    0 联系我


    1.Java开发技术交流Q群

    2.完整博客链接

    3.个人知乎

    4.gayhub

    相关源码

    本文会介绍使用 Ribbon 与 Feign 组件实现微服务之间的调用。

    1 创建广告检索系统子模块

    • 新建搜索服务子模块


    • 编辑 pom 文件
    <?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">
        <!-- 指定父pom, 注意它是 javaedge-ad-service 的子模块 -->
        <parent>
            <artifactId>javaedge-ad-service</artifactId>
            <groupId>com.sss.ad</groupId>
            <version>1.0-SNAPSHOT</version>
        </parent>
    
        <modelVersion>4.0.0</modelVersion>
    
        <!-- 当前项目/模块的坐标, groupId从父模块中继承 -->
        <artifactId>ad-search</artifactId>
        <version>1.0-SNAPSHOT</version>
        <packaging>jar</packaging>
    
        <dependencies>
            <!-- Hystrix 监控 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
            </dependency>
            <!-- 监控端点, 采集应用指标 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-actuator</artifactId>
            </dependency>
            <!-- 引入 Web 功能 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <!--
                Eureka 客户端, 客户端向 Eureka Server 注册的时候会提供一系列的元数据信息, 例如: 主机, 端口, 健康检查url等
                Eureka Server 接受每个客户端发送的心跳信息, 如果在某个配置的超时时间内未接收到心跳信息, 实例会被从注册列表中移除
            -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            </dependency>
            <!-- 引入 Feign, 可以以声明的方式调用微服务 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-openfeign</artifactId>
            </dependency>
            <!-- 引入服务容错 Hystrix 的依赖 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
            </dependency>
            <!-- 引入服务消费者 Ribbon 的依赖 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
            </dependency>
            <!-- Java Persistence API, ORM 规范 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-jpa</artifactId>
            </dependency>
            <!-- 数据库连接 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-jdbc</artifactId>
            </dependency>
            <!-- MySQL 驱动, 注意, 这个需要与 MySQL 版本对应 -->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>8.0.12</version>
                <scope>runtime</scope>
            </dependency>
    
            <!-- 通用模块 -->
            <dependency>
                <groupId>com.sss.ad</groupId>
                <artifactId>ad-common</artifactId>
                <version>1.0-SNAPSHOT</version>
            </dependency>
            <!-- apache 提供的一些工具类 -->
            <dependency>
                <groupId>commons-codec</groupId>
                <artifactId>commons-codec</artifactId>
                <version>1.9</version>
            </dependency>
            <!-- 集合类操作 -->
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-collections4</artifactId>
                <version>4.0</version>
            </dependency>
    
            <!-- binlog 监听与解析: https://github.com/shyiko/mysql-binlog-connector-java -->
            <dependency>
                <groupId>com.github.shyiko</groupId>
                <artifactId>mysql-binlog-connector-java</artifactId>
                <version>0.13.0</version>
            </dependency>
            <!-- 解析配置文件中的配置 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-configuration-processor</artifactId>
            </dependency>
            <!--kafka 依赖-->
            <dependency>
                <groupId>org.springframework.kafka</groupId>
                <artifactId>spring-kafka</artifactId>
                <version>2.1.5.RELEASE</version>
            </dependency>
        </dependencies>
    
        <!--
            SpringBoot的Maven插件, 能够以Maven的方式为应用提供SpringBoot的支持,可以将
            SpringBoot应用打包为可执行的jar或war文件, 然后以通常的方式运行SpringBoot应用
         -->
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    </project>
    
    • 新建启动类


    2 基于 Ribbon 实现微服务调用

    • 定义 demo 演示类




    3 基于 Feign 实现微服务调用

    6-4 关于微服务调用的介绍及作业

    相关文章

      网友评论

        本文标题:SpringCloud 广告系统实战(五) - 广告检索系统(微

        本文链接:https://www.haomeiwen.com/subject/munfeqtx.html