springcloud注册nacos服务、Ribbon的使用

上一篇文章讲的是springcloud注册eureka,本篇讲springcloud注册nacos服务
首先下载nacos最新版本服务器地址:github下载地址
解压进入到bin目录,编辑startup.cmd文件,找到Set Mode=“cluster”,改为Set Mode=“standalone”。说明:把nacos启动模式从集群改为单机。
进入conf目录,打开application.properties
在这里插入图片描述
修改nacos数据库连接
在这里插入图片描述
默认使用mysql数据库,建立数据库名为nacos_config
在mysql中执行conf目录下nacos-mysql.sql文件,打开nacos_config数据库的users表
在这里插入图片描述
这是nacos用户表,登录使用的用户名和密码:nacos/nacos
执行startup.cmd启动nacos服务,出现界面:
在这里插入图片描述
表示nacos成功启动,浏览器进入http://localhost:8848/nacos登录界面
在这里插入图片描述
输入用户名密码进入首页
在这里插入图片描述
创建springcloud项目,引入springboot-starter-parent

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.5.14</version>
	</parent>

springcloud依赖

	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>2020.0.6</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>

Nacos和Ribbon的相关依赖

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
         <!-- 服务注册nacos需要的依赖 -->
        <dependency>
             <groupId>com.alibaba.cloud</groupId>
             <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
             <version>2.1.2.RELEASE</version>
         </dependency>
        <!-- 引入ribbon 依赖,用来实现负载均衡 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
            <version>2.1.2.RELEASE</version>
        </dependency>
    </dependencies>

application.properties文件配置

server.port=8081
spring.application.name=nacosSystem
##springcloud注册nacos服务地址
spring.cloud.nacos.discovery.server-addr=localhost:8848

首先,需要启用 nacos-discovery,它是用于nacos服务的发现,我们要注册nacos服务就要发现它。
其次,使用Ribbon实现负责均衡,可使用两种方法实现:
1.同时使用loadBalancerClient和RestTemplate

@SpringBootApplication
@EnableDiscoveryClient
@Configuration
public class LoadApplication {
	@Autowired
    private LoadBalancerClient loadBalancerClient;
    @Autowired
    private RestTemplate restTemplate;
	@Bean
	public RestTemplate restTemplate() {
		return new RestTemplate();
	}

	@RequestMapping("/test")
	public String test(){
		//使用 LoadBalanceClient 和 RestTemolate 结合的方式来访问
        ServiceInstance serviceInstance = loadBalancerClient.choose("nacosSystem");
        String url = "http://"+serviceInstance.getHost()+":"+serviceInstance.getPort()+"/hello"
        return restTemplate.getForObject(url,String.class);
	}

	public static void main(String[] args) {
		SpringApplication.run(LoadApplication.class, args);
	}
}

2.Ribbon使用的RestTemplate 类上加@LoadBalanced注解表示启动负载均衡,这时可去掉注解@EnableDiscoveryClient,同样能发现nacos服务

@SpringBootApplication
@Configuration
public class LoadApplication {
	@Autowired
    private RestTemplate restTemplate;
    
	@Bean
	@LoadBalanced
	public RestTemplate restTemplate() {
		return new RestTemplate();
	}
	@RequestMapping("/test")
	public String test(){
        return restTemplate.getForObject("http://nacosSystem/hello",String.class);
	}

	public static void main(String[] args) {
		SpringApplication.run(LoadApplication.class, args);
	}
}

这时URL地址无需加入ip地址,直接使用:应用名称+路径

注1:为什么加上 @LoadBalanced就不能访问ip加端口呢?
因为在加了注解 @LoadBalanced 之后,我们的restTemplate 会走这个类RibbonLoadBalancerClient,serverid必须是我们访问的服务名称 ,当我们直接输入ip的时候获取的server是null,就会抛出异常。而这个服务名称是需要我们在Eureka中配置的,如果没有配置直接访问则会报错。

注2:为什么不加IP和端口都能通过RestTemplate访问呢?
添加了ribbon依赖后,会在项目启动的时候自动往RestTemplate中添加LoadBalancerInterceptor拦截器,用户根据RestTemplate发起请求时,会将请求转发到LoadBalancerInterceptor去执行,该拦截器会根据指定的负载均衡方式获取该次请求对应的应用服务端IP、port。根据获取到的IP、port重新封装请求,发送HTTP请求,返回具体响应

org.springframework.web.client.RestTemplate因为使用得比较多,其详细使用方法可参考博客:RestTemplate API

最后,启动两个springcloud项目,nacos注册可在列表中查看到
在这里插入图片描述
至此,springcloud的nacos注册,和Ribbon负责均衡的使用讲述完毕

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不知道明天和天明

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值