服务注册和发现前话:
因为这篇博客是紧跟上一篇博客的。然后我也是初学者,有什么问题可以评论区交流。谢谢大家!
微服务的服务注册和发现相信都用过Eureka,要自己本地构建一个Eureka微服务,但是整合了Alibaba的Nacos则不用那么复杂,直接启动Alibaba提供的Nacos服务即可,这样让程序员把全部精力放在业务上,下面是一个简单的架构图:
2、新建一个子项目nacos-provider 3、导入依赖org.springframework.boot spring-boot-dependencies 2.6.4 pom import org.springframework.boot spring-boot-starter-web 2.6.4 org.springframework.cloud spring-cloud-dependencies 2021.0.1 pom import com.alibaba.cloud spring-cloud-alibaba-dependencies 2.2.0.RELEASE pom import
4、编写配置com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery org.springframework.boot spring-boot-starter-web
server:
port: 9001
spring:
application:
name: nacos-provider
cloud:
nacos:
discovery:
# nacos的服务地址,nacos-server的ip地址:端口号
server-addr: 127.0.0.1:8848
5、写主启动类
package com.sky;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
// 一般springcloud组件导入什么就要开启什么,开启nacos的服务注册
@EnableDiscoveryClient
public class NacosDiscoveryApplication {
public static void main(String[] args) {
SpringApplication.run(NacosDiscoveryApplication.class,args);
}
}
6、编写controller测试(NacosController)
package com.sky.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
// RestController:返回页面字符串
@RestController
@RequestMapping("/nacos")
public class NacosController {
@GetMapping("/test/{id}")
public String test(@PathVariable("id") Integer id){
return "accept one msg id="+id;
}
}
7、启动项目访问localhost:9001/nacos/test/1
服务消费者 1、导入依赖访问成功
我们再查看nacos控制台
2、编写配置com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery org.springframework.boot spring-boot-starter-web org.springframework.cloud spring-cloud-starter-netflix-ribbon
server:
port: 9002
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
# nacos的服务地址
server-addr: 127.0.0.1:8848
3、编写主启动类
package com.sky;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(NacosConsumerApplication.class,args);
}
}
4、编写配置类
package com.sky.config;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;
@Configuration
public class BeanConfig {
@LoadBalanced
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
5、编写controller用restTemplate调用提供者方法
package com.sky.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;
@RestController
@RequestMapping("/nacos")
public class NacosController {
@Autowired
private RestTemplate restTemplate;
// 使用提供者的项目名
private static final String REST_URL_PREFIX = "http://nacos-provider";
// private static final String REST_URL_PREFIX = "http://127.0.0.1:9001";
@GetMapping("/test/{id}")
public String test(@PathVariable("id") Integer id){
return restTemplate.getForObject(REST_URL_PREFIX+"/nacos/test/"+id,String.class);
}
}
6、测试,访问http://localhost:9002/nacos/test/16
访问成功!
nacos对比Eureka简直是简单太多了!



