From de3f1b8f1d7f9c79425bf831394a101c6a6eabef Mon Sep 17 00:00:00 2001 From: "minquan.chen" Date: Mon, 17 Apr 2023 16:11:52 +0800 Subject: [PATCH 1/6] enhance adservice-v2 --- src/adservice-v2/README.md | 6 ++ .../adservice/controller/AdController.java | 6 +- .../springcloud/adservice/dto/Advertise.java | 25 ++++++- .../service/AdServiceGrpcService.java | 74 ++++++++++++++----- .../src/main/resources/bootstrap.yml | 2 + 5 files changed, 93 insertions(+), 20 deletions(-) diff --git a/src/adservice-v2/README.md b/src/adservice-v2/README.md index 553d9a239f..779cf4cf8f 100644 --- a/src/adservice-v2/README.md +++ b/src/adservice-v2/README.md @@ -12,6 +12,12 @@ This repo re-implements opentelemetry-demo-webstore's adservice with nacos regis - [x] nacos - [x] sentinel +## get data from dataservice + +if `-Dspring.dataService.enabled` is true, adservice will call dataservice to get Ad data, +if `-Dspring.cloud.nacos.config.enabled` is true, adservice use service name registry in nacos as addr to call dataservice, +otherwise it uses host:port as addr. + ## curl ```shell diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java index f29a288c47..b6506e0032 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java @@ -21,9 +21,13 @@ public AdController(final RestTemplate restTemplate) { @Value("${data_service_name:dataservice}") private String dataServiceName; + @GetMapping("/ad-key/{adKey}") + public ResponseEntity findByAdKey(@PathVariable String key) { + return this.restTemplate.getForEntity("http://" + dataServiceName + "ad/ad-key/{key}", Advertise[].class, key); + } @GetMapping("/{id}") public ResponseEntity findById(@PathVariable Long id) { - return this.restTemplate.getForEntity("http://" + dataServiceName + "/ad/{id}", Advertise.class, id); + return this.restTemplate.getForEntity("http://" + dataServiceName + "/ad/id{id}", Advertise.class, id); } @GetMapping("/all") diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/dto/Advertise.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/dto/Advertise.java index a647fc24dc..f829b1fb4f 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/dto/Advertise.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/dto/Advertise.java @@ -3,21 +3,42 @@ public class Advertise { private Integer id; + private String adKey; + + + private String redirectURL; + private String content; public Integer getId() { return id; } - public void setId(final Integer id) { + public void setId(Integer id) { this.id = id; } + public String getAdKey() { + return adKey; + } + + public void setAdKey(String adKey) { + this.adKey = adKey; + } + + public String getRedirectURL() { + return redirectURL; + } + + public void setRedirectURL(String redirectURL) { + this.redirectURL = redirectURL; + } + public String getContent() { return content; } - public void setContent(final String content) { + public void setContent(String content) { this.content = content; } } diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java index a508eadf8a..404c915fe4 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java @@ -18,10 +18,14 @@ import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.daocloud.springcloud.adservice.Interceptor.MeterInterceptor; +import org.daocloud.springcloud.adservice.controller.AdController; +import org.daocloud.springcloud.adservice.dto.Advertise; import org.daocloud.springcloud.adservice.meter.Meter; import org.ejml.simple.SimpleMatrix; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.ResponseEntity; +import org.springframework.web.client.RestTemplate; import oteldemo.AdServiceGrpc; import oteldemo.Demo.Ad; import oteldemo.Demo.AdRequest; @@ -38,6 +42,9 @@ public class AdServiceGrpcService extends AdServiceGrpc.AdServiceImplBase { @Autowired private Meter meterProvider; + @Autowired + private AdController adController; + @Value("${spring.extraAdLabel}") private String text; @@ -47,6 +54,12 @@ public class AdServiceGrpcService extends AdServiceGrpc.AdServiceImplBase { @Value("${spring.matrixRow}") private int matrixRow; + @Value("${spring.dataService.enabled}") + private boolean dataService; + + @Value("${spring.cloud.nacos.config.enabled}") + private boolean nacos; + @Override public void getAds(AdRequest req, StreamObserver responseObserver) { // get the current span in context @@ -61,26 +74,53 @@ public void getAds(AdRequest req, StreamObserver responseObserver) { // do matrixCalculate matrixCalculate(matrixRow); - if(randomError){ - //throw random error - Random random = new Random(); - int r = random.nextInt(100)+1; - if(r > 50){ - throw new StatusRuntimeException(Status.INTERNAL.withDescription("connect Canceled randomly")); + if(dataService){ + ResponseEntity advertiseResponseEntity = null; + if(nacos){ + for (int i = 0; i < req.getContextKeysCount(); i++){ + advertiseResponseEntity = adController.getAllAds(); + } + }else{ + String dataServiceAddr = System.getenv("DATA_SERVICE_ADDR"); + RestTemplate restTemplate = new RestTemplate(); + for (int i = 0; i < req.getContextKeysCount(); i++){ + advertiseResponseEntity = restTemplate.getForEntity("http://"+dataServiceAddr+"/ad/ad-key/{key}",Advertise[].class,req.getContextKeys(i)); + } } - } - if (req.getContextKeysCount() > 0) { - for (int i = 0; i < req.getContextKeysCount(); i++) { - Collection ads = getAdsByCategory(req.getContextKeys(i)); - allAds.addAll(ads); + assert advertiseResponseEntity != null; + Advertise[] advertises = advertiseResponseEntity.getBody(); + + assert advertises != null; + for(Advertise a: advertises){ + Ad ad = Ad.newBuilder() + .setRedirectUrl(a.getRedirectURL()) + .setText(a.getContent()) + .build(); + allAds.add(ad);; + } + }else { + if(randomError){ + //throw random error + Random random = new Random(); + int r = random.nextInt(100)+1; + if(r > 50){ + throw new StatusRuntimeException(Status.INTERNAL.withDescription("connect Canceled randomly")); + } + } + + if (req.getContextKeysCount() > 0) { + for (int i = 0; i < req.getContextKeysCount(); i++) { + Collection ads = getAdsByCategory(req.getContextKeys(i)); + allAds.addAll(ads); + } + } else { + allAds = getRandomAds(); + } + if (allAds.isEmpty()) { + // Serve random ads. + allAds = getRandomAds(); } - } else { - allAds = getRandomAds(); - } - if (allAds.isEmpty()) { - // Serve random ads. - allAds = getRandomAds(); } List allAdsLabeled = addLabel(allAds); diff --git a/src/adservice-v2/src/main/resources/bootstrap.yml b/src/adservice-v2/src/main/resources/bootstrap.yml index 8a9540a73a..ea3d4fbd52 100644 --- a/src/adservice-v2/src/main/resources/bootstrap.yml +++ b/src/adservice-v2/src/main/resources/bootstrap.yml @@ -146,3 +146,5 @@ spring: extraAdLabel: Daocloud randomError: true matrixRow: 200 + dataService: + enabled: true From cbcad18f7c04849c34f8cd064aee01d6452f1298 Mon Sep 17 00:00:00 2001 From: "minquan.chen" Date: Mon, 17 Apr 2023 16:25:27 +0800 Subject: [PATCH 2/6] update --- .../springcloud/adservice/service/AdServiceGrpcService.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java index 404c915fe4..0ba007219b 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java @@ -75,12 +75,15 @@ public void getAds(AdRequest req, StreamObserver responseObserver) { matrixCalculate(matrixRow); if(dataService){ + logger.info("data service is enabled, get Ad data from dataservice"); ResponseEntity advertiseResponseEntity = null; if(nacos){ + logger.info("nacos is enabled, call dataservice by nacos registry"); for (int i = 0; i < req.getContextKeysCount(); i++){ advertiseResponseEntity = adController.getAllAds(); } }else{ + logger.info("nacos is disabled, call dataservice by raw http"); String dataServiceAddr = System.getenv("DATA_SERVICE_ADDR"); RestTemplate restTemplate = new RestTemplate(); for (int i = 0; i < req.getContextKeysCount(); i++){ From 005b5b9719542c970e097a8f296e679f0e698636 Mon Sep 17 00:00:00 2001 From: "minquan.chen" Date: Mon, 17 Apr 2023 16:50:11 +0800 Subject: [PATCH 3/6] update --- src/adservice-v2/src/main/resources/bootstrap.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/adservice-v2/src/main/resources/bootstrap.yml b/src/adservice-v2/src/main/resources/bootstrap.yml index ea3d4fbd52..14a193c59e 100644 --- a/src/adservice-v2/src/main/resources/bootstrap.yml +++ b/src/adservice-v2/src/main/resources/bootstrap.yml @@ -147,4 +147,4 @@ spring: randomError: true matrixRow: 200 dataService: - enabled: true + enabled: false From f622dff1b4bf08b0e6e3f5e05498c4c4a2d322c0 Mon Sep 17 00:00:00 2001 From: "minquan.chen" Date: Mon, 17 Apr 2023 16:53:38 +0800 Subject: [PATCH 4/6] update --- .../daocloud/springcloud/adservice/controller/AdController.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java index b6506e0032..01533eb138 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/controller/AdController.java @@ -27,7 +27,7 @@ public ResponseEntity findByAdKey(@PathVariable String key) { } @GetMapping("/{id}") public ResponseEntity findById(@PathVariable Long id) { - return this.restTemplate.getForEntity("http://" + dataServiceName + "/ad/id{id}", Advertise.class, id); + return this.restTemplate.getForEntity("http://" + dataServiceName + "/ad/{id}", Advertise.class, id); } @GetMapping("/all") From 7d57e13f1541c6e8bfc9707c1548c51d215e38e6 Mon Sep 17 00:00:00 2001 From: Murphy Chen Date: Mon, 17 Apr 2023 17:08:35 +0800 Subject: [PATCH 5/6] Apply suggestions from code review Co-authored-by: Jared Tan --- .../adservice/service/AdServiceGrpcService.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java index 0ba007219b..50de30fc80 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java @@ -55,10 +55,10 @@ public class AdServiceGrpcService extends AdServiceGrpc.AdServiceImplBase { private int matrixRow; @Value("${spring.dataService.enabled}") - private boolean dataService; + private boolean dataServiceEnabled; @Value("${spring.cloud.nacos.config.enabled}") - private boolean nacos; + private boolean nacosEnabled; @Override public void getAds(AdRequest req, StreamObserver responseObserver) { @@ -74,10 +74,10 @@ public void getAds(AdRequest req, StreamObserver responseObserver) { // do matrixCalculate matrixCalculate(matrixRow); - if(dataService){ + if(dataServiceEnabled){ logger.info("data service is enabled, get Ad data from dataservice"); ResponseEntity advertiseResponseEntity = null; - if(nacos){ + if(nacosEnabled){ logger.info("nacos is enabled, call dataservice by nacos registry"); for (int i = 0; i < req.getContextKeysCount(); i++){ advertiseResponseEntity = adController.getAllAds(); From 8626276effc41432a9f99ba88670fb3b9e5a72b3 Mon Sep 17 00:00:00 2001 From: "minquan.chen" Date: Mon, 17 Apr 2023 17:09:28 +0800 Subject: [PATCH 6/6] update --- .../springcloud/adservice/service/AdServiceGrpcService.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java index 50de30fc80..8bda9edce5 100644 --- a/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java +++ b/src/adservice-v2/src/main/java/org/daocloud/springcloud/adservice/service/AdServiceGrpcService.java @@ -80,7 +80,7 @@ public void getAds(AdRequest req, StreamObserver responseObserver) { if(nacosEnabled){ logger.info("nacos is enabled, call dataservice by nacos registry"); for (int i = 0; i < req.getContextKeysCount(); i++){ - advertiseResponseEntity = adController.getAllAds(); + advertiseResponseEntity = adController.findByAdKey(req.getContextKeys(i)); } }else{ logger.info("nacos is disabled, call dataservice by raw http");