Redis的哨兵
Redis的哨兵 Sentinel
- 一.哨兵概念
- 1.相关名词解释图
- 二.主节点恢复方式
- 1.人工恢复主节点故障流程图
- 2.哨兵自动恢复主节点流程
- 三.使用docker搭建环境
- 1.安装docker-compose
- 2.安装docker
- 3.停止之前的redis服务器
- 4.使用docker获取到redis的镜像
- 5.使用docker-compose进行容器编排
- 创建目录
- 打开yml文件
- 写配件文件
- 启动数据节点:
- 搞哨兵节点
- 四.哨兵节点作用演示
- 1.先停止主节点
- 2.主节点停止后的情况
- 3.启动之前关闭的主节点
- 五.哨兵重选主节点流程
- 1.主观下线
- 2.客观下线
- 3.选举主节点
- 4.挑选新的主节点
一.哨兵概念
通过自动化的方式来解决主节点挂了的问题,哨兵机制是通过独立的进程来体现的,与redis-server是不同的进程,redis-sentinel不负责存储数据,只是对其他的redis-server进程起到监控的效果。
1.相关名词解释图
二.主节点恢复方式
1.人工恢复主节点故障流程图
下图中的用户监控一般是通过用户自己写的程序对服务器进行监控,当发生异常时,对用户进行报警。
2.哨兵自动恢复主节点流程
哨兵节点集合中是单独的多个redis sentinel进程,并且这三个哨兵进程会监控现有的redis master和slave(监控:这些进程之间会建立TCP长连接,通过这样的长连接,定期发送心跳包)
借助上述的监控机制就可以即使发现某个主机是否挂了,如果从节点挂了没什么关系,如果主节点挂了,哨兵就会发挥作用了。
此时一个哨兵节点发现主节点挂了还不能够判定主节点是否真的挂了,此时还需要多个哨兵共同认为主节点挂了,才是真的挂了,主要是为了防止误判,毕竟有时候哨兵也会出现网络问题。
主节点真的挂了之后,这些哨兵节点中就会推举出一个leader,由这个leader负责从现有的从节点中,挑选一个座位新的主节点。
挑选出新的主节点之后,哨兵节点就会自动控制该被选中的节点,执行slaveof no one,并且控制其他从节点,修他们的主节点对象,通过slaveof改到新的主节点上。
哨兵节点会自动通知客户端程序,告知新的主节点是谁,并且后续客户端再进行写操作时,就会针对新的主节点进行操作了。
三.使用docker搭建环境
按理来说肯定要将这些单独的redis-sentinel放在不同的服务器主机上,但是吃拼好饭的我,怎么敢奢求多个云服务器呢,所以只能在一个云服务器上搞几个哨兵了,呜呜呜。在实际工作中是不会这样做的,因为是没有意义的。所以此时使用docker来解决这个问题。
1.安装docker-compose
安装docker-compose只需要一个命令:apt install docker-compose(Ubantu环境),成功后输入docker-compose会出现下面的一些列options:
2.安装docker
询问AI获取命令,出现的问题也可以直接问AI就能够解决,或者在网上去查询一下基本上都能够解决这些问题,详细的就不再赘述了。:
3.停止之前的redis服务器
通过kill来杀死从节点的redis服务器,通过service redis-server stop的命令关闭主节点的服务器
4.使用docker获取到redis的镜像
可能此时拉不下来需要在配置文件中修改一下,首先通过vim /etc/docker/daemon.json进入docker的配置文件:
使用命令docker pull redis:5.0.9获取redis的镜像:
5.使用docker-compose进行容器编排
通过一个配置文件(yml),把具体要创建那些容器,每个容器的各种参数,描述清楚。后续通过一个简单的命令,就能够批量的启动/停止这些容器了。
创建三个容器,作为redis的数据点(一个主节点两个从节点) yml配置文件
创建三个容器,作为redis的哨兵节点 yml配置文件
其实也可以通过一个yml文件直接启动6个容器,如果把这6个容器同时启动,可能是哨兵先启动完成,数据节点后启动完成,哨兵可能就会认为是数据节点挂了,虽然对于大局不影响,但是会影响到观察执行日志的过程。
创建目录
打开yml文件
写配件文件
启动数据节点:
搞哨兵节点
先计入redis-sentinel的目录中,在进行vim docker-compose.yml,然后进行配置文件的书写:
此处还需要创建 sentinel1.conf sentinel2.conf sentinel3.conf 。三份文件的内容是完全相同的配置文件:
此时进行复制两份就行了:
再通过命令docker-compose up -d启动:
但是此时通过命令docker-compose logs看到有错误出现:
这是因为docker-compose一下启动了N个容器,此时N个容器都处于同一个局域网当中,就可以使这N个容器之间可以互相访问。但是,这N个容器是一起启动的所以会在一个局域网中,如果想刚才是分别启动的N个容器,则不会在同一个局域网中,则无法互通。
此时通过docker-compose把此处两组服务器给放到同一个局域网当中,在使用docker network ls列出当前docker中的局域网。
此时应该将后面创建的3个哨兵节点加入到上面数据节点的局域网当中,而不是创建新的局域网,此时就需要回到哨兵节点的目录去增加一些配置文件信息:
修改好配置文件后需要重新启动docker:
其中sentinel1.conf的配置文件也被自动给改写了:
四.哨兵节点作用演示
哨兵节点存在的意义就是为了redis主从结构出现问题时(主节点挂了),此时哨兵节点能够自动的帮我们重新选择出一个主节点,来替代之前挂了的节点,保证整个redis仍然是 可以用的状态。
1.先停止主节点
sdown:主观下线,这个哨兵节点认为该主节点挂了。
odown:客观下线,几个哨兵都认为该节点挂了,是通过法定票数决定的也就是(quorum 3/2),此时主节点挂了这件事儿就是真实的。
此时就需要哨兵选出一个从节点作为新的主节点(redis-master的IP地址就发生了改变)
2.主节点停止后的情况
主节点停止后,此时原来从节点的6380成为了现在新的主节点了(要进入redis的客户端,需要在docker原来创建的目录下才能进去)
3.启动之前关闭的主节点
使用docker start redis-master的命令启动之前关闭的主节点:
此时进入之前主节点的客户端,查看它的详细信息,就看到它现在已经是从节点,不再是主节点了。
新的主节点6380的从节点此时就有两个了:
五.哨兵重选主节点流程
1.主观下线
哨兵节点通过心跳包判定redis服务器是否正常工作,如果心跳包没有如约而至,就说明redis服务器挂了,此时还不能排除网络波动的影响,因此只能单方面认为这个redis 节点挂了。
2.客观下线
多个哨兵都认为主节点挂了(认为挂了的哨兵节点数目达到了法定票数)哨兵们就认为这个主节点是客观下线的。当然也可能存在非常严重的网络波动导致所有的哨兵都联系不上redis主节点,此时出现这个情况主节点基本上就无法工作了,因为用户无法连接上redis主节点的客户端了,此时也被视为挂了。
3.选举主节点
此时主节点挂了之后,需要让多个哨兵节点选择出一个leader节点出来,由这个节点负责选一个从节点作为新的主节点。
哨兵1、2、3:
1号哨兵给自己进行了投票:
2号和3号哨兵也给1号哨兵进行了投票:
此时就能够让1号哨兵成为leader(此处leader的选举类似于RabbitMQ中的主节点选举(个人理解))
4.挑选新的主节点
- 先进行比较优先级。每个redis数据节点,都会在配置文件中有一个优先级的设置(slave-priority)
- 比较offset大小,最大就胜出。offset代表从节点从主节点这边数据同步的进度,数值越大,说明主从节点的数据就越接近。
- 通过run id 来进行挑选一个。每个redis节点启动的时候都会随机生成一串数字(大小全随缘分)
此时就把新的主节点指定好之后,leader就会控制这个节点,执行slave no one 称为master,在控制其他节点执行slave of让这些其他节点以新的master作为主节了。
相关文章:
Redis的哨兵
Redis的哨兵 Sentinel 一.哨兵概念1.相关名词解释图 二.主节点恢复方式1.人工恢复主节点故障流程图2.哨兵自动恢复主节点流程 三.使用docker搭建环境1.安装docker-compose2.安装docker3.停止之前的redis服务器4.使用docker获取到redis的镜像5.使用docker-compose进行容器编排创…...
初识Redis · 简单理解Redis
目录 前言: 分布式系统 开源节流 认识Redis 负载均衡 缓存 微服务 前言: 本文只是作为Redis的一篇杂谈,简单理解一下Redis为什么要存在,以及它能做到和它不能做到的事儿,简单提及一下它对应的优势有什么&#…...
Python设计模式-抽象工厂模式
1. 什么是抽象工厂模式 抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种方式来创建一系列相关或相互依赖的对象,而无需指定它们具体的类。这种模式是所有形式的工厂模式中最为抽象和最具一般性的一种。…...
【中检在线-注册安全分析报告】
前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 1. 暴力破解密码,造成用户信息泄露 2. 短信盗刷的安全问题,影响业务及导致用户投诉 3. 带来经济损失,尤其是后付费客户,风险巨大,造…...
第16届蓝桥杯单片机模拟试题Ⅲ
试题 代码 sys.h #ifndef __SYS_H__ #define __SYS_H__#include <STC15F2K60S2.H> //sys.c extern unsigned char UI; //界面标志(0湿度界面、1参数界面、2时间界面) extern unsigned char time; //时间间隔(1s~10S) extern bit ssflag; //启动/停止标志…...
软件系统安全设计方案,信息化安全建设方案(Word原件)
1.1 总体设计 1.1.1 设计原则 1.2 物理层安全 1.2.1 机房建设安全 1.2.2 电气安全特性 1.2.3 设备安全 1.2.4 介质安全措施 1.3 网络层安全 1.3.1 网络结构安全 1.3.2 划分子网络 1.3.3 异常流量管理 1.3.4 网络安全审计 1.3.5 网络访问控制 1.3.6 完…...
UE5 尝试接入 C# 脚本方案
最近团结替代 Unity6 的事官宣了,只能唏嘘不已,顺带的也就研究了一下在 UE5 中接入 C# 的方案,也算是提前帮广大 Unity 开发者蹚一下转 UE 的路~ 当前我发现的,维护比较勤快的 UE C# 方案有2个,UnrealCSharp 和 Unrea…...
力扣hot100 81-90记录
81-90(动态规划) leetcodehot100 81: class Solution { public:int climbStairs(int n) {int p 0, q 0, count 1;for(int i 1; i < n; i){p q; q count;count p q;}return count;} };//81class Solution { public:vector<vect…...
深入解析以太坊虚拟机(EVM)架构与状态机特性
以太坊(Ethereum)作为第二代区块链平台,其不仅仅是一部分布式账本,而是一个支持智能合约与去中心化应用(DApps)的全球计算机。其核心架构中,以太坊虚拟机(Ethereum Virtual Machine&…...
MySQL---Ubuntu环境安装
1.首先我们要安装MySQL的安装包(APT 配置包) 这个是适合我的Ubuntu版本的MySQL安装包 下载安装包(MySQL APT 配置包) wget https://dev.mysql.com/get/mysql-apt-config_0.8.17-1_all.deb2.安装 APT 配置包: sudo d…...
Vue 3 中 ref 与 reactive 的对比
Vue 3 中 ref 与 reactive 的对比 Vue 3 中 ref 与 reactive 的对比一、定义和基本使用refreactive 二、响应式原理refreactive 三、适用场景refreactive 四、注意事项refreactive Vue 3 中 ref 与 reactive 的对比 在 Vue 3 中,ref 和 reactive 都是用于创建响应式…...
【数据结构 · 初阶】- 单链表
目录 一.相关指针知识点 二.链表 1.为什么学了顺序表还要学链表 2.优点 三.实现 1.链表的打印 —— 理解链表结构 (2) 物理结构图 2.链表的尾插 —— 入门 错误写法:tail ! NULL 总结: 正确代码物理图解: (2) 尾插整体代码 (思考…...
【前端】【React】useCallback的作用与使用场景总结
一、useCallback 的作用与使用场景总结 useCallback 是 React 提供的一个 Hook,用于缓存函数的引用,避免因为组件重新渲染而导致函数地址发生变化。它返回一个记忆(memoized)后的回调函数,只有当依赖项发生变化时才会…...
什么是 React Router?如何使用?
React Router 详解 1. 引言 在现代 web 开发中,单页面应用(SPA)越来越流行,React 是构建 SPA 的热门库之一。React Router 是一个标准的路由库,专为 React 应用设计,允许开发者在应用中实现动态路由和 UR…...
jQuery 插件
在现代Web开发中,jQuery以其简洁的语法和强大的功能成为了前端开发者们喜爱的工具之一。为了进一步扩展jQuery的功能,社区贡献了大量的插件,使得开发者能够更加高效地实现各种复杂的交互效果和功能。本文将介绍什么是jQuery插件、如何编写自己…...
未来杭州:科技与茶香交织的生态诗篇
故事背景 故事发生在中国浙江杭州,融合智能科技与传统茶文化,描绘未来城市中人与自然共生的诗意画卷。通过六个充满未来感的生态场景,展现科技如何重塑龙井茶园、古运河、西湖等经典地标,编织出一曲科技与人文共鸣的生态交响诗。 …...
微服务多模块构建feign项目过程与一些报错(2025详细版)
目录 1.eureka-server的注意事项 2.eureka-feign的注意事项 3.多模块构建feign项目过程 3.1创建父项目 3.2创建子项目eureka-server 3.3创建子项目eureka-provider 3.4创建子项目eureka-feign 3.5运行 给个点赞谢谢 1.eureka-server的注意事项 eureka-server的yml文件…...
AWS云安全实践:基于CISA关键措施的检测与实施指南
1. 引言 随着越来越多的组织将其基础设施迁移到云端,确保AWS环境的安全变得至关重要。美国网络安全与基础设施安全局(CISA)提出的关键措施为我们提供了一个可靠的框架。本文将探讨如何在AWS环境中实施这些措施,特别关注检测类别和可实施的关键措施。 2. AWS云安全中的CISA关…...
超越肉眼所见:一种利用视网膜光学相干断层扫描血管成像(OCTA)图像进行早期痴呆检测的关联模型|文献速递-深度学习医疗AI最新文献
Title 题目 Beyond the eye: A relational model for early dementia detection using retinal OCTA images 超越肉眼所见:一种利用视网膜光学相干断层扫描血管成像(OCTA)图像进行早期痴呆检测的关联模型 01 文献速递介绍 阿尔茨海默病&…...
终端使用python出现segmentation fault (core dumped)的一种解法
有时候在终端输入python,希望交互式运行命令或者通过pdb调试,但是出现如下错误: [1] 7476 segmentation fault (core dumped) python 但是单独运行python xxx.py 或者 python -c "xxx" 又是可以的! 经过与AI大模…...
分布式id生成算法(雪花算法 VS 步长id生成)
分布式ID生成方案详解:雪花算法 vs 步长ID 一、核心需求 全局唯一性:集群中绝不重复有序性:有利于数据库索引性能高可用:每秒至少生成数万ID低延迟:生成耗时<1ms二、雪花算法(Snowflake) 1. 数据结构(64位) 0 | 0000000000 0000000000 0000000000 0000000000 0 |…...
h265为什么没有大范围应用
H.265(也称为 HEVC,High Efficiency Video Coding)是一种视频压缩标准,旨在提供比 H.264(AVC)更高的压缩效率。然而,尽管 H.265 在技术上具有许多优势,但其大范围应用受到了以下几个…...
Linux图形化界面
一、Linux图形化界面 桌面对于Linux系统来说,只是一个应用程序,所以是可以移植的。 Linaro公司针对于半导体厂商推出的芯片,开发了ARM开发工具、Linux内核以及Linux发行版(包括Android及Ubuntu)。 所以无需自己移植&am…...
LangChain-检索系统 (Retrieval)
检索系统 (Retrieval) 检索系统是LangChain的核心组件之一,它提供了从各种数据源获取相关信息的能力,是构建知识增强型应用的基础。本文档详细介绍LangChain检索系统的组件、工作原理和最佳实践。 概述 检索系统解决了大型语言模型知识有限和过时的问…...
【Linux】进程概念
目录 一、进程概念 (一)什么是进程 (二)描述进程-PCB 二、fork创建进程 (一)bash概念 (二)如何创建子进程 一、进程概念 (一)什么是进程 结论&#x…...
【JavaScript】十七、事件委托(冒泡阶段的利用)
文章目录 1、事件委托2、tab栏切换案例:使用事件委托优化3、阻止元素默认行为 1、事件委托 以送快递为例,某班有20名同学,每人有一个快递,快递员可以一个个送,需要送40次,很繁琐,换个方式&…...
Android InstalldNativeService::getAppSize源码分析
InstalldNativeService::getAppSize 是 Android 系统中用于计算应用程序存储空间的核心方法,其逻辑可分为以下几个关键模块(结合代码和上下文分析): 一、基础校验与初始化 1. 权限校验 通过 ENFORCE_UID(AID_SYSTEM) 确…...
微信小程序跳
/** * 画布文本换行绘制 * canvasContext 画布实例 * text 要写入的文本 * x 初始x轴位置 * y 初始y轴位置 * ySpacing 换行后,每行直接的间隔 * maxWidth 此文本写入画布的最大宽度,超过此宽度就换行 * color 文本颜色 * size 文本字体大小 * align 文本…...
openlayers入门01 -- 环境配置和初始化地图
openlayers入门 openlayers开发环境配置 1.下载VSCode 官网地址:https://code.visualstudio.com/ 点击Download for Windows 2.安装汉化插件和openlayers插件 搜索chinese,下载Chinese (Simplified) (简体中文) Language Pack 更改语言并重启 搜…...
window实现多jdk共存、便捷切换
背景 如今大模型技术流行,想要跟上发展就也得学一学,比如Spring-AI等框架,但这些AI相关的框架对jdk版本都有要求,一般都要不低于17。 而在企业开发中,很多时候还使用着jdk8,如何重新安装17,则需…...
常见的 set 选项与空变量检查
在编写 Bash 脚本时,使用 set 命令中的一些选项可以帮助我们在脚本执行过程中及时捕获错误和潜在问题,避免脚本在出错时继续执行,提高脚本的可靠性和健壮性。 set -e:遇到错误就停 set -e 的作用是:一旦脚本中的某个…...
JS 创建对象方法
创建对象的三种方法 3 通过构造函数 自定义构造函数 构造函数 快速定义多个对象 自定义构造函数...
IMX6ULL2025年最新部署方案:最新的UBootLinux和Rootfs部署正点原子Alpha开发板指南
正点原子Alpha IMX6ULL开发板2025年最新部署方案:基于Ubuntu24.04平台开发,部署最新的UBoot/Linux和BusyBox Rootfs部署指南 前言 笔者实在绷不住比较旧的方案了,广义流行的方案是使用2016年发布的Uboot来引导Linux4.1.15,配…...
threeJs实现裸眼3D小狗
一、实现效果 使用threeJs实现裸眼3D小狗,效果如下,其实如果将小狗换成建模小狗,效果更好,这个是模拟了一只小狗。 二、实现代码 代码如下: <!DOCTYPE html> <html> <head><title>星空小狗…...
ZYNQ笔记(二):MIO 、EMIO
版本:Vivado2020.2(Vitis) 任务:使用GPIO MIO 和 EMIO 实现按键 KEY 控制 LED( 两个PL端LED、两个PS端KEY) 目录 一、MIO 、EMIO 介绍 二、硬件设计 三、软件设计 四、效果 一、MIO 、EMIO 介绍 …...
Cygwin编译安装Acise
本文记录Windows下使用Cygwin编译安装Acise的流程。 零、环境 操作系统Windows11Visual Studio CodeVisual Studio Code 1.92.0Cygwin 一、工具及依赖 1.1 Visual Studio Code 下载并安装Visual Studio Code, 同时安装以下插件, Task Explorer Output Colorizer …...
ubuntu22.04 安装-ODBC驱动-SQLserver
1.ISO下载 中科大 Index of /ubuntu-releases/http://mirrors.ustc.edu.cn/ubuntu-releases/ 2.VMware Workstation创建虚拟机 3.更换清华源或者中科大的源 Ubuntu 24.04更换清华源_哔哩哔哩_bilibili 中科大镜像源: Ubuntu - USTC Mirror Help 清华源 ubuntu | 镜…...
[数据结构]Trie字典树
GPT的介绍 🧠 一句话总结: 字典树是一种专门用来存很多字符串的“超级前缀树”,查找某个字符串或前缀的时候,特别快! ✍️ 举个生活例子(类比): 你想做一个词典(Dictio…...
【网络安全】Linux 命令大全
未经许可,不得转载。 文章目录 前言正文文件管理文档编辑文件传输磁盘管理磁盘维护网络通讯系统管理系统设置备份压缩设备管理其它命令前言 在网络安全工作中,熟练掌握 Linux 系统中的常用命令对于日常运维、日志分析和安全排查等任务至关重要。 以下是常用命令的整理汇总,…...
Xcode警报“Ignoring duplicate libraries: ‘-lc++’” 警报
目录 前言 一、问题出现的原因 二、解决步骤 1. 检查构建设置中的链接器标志 2. 检查依赖中的重复库 3. 清除派生数据: 4. 检查冲突的 C 库 5. 更新 CocoaPods: 前言 有时候我们会看到Xcode警报:Ignoring duplicate libraries: ‘-lc…...
WebStorm中使用live-server插件
文章目录 1. 前提条件1.1 已安装Node1.1.1 淘宝的镜像1.2 安装live-server1.3 安装WebStorm2. Windows配置hosts3. WebStorm配置live-server3.1 WebStorm创建3.2 启动 live-server1. 前提条件 1.1 已安装Node Windows PowerShell 版权所有(C) Microsoft Corporation。保留所…...
Python 中使用单例模式
有这么一种场景,Web服务中有一个全局资源池,在需要使用的地方就自然而言引用该全局资源池即可,此时可以将该资源池以单例模式实现。随后,需要为某一特殊业务场景专门准备一个全局资源池,于是额外复制一份代码新建了一个…...
【基于LangChain的千问大模型工具调用】 Function CallingTool Calling简易示例
目录 示例代码 运行结果 功能:根据用户输入自动选择数学计算/天气查询工具处理 "用户输入 → 意图分析 → 工具调用 → 结果返回" 库名解析:【langchain库名解析】-CSDN博客 示例代码 # 模块1:依赖导入 from langc…...
银河麒麟服务器操作系统 V10 SP1 中玩转firewalld防火墙
Hey小伙伴们~👋 今天来聊聊怎么在银河麒麟服务器操作系统 V10 SP1 中玩转firewalld防火墙!🛡️ 这个强大的工具能帮你动态管理防火墙规则,还支持区域概念,让你的网络流量控制更灵活!🎉 &#x…...
信创服务器网络更稳了!链路聚合Bonding实战
原文链接:信创服务器网络更稳了!链路聚合Bonding实战 Hello,大家好啊!今天给大家带来一篇信创服务器操作系统上链路聚合(Bonding)配置实战的文章。链路聚合可以让两块网卡协同工作,提高服务器网…...
沐渥科技详解氮气柜操作指南
氮气柜是一种通过持续注入高纯度氮气,维持柜内惰性气体环境的设备,用于存储半导体晶圆或其他敏感元件,防止氧化、吸湿和污染。氮气柜操作指南是怎样的?下面沐渥小编给大家介绍一下。 一、操作前准备 (1)安全…...
Netty之ChannelOutboundBuffer详解与实战
深入理解Netty的高低水位线机制及其应用实践 在高性能网络编程中,Netty作为一个广泛使用的异步事件驱动的Java框架,其高效的流量控制机制对于系统的稳定性和性能至关重要。本文将深入探讨Netty中的高低水位线(High/Low Water Mark࿰…...
学习Python的优势体现在哪些方面?
文章目录 前言易于学习和使用应用领域广泛丰富的开源库和社区支持跨平台兼容性职业发展前景好 前言 学习 Python 具有多方面的优势,这使得它成为当今最受欢迎的编程语言之一,以下为你详细介绍。 易于学习和使用 语法简洁易懂:Python 的语法…...
每天五分钟玩转深度学习PyTorch:搭建LSTM算法模型完成词性标注
本文重点 本文通过LSTM算法模型来解决一个实际问题,也就是如何使用LSTM完成词性预测,下面我们搭建两个模型,一个是单词级别的,另外一个是字母级别的,大概的步骤就是,字母级别的LSTM将每个单词的字母作为输入,然后取最后一个时刻作为整个单词的表示,然后将文本中所有的…...
ANP协议深度解析:智能体网络协议的演进与革新
引言 随着人工智能(AI)技术的快速发展,多智能体系统(Multi-Agent Systems, MAS)逐渐成为解决复杂问题的核心范式。然而,智能体之间的高效协作一直面临通信标准不统一、资源分配冲突、动态环境适应能力不足等…...