基于k8s環(huán)境的spring-cloud服務(wù)發(fā)現(xiàn)和調(diào)用配置

spring-cloud在k8s環(huán)境下的服務(wù)發(fā)現(xiàn)調(diào)用凿滤,似乎有點不同,還有本地開發(fā)環(huán)境利诺,如何能調(diào)用到如文件上傳微服務(wù)?

通常在抽取出一個微服務(wù)后剩燥,需要給其他開發(fā)人員調(diào)用慢逾,通常會提供maven的jar包來調(diào)用此微服務(wù)。具體過程分成3部分如下:

  • 1.文件微服務(wù)fileupload灭红。

  • 2.調(diào)用文件微服務(wù)的jar包模塊侣滩,我們叫【文件微服務(wù)client】。

  • 3.調(diào)用文件微服務(wù)的測試服務(wù)test变擒,通常也就是其他微服務(wù)君珠。

注意為了方便把【1.文件微服務(wù)fileupload】和【3.測試服務(wù)test】寫在同一個工程下。

工程結(jié)構(gòu)如下:


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", /**掃描文件微服務(wù)client的類*/
"com.xxx.xxx" /**掃描本工程下的類*/
})
@EnableTransactionManagement
//k8s的服務(wù)發(fā)現(xiàn)娇斑,注意:這個和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類文件上傳微服務(wù)類唯竹,對外調(diào)用乐导。

public class FileUploadController {
/**
     * 上傳文件生成url,并標(biāo)記此文件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類調(diào)用【文件微服務(wù)client】進(jìn)行微服務(wù)的調(diào)用。

@RestController
@RequestMapping("/fileupload-test")
@Validated
@Slf4j
public class FileUploadTestController {
    //調(diào)用【文件微服務(wù)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和文件微服務(wù)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.文件微服務(wù)fileupload】和【3.測試服務(wù)test】完成蒂秘。

2.調(diào)用【文件微服務(wù)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類調(diào)用【文件微服務(wù)】接口姻僧。

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部署的微服務(wù)名字*/
        url = "http://10.10.94.2:8080", /**直接通過url進(jìn)行本地環(huán)境調(diào)用*/
        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>

最后,將【文件微服務(wù)】部署注冊到k8s撇贺,然后就可通過本地調(diào)用了赌莺,具體部署過程忽略。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末松嘶,一起剝皮案震驚了整個濱河市艘狭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌翠订,老刑警劉巖巢音,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異尽超,居然都是意外死亡官撼,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進(jìn)店門似谁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來傲绣,“玉大人,你說我怎么就攤上這事巩踏⊥核校” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵塞琼,是天一觀的道長菠净。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么嗤练? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮在讶,結(jié)果婚禮上煞抬,老公的妹妹穿的比我還像新娘。我一直安慰自己构哺,他們只是感情好革答,可當(dāng)我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著曙强,像睡著了一般残拐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上碟嘴,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天溪食,我揣著相機與錄音,去河邊找鬼娜扇。 笑死错沃,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的雀瓢。 我是一名探鬼主播枢析,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼刃麸!你這毒婦竟也來了醒叁?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤泊业,失蹤者是張志新(化名)和其女友劉穎把沼,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吁伺,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡智政,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了箱蝠。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片续捂。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖宦搬,靈堂內(nèi)的尸體忽然破棺而出牙瓢,到底是詐尸還是另有隱情,我是刑警寧澤间校,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布矾克,位于F島的核電站,受9級特大地震影響憔足,放射性物質(zhì)發(fā)生泄漏胁附。R本人自食惡果不足惜酒繁,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望控妻。 院中可真熱鬧州袒,春花似錦、人聲如沸弓候。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽菇存。三九已至夸研,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間依鸥,已是汗流浹背亥至。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留贱迟,地道東北人抬闯。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像关筒,于是被迫代替她去往敵國和親溶握。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,492評論 2 348

推薦閱讀更多精彩內(nèi)容