通过gateway实现服务的平滑迁移
本文属于b站图灵课堂springcloud笔记系列。讲得好还不要钱,值得推荐。
配置下试试。
再之前库存工程,新增了一个测试类
package org.tuling.tlmallstorage.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.concurrent.atomic.AtomicInteger;
@RestController
public class UrlController {
private Logger logger = LoggerFactory.getLogger(getClass());
@Value("${abcd.url:dddd}")
private String url;
private static final AtomicInteger URL_COUNT = new AtomicInteger(0);
private static final AtomicInteger NEW_URL_COUNT = new AtomicInteger(0);
@GetMapping("/url")
public String url(){
int count = URL_COUNT.incrementAndGet();
logger.info("url count:{}",count);
return url;
}
@GetMapping("/new/url")
public String newUrl(){
int count = NEW_URL_COUNT.incrementAndGet();
logger.info("new_url count:{}",count);
return url;
}
}
gateway 修改下application.yml
启动postman跑几百次,postman 得先把url save到collection,再从collection run ,设置迭代次数,这个不如jmeter方便。
观看下结果,大致符合设置权重:5:1.
官网的例子更直接:可以指定了机器。这样就是在nacos动态配置,开始老的机器占比达,慢慢调整到新机器上,实现平滑迁移。