中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

『高級篇』docker之開發課程EdgeService(16)

發布時間:2020-05-25 21:28:32 來源:網絡 閱讀:200 作者:IT人故事 欄目:云計算

原創文章,歡迎轉載。轉載請注明:轉載自IT人故事會,謝謝!
原文鏈接地址:『高級篇』docker之開發課程EdgeService(16)

課程的edgeService依賴于課程服務的dubbo服務,對外提供的restAPI,跟用戶的EdgeService有點類似,只是一個調用的是thrift,一個調用的是dubbo,比較特殊的是課程的EdgeService需要用戶登錄后才可以訪問,如果沒有登錄的話,需要跳轉到登錄系統才可以訪問。源碼:https://github.com/limingios/msA-docker

『高級篇』docker之開發課程EdgeService(16)

新建模塊course-edge-servce

『高級篇』docker之開發課程EdgeService(16)

  • 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">
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.3.RELEASE</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.idig8</groupId>
    <artifactId>course-edge-service</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
        </dependency>
        <dependency>
            <groupId>com.idig8</groupId>
            <artifactId>course-dubbo-service-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>com.idig8</groupId>
            <artifactId>user-edge-service-client</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

    </dependencies>

</project>

『高級篇』docker之開發課程EdgeService(16)

  • controller 調用course-dubbo-service-api 中的接口
    
    package com.idig8.course.controller;

import com.alibaba.dubbo.config.annotation.Reference;
import com.idig8.course.dto.CourseDTO;
import com.idig8.course.service.ICourseService;
import com.idig8.thrift.user.dto.UserDTO;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import java.util.List;

/**

  • Created by Michael on 2017/11/4.*/
    @Controller
    br/>*/
    @Controller
    public class CourseController {

    @Reference
    private ICourseService courseService;

    @RequestMapping(value = "/courseList", method = RequestMethod.GET)@ResponseBody
    br/>@ResponseBody

    UserDTO user = (UserDTO)request.getAttribute("user");
    System.out.println(user.toString());
    
    return courseService.courseList();

    }
    }


![](https://upload-images.jianshu.io/upload_images/11223715-58de6c1baaf6bccf.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

* 增加filter組件
``` java
package com.idig8.course.filter;

import com.idig8.thrift.user.dto.UserDTO;
import com.idig8.user.client.LoginFilter;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Created by liming.
 */
@Component
public class CourseFilter extends LoginFilter {

    @Value("${user.edge.service.addr}")
    private String userEdgeServiceAddr;

    @Override
    protected String userEdgeServiceAddr() {
        return userEdgeServiceAddr;
    }

    @Override
    protected void login(HttpServletRequest request, HttpServletResponse response, UserDTO userDTO) {

        request.setAttribute("user", userDTO);
    }
}

『高級篇』docker之開發課程EdgeService(16)

  • 啟動類
    
    package com.idig8.course;

import com.idig8.course.filter.CourseFilter;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;

import java.util.ArrayList;
import java.util.List;

/**

  • Created by liming*/
    @SpringBootApplication
    br/>*/
    @SpringBootApplication

    public static void main(String args[]) {
    SpringApplication.run(ServiceApplication.class, args);
    }

    @Bean
    public FilterRegistrationBean filterRegistrationBean(CourseFilter courseFilter ) {
    FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
    filterRegistrationBean.setFilter(courseFilter);

    List<String> urlPatterns = new ArrayList<String>();
    urlPatterns.add("/*");
    filterRegistrationBean.setUrlPatterns(urlPatterns);
    return filterRegistrationBean;

    }
    }


![](https://upload-images.jianshu.io/upload_images/11223715-5cf13f17115c9b6d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

* application.properties

``` properties
server.port=8081

#dubbo config
spring.dubbo.application.name=course-service
spring.dubbo.registry.address=zookeeper://47.98.183.16:2181
spring.dubbo.scan=com.idig8.course

user.edge.service.addr=127.0.0.1:8082

『高級篇』docker之開發課程EdgeService(16)

業務流程梳理

『高級篇』docker之開發課程EdgeService(16)

  1. 課程EdgeService 依賴用戶EdgeService服務,Thrift用戶服務,課程服務。
  2. 課程 EdgeService pom 依賴了用戶登錄user-edge-service-client,user-edge-service-client用于檢測用戶是否登錄功能。需要調用用戶的服務。
  3. 當用戶完成登錄后,課程EdgeService 訪問課程服務,獲取課程的列表信息。
  4. 課程EdgeService 依賴用戶EdgeService服務,Thrift用戶服務登錄控制,登錄后的跳轉功能。
  5. 課程EdgeService 依賴與course-dubbo-service-api服務,用于獲取課程信息和用戶的課程信息。

梳理下dubbo的思路

  1. 建立對應的api項目定義方法。最終提供一個jar包供調用方和服務提供方使用。
  2. 服務實現方引用api項目,實現里面的功能,提供端口,名稱,地址,zookeeper監控中心。
  3. 服務調用方引用api項目,引用zookeeper的監控中心發現服務。直接調用服務就可以用服務實現方的方法了。

程序演示

  • 啟動服務(按照順序)

    1. user-thrift-service
    2. user-edge-service
    3. course-dubbo-service
    4. course-edge-service
  • 界面演示
    1. 訪問http://127.0.0.1:8081 自動跳轉到http://127.0.0.1:8082/user/login
    2. 登錄獲取到token
      3.訪問地址http://127.0.0.1:8081/course/courseList?token=ux4g5z98mowv0qr6r6e6ietdo00nh0vl

『高級篇』docker之開發課程EdgeService(16)

『高級篇』docker之開發課程EdgeService(16)

PS:微服務跟之前說的一樣就是互相通過RPC的方式進行通信,之間有自己的數據庫,只是RPC暴露接口的方式來獲取其他的微服務之間的數據。

『高級篇』docker之開發課程EdgeService(16)

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

蒙城县| 阳城县| 开封县| 宁南县| 应用必备| 南丹县| 横峰县| 大石桥市| 栖霞市| 和平区| 莲花县| 长阳| 大荔县| 锡林郭勒盟| 栾城县| 从化市| 贺兰县| 银川市| 读书| 海兴县| 鄱阳县| 湘乡市| 郎溪县| 宿松县| 山东省| 林西县| 孟连| 行唐县| 黎平县| 犍为县| 金乡县| 德令哈市| 古蔺县| 吴江市| 临海市| 健康| 武鸣县| 抚松县| 神木县| 枣庄市| 惠水县|