【分布式系统中的“瑞士军刀”_ Zookeeper】二、Zookeeper 核心功能深度剖析与技术实现细节
在分布式系统的复杂生态中,Zookeeper 凭借其强大的核心功能,成为保障系统稳定运行的关键组件。上篇文章我们了解了 Zookeeper 的基础概念与安装配置,本文将继续深入剖析 Zookeeper 的核心功能,包括分布式锁、配置管理、命名服务和集群管理等。带你掌握这些功能的技术实现细节。
一、分布式锁
1.1 实现原理
Zookeeper 实现分布式锁的核心逻辑基于 ZNode 的特性。多个客户端竞争同一资源锁时,会在指定的 ZNode 路径下创建临时顺序节点。例如,创建路径为/lock/resource-的临时顺序节点,第一个客户端创建的节点可能是/lock/resource-0000000001,第二个客户端创建的是/lock/resource-0000000002,以此类推。序号最小的节点代表获取到锁,其他节点则监听比自己序号小的前一个节点。当持有锁的节点释放(会话结束,临时节点自动删除),下一个序号最小的节点监听到事件后,即可获取锁,从而实现分布式环境下的资源互斥访问。
1.2 配置与操作
在 CentOS 7 系统中,确保 Zookeeper 已正确安装并启动。通过 Zookeeper 命令行工具zkCli.sh连接到 Zookeeper 服务器:
/usr/local/zookeeper/bin/zkCli.sh -server localhost:2181
假设我们要实现对某个共享资源的锁定,首先创建锁的根节点(持久节点):
create /lock ""
模拟两个客户端竞争锁,客户端 1 创建临时顺序节点:
create -e -s /lock/resource- ""
执行后,可能得到类似/lock/resource-0000000001的节点路径,此时客户端 1 获取到锁。客户端 2 同样创建临时顺序节点:
create -e -s /lock/resource- ""
得到如/lock/resource-0000000002的节点路径,客户端 2 需监听/lock/resource-0000000001节点。使用ls -w命令设置监听:
ls -w /lock
当客户端 1 完成操作,会话结束,其创建的临时顺序节点自动删除,客户端 2 监听到事件后,检查自己的节点是否为序号最小的节点,若是则获取锁。
1.3 代码示例
以下是使用 Java 实现的简单分布式锁代码:
import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;import java.io.IOException;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.CountDownLatch;public class ZookeeperDistributedLock implements Watcher {private static final String ZOOKEEPER_SERVER = "localhost:2181";private static final String LOCK_ROOT = "/lock";private static final String LOCK_NODE_PREFIX = "/resource-";private ZooKeeper zk;private String currentNode;private String waitNode;private CountDownLatch latch = new CountDownLatch(1);public ZookeeperDistributedLock() throws IOException, KeeperException, InterruptedException {zk = new ZooKeeper(ZOOKEEPER_SERVER, 5000, this);Stat stat = zk.exists(LOCK_ROOT, false);if (stat == null) {zk.create(LOCK_ROOT, new byte[0], ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);}currentNode = zk.create(LOCK_ROOT + LOCK_NODE_PREFIX, new byte[0], ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);System.out.println("Created node: " + currentNode);List<String> children = zk.getChildren(LOCK_ROOT, true);Collections.sort(children);if (currentNode.equals(LOCK_ROOT + "/" + children.get(0))) {latch.countDown();} else {int index = children.indexOf(currentNode.substring(LOCK_ROOT.length() + 1));waitNode = LOCK_ROOT + "/" + children.get(index - 1);zk.getData(waitNode, true, null);}}@Overridepublic void process(WatchedEvent event) {if (event.getType() == Event.EventType.NodeDeleted && event.getPath().equals(waitNode)) {latch.countDown();}}public void lock() throws InterruptedException {latch.await();}public void unlock() throws KeeperException, InterruptedException {zk.delete(currentNode, -1);zk.close();}public static void main(String[] args) throws IOException, KeeperException, InterruptedException {ZookeeperDistributedLock lock = new ZookeeperDistributedLock();System.out.println("Trying to acquire lock...");lock.lock();System.out.println("Lock acquired, performing operations...");// 模拟业务操作Thread.sleep(3000);System.out.println("Operations completed, releasing lock...");lock.unlock();}
}
二、配置管理
2.1 功能原理
在分布式系统中,众多节点需要统一管理配置信息。Zookeeper 通过将配置存储在 ZNode 节点中,利用 Watcher 机制实现配置的动态更新。当配置信息对应的 ZNode 数据发生变化时,Zookeeper 会通知所有监听该节点的客户端,客户端接收到通知后重新加载配置,从而保证各个节点使用的是最新配置。
2.2 配置与操作
在 CentOS 7 中,启动 Zookeeper 服务后,通过zkCli.sh连接服务器。创建配置存储节点,例如存储数据库连接配置:
create /config/db ""
设置数据库连接配置数据:
set /config/db "jdbc:mysql://localhost:3306/mydb?user=root&password=123456"
客户端可使用get -w命令监听配置节点:
get -w /config/db
当配置需要更新时,修改节点数据:
set /config/db "jdbc:mysql://localhost:3306/newdb?user=admin&password=654321"
监听该节点的客户端将收到配置更新通知并重新加载配置。
2.3 代码示例
以下是 Java 客户端监听配置更新的代码:
import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;import java.io.IOException;public class ZookeeperConfigListener implements Watcher {private static final String ZOOKEEPER_SERVER = "localhost:2181";private static final String CONFIG_NODE = "/config/db";private ZooKeeper zk;public ZookeeperConfigListener() throws IOException {zk = new ZooKeeper(ZOOKEEPER_SERVER, 5000, this);}public void listen() throws KeeperException, InterruptedException {while (true) {Stat stat = new Stat();byte[] data = zk.getData(CONFIG_NODE, true, stat);System.out.println("Current config: " + new String(data));Thread.sleep(1000);}}@Overridepublic void process(WatchedEvent event) {if (event.getType() == Event.EventType.NodeDataChanged && event.getPath().equals(CONFIG_NODE)) {try {System.out.println("Config updated, reloading...");byte[] data = zk.getData(CONFIG_NODE, true, null);System.out.println("New config: " + new String(data));} catch (KeeperException | InterruptedException e) {e.printStackTrace();}}}public static void main(String[] args) throws IOException, KeeperException, InterruptedException {ZookeeperConfigListener listener = new ZookeeperConfigListener();listener.listen();}
}
三、命名服务
3.1 实现原理
Zookeeper 的命名服务通过树形结构的 ZNode 节点,实现服务实例的注册与发现。服务提供者启动时,将自身的服务信息(如服务地址、端口、接口等)以节点数据的形式注册到 Zookeeper 的指定路径下。服务消费者在需要调用服务时,从 Zookeeper 中查询对应服务的节点路径,获取可用的服务实例地址,进而实现服务调用。同时,利用 Watcher 机制,当服务实例的状态发生变化(如新增、下线)时,服务消费者能及时感知并更新可用服务列表。
3.2 配置与操作
假设存在一个用户服务,服务提供者在 CentOS 7 系统中启动后,通过zkCli.sh连接 Zookeeper,注册服务实例:
create /services/user-service/instance1 "192.168.1.100:8080"
服务消费者查询服务实例:
ls /services/user-service
获取到服务实例列表后,可进一步获取实例详细信息:
get /services/user-service/instance1
并使用ls -w监听服务实例变化:
ls -w /services/user-service
3.3 代码示例
以下是服务提供者注册服务和服务消费者发现服务的 Java 代码:
服务提供者
import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;import java.io.IOException;public class ZookeeperServiceProvider {private static final String ZOOKEEPER_SERVER = "localhost:2181";private static final String SERVICE_ROOT = "/services/user-service";private static final String INSTANCE_NAME = "instance1";private static final String SERVICE_ADDRESS = "192.168.1.100:8080";private ZooKeeper zk;public ZookeeperServiceProvider() throws IOException, KeeperException, InterruptedException {zk = new ZooKeeper(ZOOKEEPER_SERVER, 5000, watchedEvent -> {});Stat stat = zk.exists(SERVICE_ROOT, false);if (stat == null) {zk.create(SERVICE_ROOT, new byte[0], ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);}zk.create(SERVICE_ROOT + "/" + INSTANCE_NAME, SERVICE_ADDRESS.getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL);}public static void main(String[] args) throws IOException, KeeperException, InterruptedException {new ZookeeperServiceProvider();System.out.println("Service registered successfully");Thread.sleep(Long.MAX_VALUE);}
}
服务消费者
import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;import java.io.IOException;
import java.util.List;public class ZookeeperServiceConsumer implements Watcher {private static final String ZOOKEEPER_SERVER = "localhost:2181";private static final String SERVICE_ROOT = "/services/user-service";private ZooKeeper zk;public ZookeeperServiceConsumer() throws IOException {zk = new ZooKeeper(ZOOKEEPER_SERVER, 5000, this);}public void discoverService() throws KeeperException, InterruptedException {while (true) {List<String> children = zk.getChildren(SERVICE_ROOT, true);for (String child : children) {Stat stat = new Stat();byte[] data = zk.getData(SERVICE_ROOT + "/" + child, false, stat);System.out.println("Available service instance: " + new String(data));}Thread.sleep(1000);}}@Overridepublic void process(WatchedEvent event) {if (event.getType() == Event.EventType.NodeChildrenChanged && event.getPath().equals(SERVICE_ROOT)) {try {System.out.println("Service instances changed, re-discovering...");discoverService();} catch (KeeperException | InterruptedException e) {e.printStackTrace();}}}public static void main(String[] args) throws IOException, KeeperException, InterruptedException {ZookeeperServiceConsumer consumer = new ZookeeperServiceConsumer();consumer.discoverService();}
}
四、集群管理与协调
4.1 实现原理
Zookeeper 集群采用 Leader - Follower 模式进行管理与协调。集群启动时,通过选举算法(如 FastLeaderElection)选出一个 Leader 节点,其他节点作为 Follower。Leader 负责处理写请求,并将数据变更同步到 Follower;Follower 处理读请求并从 Leader 同步数据。当 Leader 节点故障时,集群会重新选举产生新的 Leader,保证系统的正常运行。选举过程基于节点的 ZXID(事务 ID)和节点 ID,确保拥有最新数据的节点成为 Leader。
4.2 配置与操作
在 CentOS 7 中搭建 Zookeeper 集群,需要修改zoo.cfg配置文件。假设有三个节点,分别在不同服务器上(这里假设在同一台机器的不同端口模拟),zoo.cfg配置如下:
tickTime=2000
dataDir=/var/lib/zookeeper
clientPort=2181
initLimit=10
syncLimit=5
server.1=localhost:2888:3888
server.2=localhost:2889:3889
server.3=localhost:2890:3890
其中,server.x格式中,x为节点编号,第一个端口(如 2888)用于 Follower 与 Leader 之间的数据同步,第二个端口(如 3888)用于选举。
在每个节点的数据目录/var/lib/zookeeper下创建一个名为myid的文件,内容为该节点的编号(如节点 1 的myid文件内容为1,节点 2 为2,节点 3 为3):
echo "1" > /var/lib/zookeeper/myid
分别启动三个节点的 Zookeeper 服务:
/usr/local/zookeeper/bin/zkServer.sh start
通过zkServer.sh status命令查看节点角色:
/usr/local/zookeeper/bin/zkServer.sh status
可看到一个节点为Leader,其他为Follower。
4.3 故障模拟与恢复
模拟 Leader 节点故障,停止 Leader 节点的 Zookeeper 服务:
/usr/local/zookeeper/bin/zkServer.sh stop
一段时间后,再次使用zkServer.sh status命令查看,会发现集群重新选举出了新的 Leader,保证了集群的正常运行。
相关文章:
【分布式系统中的“瑞士军刀”_ Zookeeper】二、Zookeeper 核心功能深度剖析与技术实现细节
在分布式系统的复杂生态中,Zookeeper 凭借其强大的核心功能,成为保障系统稳定运行的关键组件。上篇文章我们了解了 Zookeeper 的基础概念与安装配置,本文将继续深入剖析 Zookeeper 的核心功能,包括分布式锁、配置管理、命名服务和…...
前端学习笔记(四)自定义组件控制自己的css
1、前言及背景 自己写的一个组件有至少3个页面在使用,组件中的部分文字颜色需要统一修改需要根据一个状态字段来显示不同颜色且不希望受父组件影响 注意:博主学习vue截止目前也就半年,如有知识错误之处还请指出不胜感激,祝学习开…...
从描述语言,非功能性需求,需求和架构的一致性三个方面,说明软件需求到架构的映射存在哪些难点
软件需求到架构的映射是软件工程中的关键环节,其难点主要体现在描述语言差异、非功能性需求的复杂性以及需求与架构的一致性维护三个方面。以下是具体分析: 1. 描述语言的差异 难点:需求与架构使用不同的抽象语言描述,导致语义鸿…...
linux blueZ 第五篇:高阶优化与性能调优——蓝牙吞吐、延迟与功耗全攻略
本篇面向已有实战经验的读者,深入探讨 Classic Bluetooth 与 BLE 在 BlueZ 平台上的性能优化和调优方法,包括连接参数、MTU 调整、PHY 选择、缓存管理、并发策略,以及 HCI 抓包、功耗测量与自动化基准测试,助你打造高吞吐、低延迟、超低功耗的蓝牙应用。 目录 为何要做性能…...
linux的例行性工作(at)
使用场景: 生活中,我们有太多场景需要使用到闹钟,比如早上 7 点起床,下午 4 点开会,晚上 8 购物,等等 在 Linux 系统里,我们同样也有类似的需求。比如我们想在凌晨 1 点将文件上传服务器&#…...
JVM考古现场(二十六):执剑人·降维打击的终极审判
楔子:二向箔的颤动——当修真文明遭遇降维打击 "警告!老年代发生维度坍缩!"我腰间悬挂的昆仑镜突然迸发幽蓝光芒,终南山巅的河图洛书大阵中,GC日志正以《奇门遁甲》的格局疯狂演化: // 降维打击…...
腾讯云物联网平台
文档:物联网开发平台 MQTT.fx 快速接入物联网开发平台_腾讯云...
Unity之基于MVC的UI框架-含案例
Unity之基于MVC的UI框架-含案例 使用案例:类《双人成行》3D动作益智冒险类双人控制游戏开发教程 资源地址:https://learn.u3d.cn/tutorial/3d-adventure-william-anna 一、MVC框架概览 本框架以MVC的方式搭建,以View视口的方式展现数据&am…...
【Token系列】01 | Token不是词:GPT如何切分语言的最小单元
文章目录 01 | Token不是词:GPT如何切分语言的最小单元?一、什么是 Token?二、Token 是怎么来的?——BPE算法原理BPE核心步骤: 三、为什么不直接用词或字符?四、Token切分的实际影响五、中文Token的特殊性六…...
C++学习之路,从0到精通的征途:List类的模拟实现
目录 一.list的介绍 二.list的接口实现 1.结点 2.list结构 3.迭代器 (1)begin (2)end 4.修改 (1)insert (2)push_back (3)push_front ࿰…...
Java大师成长计划之第4天:Java中的泛型
📢 友情提示: 本文由银河易创AI(https://ai.eaigx.com)平台gpt-4o-mini模型辅助创作完成,旨在提供灵感参考与技术分享,文中关键数据、代码与结论建议通过官方渠道验证。 在现代软件开发中,类型安…...
计算机学报 2024年 区块链论文 录用汇总 附pdf下载
计算机学报 Year:2024 1 Title: 区块链中的公钥密码:设计、分析、密评与展望 Authors: Key words: 区块链;公钥密码算法;算法设计;复杂性分析;密评 Abstract: 比特币的成功,吸引了人们研…...
【Castle-X机器人】三、紫外消杀模块安装与调试
持续更新。。。。。。。。。。。。。。。 【Castle-X机器人】紫外消杀模块安装与调试 三、紫外消杀模块安装与调试2.1 安装2.2 调试2.2.1 紫外消杀模块话题2.2.2 测试 三、紫外消杀模块安装与调试 2.1 安装 使用相应工具将紫外消杀模块固定在Castle-X机器人底盘 2.2 调试 2.2…...
精益数据分析(29/126):深入剖析电子商务商业模式
精益数据分析(29/126):深入剖析电子商务商业模式 在创业和数据分析的学习道路上,我们始终在探索如何更精准地把握商业规律,提升业务的竞争力。今天,我们依旧怀揣着共同进步的愿望,深入解读《精…...
AI图像编辑器 Luminar Neo 便携版 Win1.24.0.14794
如果你对图像编辑有兴趣,但又不想花费太多时间学习复杂的软件操作,那么 Luminar Neo 可能就是你要找的完美工具。作为一款基于AI技术的创意图像编辑器,Luminar Neo简化了复杂的编辑流程,即使是没有任何图像处理经验的新手…...
在Mybatis中为什么要同时指定扫描mapper接口和 mapper.xml 文件,理论单独扫描 xml 文件就可以啊
设计考虑因素 历史兼容性: MyBatis早期版本主要依赖XML配置,后来才引入接口绑定方式同时支持两种方式可以保证向后兼容 明确性: 显式指定两种路径可以使映射关系更加明确减少因命名不一致导致的潜在问题 性能考虑: 同时扫描可…...
MyBatis XML 配置完整示例(含所有核心配置项)
MyBatis XML 配置完整示例(含所有核心配置项) 1. 完整 mybatis-config.xml 配置文件 <?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""htt…...
【数据结构入门训练DAY-24】美国大选
文章目录 前言一、题目二、解题思路结语 前言 本次训练内容 训练STL中sort的操作方法。训练解题思维。 一、题目 美国大选是按各州的投票结果来确定最终的结果的,如果得到超过一半的州的支 持就可以当选,而每个州的投票结果又是由该州选民投票产生…...
stm32L4R5ZI Nucleo-144 GPIO点灯及按键中断
文章目录 前言一、CubeMx环境配置二、GPIO点灯操作三、按键中断点灯总结 前言 STM32L4R5ZI Nucleo-144是STMicroelectronics推出的一款基于ARM Cortex-M4内核的微控制器芯片。它是STM32L4系列中的一员,针对低功耗和高性能的应用而设计。以下是一些关键特点和技术规格…...
访问Redis时遇到 unknown command ‘FT.INFO‘, with args beginning with 错误的解决方案
在B站学习 图灵程序员-诸葛 的LangChain入门课程《基于Redis保存历史聊天信息》。在实践代码时遇到了一些问题,在这里记录一下,希望能帮助到也在学习的同学。话不多说,上代码,这段代码使用langchain_redis来持久化大模型对话的聊天…...
Swift与iOS内存管理机制深度剖析
前言 内存管理是每一位 iOS 开发者都绕不开的话题。虽然 Swift 的 ARC(自动引用计数)极大简化了开发者的工作,但只有深入理解其底层实现,才能写出高效、健壮的代码,避免各种隐蔽的内存问题。本文将从底层原理出发&…...
数据库系统概论(五)关系模型的数据结构及形式化
数据库系统概论(五)关系模型的数据结构及形式化 前言一、关系:从“表格”说起1.1 关系数据模型中的“关系”是什么?1.2 域(Domain):数据的“类型限定”1.3 笛卡尔积(Cartesian Produ…...
Python类和对象四(十三)
魔法方法: 按位运算 按位于运算 只要相同才是1 或运算: 只要某个位是1结果就是1 、 按位非 将结果取反 按位异或: 左移和右移运算符: 右移两位 右移动n位,就是除以2的n次方 左移两位: 左移n位就是乘…...
Go 1.24 中的弱指针包 weak 使用介绍
在 Go 语言中,“弱指针”指的是不会阻止垃圾回收器(GC)回收目标对象的引用。 当一个对象只剩弱指针指向它,而没有任何强引用时,GC 仍会把该对象当作不可达对象并回收;随后,所有指向它的弱指针会…...
毕业项目-基于深度学习的入侵检测系统
选题背景与意义 随着互联网技术的飞速发展,网络在各个领域中的作用日益重要。然而,伴随着技术的进步,网络安全问题也愈加严峻,网络攻击事件频繁发生,给个人、企业乃至国家带来了巨大的经济损失与安全威胁。入侵检测系…...
Github 2025-04-26 Rust开源项目日报Top10
根据Github Trendings的统计,今日(2025-04-26统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Rust项目10Dart项目1RustDesk: 用Rust编写的开源远程桌面软件 创建周期:1218 天开发语言:Rust, Dart协议类型:GNU Affero General Public Li…...
【Hive入门】Hive分桶表深度解析:从哈希分桶到Join优化的完整指南
目录 引言 1 分桶表基础概念 1.1 什么是分桶表 1.2 分桶与分区的区别 2 分桶表设计与创建 2.1 创建分桶表语法 2.2 分桶键选择原则 2.3 桶数确定策略 3 分桶表数据加载 3.1 标准数据加载流程 3.2 分桶表数据验证 4 分桶Join优化原理 4.1 Map端Join优化 4.2 Sort-…...
django之优化分页功能(利用参数共存及封装来实现)
优化分页功能 目录 1.封装分页代码 2.解决分页时覆盖搜索参数的bug 3.优化分页功能 上一篇文章我们讲到了搜索功能和分页展示数据功能。那这篇文章, 在上篇文章的基础上, 会去优化这些功能并解决搜索功能和分页功能不能一起使用的bug。 一、封装分页代码 原本我们的asse…...
linux blueZ 第四篇:BLE GATT 编程与自动化——Python 与 C/C++ 实战
本篇聚焦 BLE(Bluetooth Low Energy)GATT 协议层的编程与自动化实践,涵盖 GATT 基础、DBus API 原理、Python(dbus-next/bleak)示例、C/C++ (BlueZ GATT API)示例,以及自动发现、读写特征、订阅通知、安全配对与脚本化测试。 目录 BLE GATT 基础概念 BlueZ DBus GATT 模…...
前端面试每日三题 - Day 16
这是我为准备前端/全栈开发工程师面试整理的第16天每日三题练习,涵盖事件循环深入解析 、Vue3 响应式系统原理 ,以及 多租户系统设计实践。每道题附带 详细解析、示例代码与脑图建议,助你全面掌握底层原理与架构设计思维。 ✅ 题目 1…...
使用PyTorch实现简单图像识别(基于MNIST手写数字数据集)的完整代码示例,包含数据加载、模型定义、训练和预测全流程
以下是一个使用PyTorch实现简单图像识别(基于MNIST手写数字数据集)的完整代码示例,包含数据加载、模型定义、训练和预测全流程: import torch import torch.nn as nn import torch.optim as optim import torchvision import torc…...
【Android】四大组件之Activity
目录 一、什么是Activity 二、如何创建和配置Activity 三、Activity 跳转与数据传递 四、数据保存与恢复 五、Activity 启动模式 六、自定义返回行为 七、复杂界面布局 你可以把Activity想象成手机屏幕上的一个“页面”。比如,当你打开一个App时,…...
数据库原理(1)
第一章 概论 一、基本概念 数据(Data)是数据库中存储的基本对象,描述事物的符号记录。例如学生的学号、姓名等信息都是数据。 数据库(Database,DB)长期存储在计算机内、有组织的、可共享的大量数据的集合。…...
SQL盲注问题深度解析与防范策略
引言 在当今互联网时代,Web应用程序的安全性是重中之重。SQL注入作为一种常见且极具威胁性的攻击手段,而其中的SQL盲注更是因其隐蔽性强、难以察觉而备受关注。攻击者借助SQL盲注,在无法直接获取数据库返回结果的情况下,通过精心构造特殊的SQL语句,利用页面的不同响应来逐…...
Android JIT( ART即时编译器),Just In Time Compiler,即时编译技术
Android JIT( ART即时编译器),Just In Time Compiler,即时编译技术 Android Runtime (ART) 包含一个具备代码分析功能的即时 (JIT) 编译器,该编译器可以在 Android 应用运行时持续提高其性能。JIT是Just In Time Compiler…...
当自动驾驶遇上“安全驾校”:NVIDIA如何用技术给无人驾驶赋能?
自动驾驶技术的商业化落地,核心在于能否通过严苛的安全验证。国内的汽车企业其实也在做自动驾驶,但是吧,基本都在L2级别。换句话说就是在应急时刻内,还是需要人来辅助驾驶,AI驾驶只是决策层,并不能完全掌握…...
Unity中数据储存
在Unity项目开发中,会有很多数据,有需要保存到本地的数据,也有直接保存在缓存中的临时数据,一般为了方便整个项目框架中各个地方能调用需要的数据,因此都会实现一个数据工具或者叫数据管理类,用来管理项目中所有的数据。 首先保存在缓存中的数据,比如用户信息,我们只需…...
【C++11】可变参数模板
前言: 上文我们学到右值引用及其移动语义,学习到了C11中对性能提升对重要的更新之一。C11进阶之路:右值引用和移动语义,让代码跑得更快!-CSDN博客 本文我们来讲讲,C11的下一个新语法:可变参数模…...
c语言知识整理
一 数据的存储 对于整形的存储 无论是正负在存储中都是使用补码进行存储的 那个一个数字的补码在转换正负时不同的 对于存储中 首位一定是符号位 如果是0 那么是正数 如果是1 那么是负数 (32位 除符号位 缺少的位数使用0补齐) 如果是正数 …...
算法习题-力扣446周赛题解
算法可以调度思维,让程序员的思维发散,找到更好的解决方案。 第一题:执行指令后的得分 题目: 给你两个数组:instructions 和 values,数组的长度均为 n。你需要根据以下规则模拟一个过程: 从下标…...
基于共享上下文和自主协作的 RD Agent 生态系统
在llmangentmcp这个框架中: LLM: 依然是智能体的“大脑”,赋予它们理解、推理、生成和规划的能力,并且也用于处理和利用共享上下文。Agent: 具备特定 R&D 职能的自主单元,它们感知共享上下文࿰…...
Operating System 实验五 进程管理编程实验
实验目标: 写个多线程的程序,重现竞争条件,并通过信号量或者互斥量,解决临界区问题某工厂有两个生产车间和一个装配车间,两个生产车间分别生产A、B两种零件,装配车间的任务是把A、B两种零件组装成产品。两个生产车间每生产一个零件后,都要分别把它们送到装配车间的货架F…...
Deep Reinforcement learning for real autonomous mobile robot navigation
https://www.youtube.com/watch?vKyA2uTIQfxw AI Learns to Park - Deep Reinforcement Learning https://www.youtube.com/watch?vVMp6pq6_QjI Q Learning simply explained | SARSA and Q-Learning Explanation https://www.youtube.com/watch?vMI8ByADM…...
计算机网络 | 应用层(4)--DNS:因特网的目录服务
💓个人主页:mooridy-CSDN博客 💓文章专栏:《计算机网络:自定向下方法》 大纲式阅读笔记_mooridy的博客-CSDN博客 🌹关注我,和我一起学习更多计算机网络的知识 🔝🔝 目录 …...
WPF核心技术解析与使用示例
WPF核心技术解析与使用示例 一、依赖属性(Dependency Property)详解 1. 依赖属性基础 核心概念: 依赖属性是WPF实现数据绑定、样式、动画等特性的基础通过属性系统实现高效的内存管理和值继承标准定义模式: public class MyControl : Control {// 1. 定义…...
JVM运行机制全景图:从源码到执行的全过程
JVM运行机制全景图:从源码到执行的全过程 引言:你真的了解 Java 是怎么跑起来的吗? 许多开发者写完 Java 代码之后,就交给编译器和运行时去“神奇”地执行了。但你有没有想过,一段 .java 文件是如何一步步变成可运行的程序?今天,我们就从 源码 ➝ 字节码 ➝ 类加载 ➝…...
使用 AFL++ 对 IoT 二进制文件进行模糊测试 - 第二部分
在上一部分中,我们研究了如何使用 AFL++ 对简单的物联网二进制文件进行模糊测试。这些程序接受来自文件的输入,并且易于模糊测试。 在本文中,我们将研究套接字二进制文件。使用套接字进行网络通信的模糊测试二进制文件与使用基于文件 I/O 的模糊测试二进制文件不同。Vanill…...
在华为云平台上使用 MQTT 协议:构建高效可靠的物联网通信
🌐 在华为云平台上使用 MQTT 协议:构建高效可靠的物联网通信 随着物联网(IoT)技术的发展,设备间的高效通信变得尤为重要。MQTT(Message Queuing Telemetry Transport)作为一种轻量级的消息传输…...
基于STM32的物流搬运机器人
功能:智能循迹、定距夹取、颜色切换、自动跟随、自动避障、声音夹取、蓝牙遥控、手柄遥控、颜色识别夹取、循迹避障、循迹定距…… 包含内容:完整源码、使用手册、原理图、视频演示、PPT、论文参考、其余资料 资料只私聊...
H.264/AVC标准主流开源编解码器编译说明
An artisan must first sharpen his tools if he is to do his work well. 工欲善其事,必先利其器. 前言 想研究和学习H.264/AVC视频编解码标准的入门的伙伴们,不论是学术研究还是工程应用都离不开对源码的分析,因此首要工作是对各类编解码器进行编译,本文针对主流的一些符…...