当前位置: 首页 > news >正文

Spring Cloud学习:二【详细】

目录

Nacos的配置

Nacos的单机启动

服务注册

Nacos服务分级存储模型

优先访问同集群的服务

根据权重负载均衡

环境隔离Namespace

Nacos调用流程

Nacos与Eureka注册对比

Nacos与Eureka的共同点

Nacos与Eureka的区别

Nacos配置管理

统一配置

配置自动刷新

多环境配置共享

配置文件优先级

Nacos集群搭建

数据库初始化

配置nacos

启动nacos

负载均衡反向代理(Nginx)


Nacos的配置

在GitHub下载好Nacos之后,解压到目录中需要对其进行配置(如果端口不存在占用则不需要进行修改)。解压后进入conf目录下,编辑appliaction.properties文件修改端口(默认端口为8848)

Nacos的单机启动

启动方式:在bin目录下打开cmd窗口输入startup.cmd -m standalone

访问Nacos的主页(默认账号与密码都为nacos)

服务注册

Eureka与Nacos并不能同时存在,因此需要将Eureka的依赖注掉,引入Nacos的依赖,首先在父工程中引入管理依赖。

<!--nacos依赖管理-->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.5.RELEASE</version><type>pom</type><scope>import</scope>
</dependency>

在其他项目中引入Nacos的依赖

        <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

然后修改配置文件

spring:cloud:nacos:server-addr: localhost:8848 #服务端地址

启动服务观察Nacos主页

Nacos服务分级存储模型

一个服务比如说User-Server,启动起来的IP:端口 就是一个实例对象,不同机房的实例对象的集合叫集群。

之所以存在该模型是为了避免只有一个集群时,当机房发生事故导致服务无法访问。

服务调用尽可能的调用本地集群,跨集群访问延迟大。如果本地集群不可用再选择跨集群调用

默认是没有分配集群的,如果需要,需要在配置文件中进行配置

spring:cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HN #配置集群名称 河南

启动多个服务更换集群名称查看Nacos信息

优先访问同集群的服务

在没有配置的情况下,默认采用的是轮询的方式去调用服务,这不符合集群的访问规则,因此我们可以通过修改配置文件来实现优先访问同集群服务,然后再本地集群中选择随机的访问规则

xxx-server:ribbon:NFLoadBalancerRuleClassName: com.alibaba.cloud.naocs.ribbon.NacosRule #选择负载均衡策略

根据权重负载均衡

由于修改后的负载均衡策略是随机分配,但是有些设备性能较差,有些设备性能好,我们希望可以让性能好的设备多处理一些事件,那么我们可以通过修改权重来更改随机概率,权重越大,访问次数越多。

环境隔离Namespace

首先需要在Nacos控制台创建命名空间

然后将服务放置在命名空间,这就需要在代码中修改配置文件了

spring:cloud:nacos:server-addr: localhost:8848discovery:namespace: 命名空间ID

不在同一个命名空间的服务是无法互相访问的

Nacos调用流程

当服务没有配置时默认是临时实例,临时实例采用心跳检测存活状态,当服务挂掉之后,会直接将临时实例剔除,而非临时实例nacos会主动询问存活状态,当挂掉之后也不会剔除,等待重新启动,消费者会主动拉取生产者信息在自己内部缓存,当有状态发生变更时,nacos会立刻主动更新最新消息给消费者。

spring:cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HN #配置集群名称 河南ephemeral: false #设置为非临时实例

Nacos与Eureka注册对比

Nacos与Eureka的共同点

  • 都支持服务注册和服务拉取
  • 都支持服务提供者心跳方式做健康检测

Nacos与Eureka的区别

  • Nacos支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式。
  • 临时实例心跳不正常会被剔除,非临时实例则不会被剔除。
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时。
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式。

Nacos配置管理

当服务启动过多时,需要进行配置文件修改,如果一个一个修改则工作量较大且易出错,而且修改配置后还需要进行重启。为此,Nacos提供了配置管理服务

在配置内容栏中,并不是将所有的配置文件粘贴进去,而是由热更新需求的配置进去就好。

统一配置

在启动服务时在读取application文件时优先读取nacos文件中的内容,而nacos的地址就需要保存在一个读取优先级更高的文件中(bootstarp.yml)

实现该功能需要引入配置依赖

        <!--nacos的配置文件管理--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>

在resource添加配置文件bootstrap.yml

spring:application:name: 服务名称profiles:active: 命名空间IDcloud:nacos:server-addr: localhost:8848 #Nacos地址config:file-extension: yaml #文件后缀名

配置自动刷新

当配置文件更改时,默认是不会生效的,要实现自动刷新配置功能有两种方法。

  • 在读取nacos配置文件信息的类中添加@RefreshScope
  • 添加一个配置类使用@ConfigurationProperties注解

假如说我们存在一个时间格式转换的配置如下图

我们可以在使用@RefreshScope注解实现配置刷新

@RestController
@RequestMapping("order")
@RefreshScope
public class OrderController {@Value("${pattern.dateformat}")private String dateFormat;@Autowiredprivate OrderService orderService;@GetMapping("{orderId}")public Order queryOrderByUserId(@PathVariable("orderId") Long orderId,@RequestHeader(value = "Truth",required = false) String truth) {// 根据id查询订单并返回return orderService.queryOrderById(orderId);}
}

也可以使用配置类,然后在其他地方注入属性配置类,通过调用get方法获取配置值

@Data
@Component
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {private String dateformat;
}

注意:不是所有的配置都适合存放配置中心,一般是存放自定义配置

多环境配置共享

有一些是无论是什么环境都不会改变的配置可以采用多环境配置共享的方法来减少文件编写次数。

微服务启动时会从nacos读取多个配置文件:

  • [spring.application.name]-[spring.profiles.active].yaml,例: userservice-dev.yaml
  • [spring.application.name].yaml,例如: userservice.yaml

无论profile如何变化,[spring.application.name].yaml这个文件一定会加载,因此多环境共享配置可以写入这个文件。

配置文件优先级

当一个配置在Nacos中配置也在本地环境中配置时会存在配置文件优先级的问题。优先级从高到低排序为

  • [spring.application.name]-[spring.profiles.active].yaml:指定环境的优先级最高
  • [spring.application.name].yaml:多环境配置次高
  • 本地配置最低

因此,当同时配置一个属性时,会采用指定环境的nacos配置文件。

Nacos集群搭建

Nacos集群为了保持数据一致性,需要访问同一个数据库集群,当请求发起时通过Nginx进行负载均衡。

数据库初始化

sql文件在nacos文件下的conf文件下存在一份

如果不存在可以复制如下代码

CREATE TABLE `config_info` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',`data_id` varchar(255) NOT NULL COMMENT 'data_id',`group_id` varchar(255) DEFAULT NULL,`content` longtext NOT NULL COMMENT 'content',`md5` varchar(32) DEFAULT NULL COMMENT 'md5',`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',`src_user` text COMMENT 'source user',`src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',`app_name` varchar(128) DEFAULT NULL,`tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',`c_desc` varchar(256) DEFAULT NULL,`c_use` varchar(64) DEFAULT NULL,`effect` varchar(64) DEFAULT NULL,`type` varchar(64) DEFAULT NULL,`c_schema` text,PRIMARY KEY (`id`),UNIQUE KEY `uk_configinfo_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_aggr   */
/******************************************/
CREATE TABLE `config_info_aggr` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',`data_id` varchar(255) NOT NULL COMMENT 'data_id',`group_id` varchar(255) NOT NULL COMMENT 'group_id',`datum_id` varchar(255) NOT NULL COMMENT 'datum_id',`content` longtext NOT NULL COMMENT '内容',`gmt_modified` datetime NOT NULL COMMENT '修改时间',`app_name` varchar(128) DEFAULT NULL,`tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',PRIMARY KEY (`id`),UNIQUE KEY `uk_configinfoaggr_datagrouptenantdatum` (`data_id`,`group_id`,`tenant_id`,`datum_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='增加租户字段';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_beta   */
/******************************************/
CREATE TABLE `config_info_beta` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',`data_id` varchar(255) NOT NULL COMMENT 'data_id',`group_id` varchar(128) NOT NULL COMMENT 'group_id',`app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',`content` longtext NOT NULL COMMENT 'content',`beta_ips` varchar(1024) DEFAULT NULL COMMENT 'betaIps',`md5` varchar(32) DEFAULT NULL COMMENT 'md5',`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',`src_user` text COMMENT 'source user',`src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',`tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',PRIMARY KEY (`id`),UNIQUE KEY `uk_configinfobeta_datagrouptenant` (`data_id`,`group_id`,`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_beta';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_info_tag   */
/******************************************/
CREATE TABLE `config_info_tag` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',`data_id` varchar(255) NOT NULL COMMENT 'data_id',`group_id` varchar(128) NOT NULL COMMENT 'group_id',`tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',`tag_id` varchar(128) NOT NULL COMMENT 'tag_id',`app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',`content` longtext NOT NULL COMMENT 'content',`md5` varchar(32) DEFAULT NULL COMMENT 'md5',`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',`src_user` text COMMENT 'source user',`src_ip` varchar(50) DEFAULT NULL COMMENT 'source ip',PRIMARY KEY (`id`),UNIQUE KEY `uk_configinfotag_datagrouptenanttag` (`data_id`,`group_id`,`tenant_id`,`tag_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_info_tag';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = config_tags_relation   */
/******************************************/
CREATE TABLE `config_tags_relation` (`id` bigint(20) NOT NULL COMMENT 'id',`tag_name` varchar(128) NOT NULL COMMENT 'tag_name',`tag_type` varchar(64) DEFAULT NULL COMMENT 'tag_type',`data_id` varchar(255) NOT NULL COMMENT 'data_id',`group_id` varchar(128) NOT NULL COMMENT 'group_id',`tenant_id` varchar(128) DEFAULT '' COMMENT 'tenant_id',`nid` bigint(20) NOT NULL AUTO_INCREMENT,PRIMARY KEY (`nid`),UNIQUE KEY `uk_configtagrelation_configidtag` (`id`,`tag_name`,`tag_type`),KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='config_tag_relation';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = group_capacity   */
/******************************************/
CREATE TABLE `group_capacity` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',`group_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Group ID,空字符表示整个集群',`quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',`usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',`max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',`max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数,,0表示使用默认值',`max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',`max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',PRIMARY KEY (`id`),UNIQUE KEY `uk_group_id` (`group_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='集群、各Group容量信息表';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = his_config_info   */
/******************************************/
CREATE TABLE `his_config_info` (`id` bigint(64) unsigned NOT NULL,`nid` bigint(20) unsigned NOT NULL AUTO_INCREMENT,`data_id` varchar(255) NOT NULL,`group_id` varchar(128) NOT NULL,`app_name` varchar(128) DEFAULT NULL COMMENT 'app_name',`content` longtext NOT NULL,`md5` varchar(32) DEFAULT NULL,`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,`src_user` text,`src_ip` varchar(50) DEFAULT NULL,`op_type` char(10) DEFAULT NULL,`tenant_id` varchar(128) DEFAULT '' COMMENT '租户字段',PRIMARY KEY (`nid`),KEY `idx_gmt_create` (`gmt_create`),KEY `idx_gmt_modified` (`gmt_modified`),KEY `idx_did` (`data_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='多租户改造';/******************************************/
/*   数据库全名 = nacos_config   */
/*   表名称 = tenant_capacity   */
/******************************************/
CREATE TABLE `tenant_capacity` (`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID',`tenant_id` varchar(128) NOT NULL DEFAULT '' COMMENT 'Tenant ID',`quota` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '配额,0表示使用默认值',`usage` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '使用量',`max_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个配置大小上限,单位为字节,0表示使用默认值',`max_aggr_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '聚合子配置最大个数',`max_aggr_size` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '单个聚合数据的子配置大小上限,单位为字节,0表示使用默认值',`max_history_count` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '最大变更历史数量',`gmt_create` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`gmt_modified` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '修改时间',PRIMARY KEY (`id`),UNIQUE KEY `uk_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='租户容量信息表';CREATE TABLE `tenant_info` (`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 'id',`kp` varchar(128) NOT NULL COMMENT 'kp',`tenant_id` varchar(128) default '' COMMENT 'tenant_id',`tenant_name` varchar(128) default '' COMMENT 'tenant_name',`tenant_desc` varchar(256) DEFAULT NULL COMMENT 'tenant_desc',`create_source` varchar(32) DEFAULT NULL COMMENT 'create_source',`gmt_create` bigint(20) NOT NULL COMMENT '创建时间',`gmt_modified` bigint(20) NOT NULL COMMENT '修改时间',PRIMARY KEY (`id`),UNIQUE KEY `uk_tenant_info_kptenantid` (`kp`,`tenant_id`),KEY `idx_tenant_id` (`tenant_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='tenant_info';CREATE TABLE `users` (`username` varchar(50) NOT NULL PRIMARY KEY,`password` varchar(500) NOT NULL,`enabled` boolean NOT NULL
);CREATE TABLE `roles` (`username` varchar(50) NOT NULL,`role` varchar(50) NOT NULL,UNIQUE INDEX `idx_user_role` (`username` ASC, `role` ASC) USING BTREE
);CREATE TABLE `permissions` (`role` varchar(50) NOT NULL,`resource` varchar(255) NOT NULL,`action` varchar(8) NOT NULL,UNIQUE INDEX `uk_role_permission` (`role`,`resource`,`action`) USING BTREE
);INSERT INTO users (username, password, enabled) VALUES ('nacos', '$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu', TRUE);INSERT INTO roles (username, role) VALUES ('nacos', 'ROLE_ADMIN');

配置nacos

存在3个nacos节点,需要在conf目录下,先修改application.properties文件中的端口号,避免重复。其次将mysql配置打开。

其次修改cluster.conf.example文件,重命名为cluster.conf。并点击配置集群节点

如果是2.x版本的Nacos建议单口修改为8748、8648。因为在2.x版本之后又引入了gRPC服务,在启动时会占用相邻端口,启动第一个之后的其他Nacos节点会导致端口占用。

启动nacos

不需要指定-m等参数,直接输入指令startup.cmd

全部启动成功。

负载均衡反向代理(Nginx)

配置Nginx,修改conf文件下的nginx.conf文件,添加如下代码

双击启动nginx.exe

访问localhost/nacos展示如下

修改Java代码配置、Nacos与Nginx服务启动后需要在bootstarp.yml文件中配置Nginx配置的代理端口为80(你修改的Nginx端口)

http://www.lryc.cn/news/209156.html

相关文章:

  • Unity的live2dgalgame多语言可配置剧情框架
  • 再畅通工程(最小生成树)
  • 前后端分离不可忽视的陷阱,深入剖析挑战,分享解决方案,助你顺利实施分离开发。
  • (四)库存超卖案例实战——优化redis分布式锁
  • 【ROS入门】雷达、摄像头及kinect信息仿真以及显示
  • 实用篇-认识微服务
  • 【产品运营】产品需求应该如何管理
  • Linux 系统调用IO口,利用光标偏移实现文件复制
  • 【原创】指针变量作为函数参数要点注意
  • SpringMVC Day 04 : 数据绑定
  • 2.3.1 协程设计原理与汇编实现
  • J2EE项目部署与发布(Windows版本)->会议OA单体项目Windows部署,spa前后端分离项目Windows部署
  • Lua脚本语言
  • cat()函数和print()函数的区别
  • 宝塔面板安装Python和Flask(新版Python项目)
  • 火柴排队.
  • 改善游戏体验:数据分析与可视化的威力
  • GEE:本地影像上传到GEE的Assets中,并输入机器学习算法中作为特征变量
  • 【Mybatis源码】XMLConfigBuilder构建器 - 读取XML配置初始化Configuration对象
  • Python算法练习 10.28
  • 【java学习—八】单例设计模式(5)
  • 【设计模式】第4节:创建型模式之“单例模式”
  • NodeJS爬取墨刀上的设计图片
  • linux--
  • conda虚拟环境笔记收录
  • RGB-T Salient Object Detection via Fusing Multi-Level CNN Features
  • 安卓开发实例:方向传感器
  • [论文笔记]GTE
  • Prometheus字段解析
  • msigdbr hallmarks gsea broad研究所