基于k8s环境的spring-cloud服务发现和调用配置

spring-cloud在k8s环境下的服务发现调用,似乎有点不同,还有本地开发环境,如何能调用到如文件上传微服务?

通常在抽取出一个微服务后,需要给其他开发人员调用,通常会提供maven的jar包来调用此微服务。具体过程分成3部分如下:

  • 1.文件微服务fileupload。

  • 2.调用文件微服务的jar包模块,我们叫【文件微服务client】。

  • 3.调用文件微服务的测试服务test,通常也就是其他微服务。

注意为了方便把【1.文件微服务fileupload】和【3.测试服务test】写在同一个工程下。

工程结构如下:


aaa.png

主要的就是Application类注解的配置:

package com.xxx.xxx;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.transaction.annotation.EnableTransactionManagement;

@SpringBootApplication
@MapperScan("com.xxx.xxx.dao")
@ComponentScan({
"com.xxx.fileupload.feign", /**扫描文件微服务client的类*/
"com.xxx.xxx" /**扫描本工程下的类*/
})
@EnableTransactionManagement
//k8s的服务发现,注意:这个和spring-cloud的不一样。
@EnableDiscoveryClient
//注意,如果不配置basePackages可能会无法实例化类。
@EnableFeignClients(basePackages = "com.xxx.fileupload.feign")
//定时器配置注解
@EnableScheduling 
public class UploadFileApplication {
    public static void main(String[] args) {
        SpringApplication.run(UploadFileApplication.class, args);
        System.out.println("main end");
    }
}

FileUploadController类文件上传微服务类,对外调用。

public class FileUploadController {
/**
     * 上传文件生成url,并标记此文件url缓存2个小时,2个小时删除此文件。
     *
     * @param ao
     * @return
     */
    @PostMapping("/uploadFile")
    @ApiOperation(value = "上传文件")
    public ResultVo<Object> uploadFile(@Valid UploadFileAo ao) {
        PutObjectResult result;
        try {
            result = obsService.putObjectAndSetPreAccessStrategy(ao.fileMd5(), ao.getFile().getInputStream());
        } catch (IOException e) {
            return new ResultVo<>(500, "failed", "上传文件异常");
        }
        if (result.getStatusCode() == 200) {
            myRedisCache.hset("upfile", ao.fileMd5(), "{url:\"" + result.getObjectUrl() + "\",\"time\":" + System.currentTimeMillis() + "}");
        }
        return new ResultVo<>(result.getStatusCode(), "success", result);
    }
}

FileUploadTestController类调用【文件微服务client】进行微服务的调用。

@RestController
@RequestMapping("/fileupload-test")
@Validated
@Slf4j
public class FileUploadTestController {
    //调用【文件微服务client】的类
    @Autowired
    FileUploadClient client;

    /**
     *
     * @param ao
     * @return
     */
    @PostMapping("/uploadFile")
    @ApiOperation(value = "上传文件")
    public ResultVo<Object> uploadFile(@Valid UploadFileAo ao) {
        return client.uploadFile(ao);
    }

pom.xml主要依赖,k8s和文件微服务client。

  <dependencies>
 <dependency>
      <groupId>com.xxx.xxx</groupId>
      <artifactId>common-fileupload</artifactId>
      <version>1.0.0</version>
    </dependency>
<dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-kubernetes-config</artifactId>
    </dependency>
    <dependency>
 <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>

    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-kubernetes-all</artifactId>
    </dependency>

    <dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
    </dependency>
  </dependencies>

yml需要配置

logging:
  level:
    com.xxx.fileupload.feign.FileUploadClient: DEBUG
#熔断器
feign:
  hystrix:
    enabled: true

由此,【1.文件微服务fileupload】和【3.测试服务test】完成。

2.调用【文件微服务client】模块:
3690459-7487a36ba3c6856e.png

FeignLoggerConfiguration 类配置feign的log级别,以便打印出feign请求的log。

package com.xxx.fileupload.feign;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class FeignLoggerConfiguration {
    //指定feign的日志级别
    @Bean
    feign.Logger.Level feignLoggerLevel(){
        return feign.Logger.Level.FULL;
    }
}

FileUploadClient类调用【文件微服务】接口。

package com.xxx.fileupload.feign;

import com.xxx.fileupload.ao.SubmitUrlAo;
import com.xxx.fileupload.ao.UploadFileAo;
import com.xxx.fileupload.vo.ResultVo;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@FeignClient(name = "service-fileupload", /**k8s部署的微服务名字*/
        url = "http://10.10.94.2:8080", /**直接通过url进行本地环境调用*/
        fallback = FileUploadClientFallback.class, /**熔断处理类*/
        configuration = FeignLoggerConfiguration.class) /**log配置类*/
public interface FileUploadClient {
    @RequestMapping(path = "/fileupload/uploadFile", method = RequestMethod.POST)
    ResultVo<Object> uploadFile(UploadFileAo ao);
    @RequestMapping(path = "/fileupload/submitFileUrlsMd5", method = RequestMethod.POST)
    ResultVo<Object> submitFileUrlsMd5(SubmitUrlAo ao);
}

FileUploadClientFallback 类熔断处理。

package com.xxx.fileupload.feign;

import com.xxx.fileupload.ao.SubmitUrlAo;
import com.xxx.fileupload.ao.UploadFileAo;
import com.xxx.fileupload.vo.ResultVo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

@Component
public class FileUploadClientFallback implements FileUploadClient {
    private Logger logger = LoggerFactory.getLogger(FileUploadClientFallback.class);

    @Override
    public ResultVo<Object> uploadFile(UploadFileAo ao) {
        logger.info("uploadFile {}",ao.toString());
        return new ResultVo<>(500, "fallback");
    }

    @Override
    public ResultVo<Object> submitFileUrlsMd5(SubmitUrlAo ao) {
        logger.info("submitFileUrlsMd5 {}",ao.toString());
        return new ResultVo<>(500, "fallback");
    }
}

pom.xml

 <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.2.5.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.30</version>
        </dependency>
 </dependencies>

最后,将【文件微服务】部署注册到k8s,然后就可通过本地调用了,具体部署过程忽略。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容