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

【从零开始一步步学习VSOA开发】 概述

概述

概念

VSOA(Vehicle SOA)是翼辉为了解决任务关键型系统不能适用当前微服务通信架构问题而设计的⼀个轻量级适用于任务关键领域的微服务通信架构,以方便开发者构建大型分布式松耦合软件系统,且支持并行开发。

特点

其主要特点为支持多种编程语言、多 CPU 架构环境与多操作系统平台,同时不依赖任何第三方库,架构简洁、资源占用小、服务响应速度快,具有开发成本低、开发效率高等特点。考虑到任务关键型场景的多样性和碎片化特点,VSOA 汇集订阅/发布、RPC、高带宽数据流以及自定义数据报等功能于一体,可满足任何分布式应用模型;同时提供非入侵式仿真测试工具与便捷的开发环境,让开发者在享受云计算先进的开发体验以及高效的生产效率的同时,继续保持任务关键领域对业务功能和性能的高可靠需求。

  • 支持订阅和发布模型
  • 支持实时 RPC 调用
  • 支持并行多命令序列
  • 支持可靠与快速数据发布与数据报
  • 支持多路全双工高速并行数据流
  • 支持网络 QoS 控制
  • 支持统⼀的 URL 资源标识
  • 支持域名管理与位置服务
  • 轻松实现服务器容错设计
  • 支持多种编程语言、操作系统和 CPU 体系
  • 支持 IPv4/IPv6 双栈
  • 支持标准编程范式,便于模型化开发
  • 便于实现冗余健壮性设计
  • 支持非入侵式仿真和测试

角色组成

在 VSOA 框架中,存在如下三个角色:
服务端: 指服务的提供者,向外提供资源。
客户端: 指业务的使用者,使用服务端的资源。
位置服务: 与 DNS 类似,客户端无需知道服务提供方实际的网络地址即可与其建立连接。
在这里插入图片描述

教学简化

VSOA(Vehicle SOA)是翼辉面向 “ 任务关键型云原生架构 ” 推出的系列产品之一。鉴于 VSOA 相关开发编程语言、开发操作系统、运行操作系统、运行处理器体系结构多样更设计云原生诸多概念和工具,组合逻辑复杂,为降低初学者理解实操难度,本系列教程只选择一种组合进行讲解,尽量减少非关键信息的说明。

如下是 VSOA 相关技术列表,初略估计可以有 96 种组合,后面只选择C 语言+开发Windows+运行SylixOS+运行amd64这最常见的一种进行讲解。

开发编程语言开发操作系统环境运行操作系统环境运行处理器体系结构
C/C++WindowsSylixOSamd64
JavaScriptLinux Debian 系Linux Debian 系i386
GolangWindowsarm
Java
aarch64

官方教程都是在云原生的体系下降 VSOA 的,涉及很多容器,容器管理,JavaScript、 Golang等内容,但 VOSA 其实是能在普通 SylixOS 下运行的,而不限定于容器中,所以后面只在最简单环境和依赖下讲解 VSOA,进一步专注于 VSOA 本身的学习和演示。

相关文章:

【从零开始一步步学习VSOA开发】 概述

概述 概念 VSOA(Vehicle SOA)是翼辉为了解决任务关键型系统不能适用当前微服务通信架构问题而设计的⼀个轻量级适用于任务关键领域的微服务通信架构,以方便开发者构建大型分布式松耦合软件系统,且支持并行开发。 特点 其主要特…...

小程序背景图片无法通过 WXSS 获取

问题:pages/index/index.wxss 中的本地资源图片无法通过 WXSS 获取 可以使用网络图片,或者 base64,或者使用标签。 将图片转换为base64,地址 base64图片在线转换工具 - 站长工具 在这里把要使用的图片转换一把,然后将得…...

CC++内存魔术:掌控无形资源

hello,uu们,今天呢我们来详细讲解C&C的内存管理,好啦,废话不多讲,开干 1:C/C内存分布 2:C语言中动态内存管理方式:malloc/calloc/realloc/free 3:C内存管理方式 3.1:new/delete操作内置类型 3.1.1:代码1 3.1.2:代码2 3.2:new和delete操作自定义类型 3.2.1:C语言创建…...

算法--初阶

1、tips 1.1、set求交集 {1,2,3} & {2,3} & {1,2} {2} 其实就是位运算, 只有set可以这样使用, list没有这种用法 {1,2,3} | {2,3, 4} | {1,2} {1, 2, 3, 4} 并集 1.2、*与** * 序列(列表、元组)解包,如果是字典,那…...

通过Java实现插入排序(直接插入,希尔)与选择排序(直接选择,堆排)

目录 (一)插入排序 1.直接插入排序 (1)核心思想: (2)代码实现(以从小到大排序为例): (3)代码分析: 2.希尔排序&#xff08…...

大型分布式B2B2C多用户商城7.0企业版源码分享【java语言、方便二次开发】

项目介绍 项目基于SpringBoot开发,运营端和商户端采用ElementVue,买家使用采用VueIviewnuxt服务端渲染。使用到的中间件有Redis、RabbitMQ、ElasticSearch、FastDFS、Mongodb等。主要功能包括有运营管理、商品管理、订单管理、售后管理、会员管理、财务…...

C++的结构体、联合体、枚举类型(一)

1.C++的结构体 2.C++的联合体 3.C++的枚举类型 1.C++的结构体 (1)C++中定义结构体变量,可以省略struct关键字 struct XX{…}; XX x;//定义结构体变量直接省略struct(2)C++结构体中可以直接定义函数,谓之成员函数(又叫方法)(3)在成员函数中可以直接访问该结构体的成员变…...

搭建高可用OpenStack(Queen版)集群(一)之架构环境准备

一、搭建高可用OpenStack(Queen版)集群之架构环境准备 一、架构设计 二、初始化基础环境 1、管理节点创建密钥对(方便传输数据) 所有控制节点操作 # ssh-keygen #一路回车即可 Generating public/private rsa key pair. Enter f…...

通过Stack Overflow线程栈溢出的问题实例,详解C++程序线程栈溢出的诸多细节

目录 1、问题说明 2、从Visual Studio输出窗口中找到了线索,发生了Stack Overflow线程栈溢出的异常 3、发生Stack Overflow线程栈溢出的原因分析 4、线程占用的栈空间大小说明 5、引发线程栈溢出的常见原因和场景总结 6、在问题函数入口处添加return语句&…...

LeetCode刷题笔记 | 3 | 无重复字符的最长子串 | 双指针 | 滑动窗口 | 2025兴业银行秋招笔试题 | 哈希集合

🙋大家好!我是毛毛张! 🌈个人首页: 神马都会亿点点的毛毛张 这是一道银行的面试题,就是简单?! LeetCode链接:3. 无重复字符的最长子串 1.题目描述 给定一个字符串 s &#xff0c…...

验证cuda和pytorch都按照成功了

要验证您的PyTorch是否能够调用CUDA,您可以执行以下步骤: 1. **检查CUDA是否可用**: 在Python中运行以下代码来检查CUDA是否可用: python import torch print(torch.cuda.is_available()) 如果输出为 True&…...

iOS开发如何自己捕获Crash

为了在iOS中捕获和处理未捕获的Objective-C异常和系统信号引起的崩溃,可以使用NSSetUncaughtExceptionHandler和标准的Unix信号处理机制来实现。这能帮助你记录绝大部分的崩溃信息。以下是详细的实现步骤和代码示例: 一、系统崩溃处理 通过NSSetUncaug…...

雪花算法(Snowflake Algorithm)

雪花算法(Snowflake Algorithm)是一种分布式唯一ID生成算法,主要用于生成全球唯一的ID,广泛应用于分布式系统中,例如在数据库中作为主键。这个算法最初由Twitter提出,并且被广泛使用在很多大规模系统中。有…...

〖任务1〗ROS2 jazzy Linux Mint 22 安装教程

前言: 本教程在Linux系统上使用。 目录 一、linux安装二、linux VPN安装三、linux anaconda安装(可选)四、linux ROS2 安装五、rosdep init/update 解决方法六、安装GUI 一、linux安装 移动硬盘安装linux:[LinuxToGo教程]把ubunt…...

图像增强:使用周围像素填充掩码区域

制作图像需要填充的掩码区域,对需要填充的位置的mask赋值非0,不需要填充赋值为0使用cv2.inpaint对图像掩码mask中非0元素位置的图像像素进行修复。从而实现使用周围像素填充掩码区域cv2.inpaint 是 OpenCV 库中的一个函数,用于图像修复(inpainting),即填充图像中的损坏区…...

给虚拟机Ubuntu扩展硬盘且不丢数据

1.Ubuntu关机状态下先扩展,如扩展20GB 2.进入ubuntu,切换root登录,必须是root全选,否则启动不了分区工具gparted 将新的20GB创建好后,选择ext4,primary; 3.永久挂载 我的主目录在/并挂载到/dev/sda1 从图…...

Oracle(41)如何使用PL/SQL批量处理数据?

在PL/SQL中,批量处理数据是一种高效的方法,可以在数据库中处理大量数据,而无需逐行操作。批量处理数据的关键技术包括: PL/SQL表(索引表):在内存中存储数据以进行批量操作。FORALL语句&#xf…...

JavaEE 第2节 线程安全知识铺垫1

目录 一、通过jconsole.exe查看线程状态的方法 二、Thread类的几种常见属性 三、线程状态 一、通过jconsole.exe查看线程状态的方法 通过jconsole查看线程状态非常实用的方式 只要你安装了jdk,大致按照这个目录就可以找到这个可执行程序: 然后双击这…...

LeetCode Hot100 零钱兑换

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。 你可以认为每种硬币的数量是无限的。 示…...

微信小程序接口实现语音转文字

一、效果展示 我们有一个按钮,点击“开始录音”按钮,此时按钮变成“停止录音”并开始计时,点击停止录音后,界面上即可展示返回的文字 二、代码实现 完整代码实现见github 1.小程序端代码 // index.js const recorderManager…...

Gerrit代码提交避坑指南:5种常见错误及解决方法(附真实案例)

Gerrit代码提交避坑指南:5种常见错误及解决方法(附真实案例) 在团队协作开发中,Gerrit作为代码评审工具被广泛使用,但开发者常会遇到各种提交问题。本文将深入分析五种高频错误场景,提供可落地的解决方案&a…...

HC32F460串口IAP升级实战:避开华大MCU那些坑(附完整代码)

HC32F460串口IAP升级实战:从原理到避坑指南 1. IAP升级的核心原理与华大MCU特性 IAP(In Application Programming)技术允许MCU在运行过程中通过通信接口(如串口)对自身Flash进行编程,实现固件在线更新。与传…...

从理论到实践:积分分离PID在智能车电机控制中的5个关键应用点

从理论到实践:积分分离PID在智能车电机控制中的5个关键应用点 在智能车竞赛中,电机控制算法的优劣直接决定了车辆在赛道上的表现。传统PID控制器虽然结构简单、易于实现,但在面对复杂赛道环境时,往往会出现超调、震荡等问题。积分…...

Chord视觉定位模型效果展示:‘找到图中的白色花瓶’→精准坐标输出真实案例集

Chord视觉定位模型效果展示:‘找到图中的白色花瓶’→精准坐标输出真实案例集 1. 项目简介 1.1 什么是Chord视觉定位模型 Chord是一个基于Qwen2.5-VL多模态大模型的视觉定位服务,它能够理解自然语言描述,并在图像中精确定位目标对象&#…...

量子退火器实战:用D-Wave解决CVRP物流路径优化问题(附Python代码)

量子退火实战:D-Wave在物流路径优化中的创新应用与Python实现 1. 量子计算与物流优化的跨界融合 当量子计算遇上物流优化,会碰撞出怎样的火花?作为物流算法工程师,我们每天都在与NP难问题搏斗。传统计算机在处理车辆路径规划这类组…...

Qwen3-32B-Chat私有化部署案例:金融研报摘要生成服务API封装

Qwen3-32B-Chat私有化部署案例:金融研报摘要生成服务API封装 1. 项目背景与价值 在金融行业,每天都会产生大量研究报告,分析师需要花费大量时间阅读和提炼关键信息。传统的人工摘要方式效率低下,且难以保证一致性。Qwen3-32B作为…...

从“玩具”到“工程”:我是如何用Qwen Coder的上下文工程框架,把AI编程引入真实企业项目的

从个人实验到团队革命:Qwen Coder如何重塑我们的AI编程工作流 去年夏天,当我第一次用ChatGPT生成Python代码时,团队里还有人开玩笑说这是"玩具程序员"。六个月后,我们却用Qwen Coder的上下文工程框架,在一个…...

告别绿幕!用MatAnyone搞定复杂背景视频抠像,保姆级部署教程(附避坑指南)

零门槛实现电影级抠像:MatAnyone实战指南与创意应用 在短视频和自媒体爆发的时代,高质量视频内容已成为创作者的核心竞争力。传统绿幕抠像技术虽然成熟,但对场地、设备和后期技术要求极高,让许多独立创作者望而却步。MatAnyone的出…...

从Halcon到C#:手把手教你将vector_angle_to_rigid生成的矩阵用到机器人引导中

从Halcon到C#:工业视觉与机器人协同的刚体变换实战指南 在工业自动化领域,视觉引导机器人已成为精密装配、物料搬运和质量检测等场景的核心技术。当视觉系统通过Halcon检测到工件的位置和角度后,如何将这些信息准确传递给机器人执行机构&…...

xHCI1.1架构解析:从寄存器到数据传输的完整流程

1. xHCI1.1架构全景概览 第一次拆开USB3.0移动硬盘盒时,我盯着主控芯片上"xHCI"的标识发愣——这个藏在硬件深处的控制器,到底是如何让数据在电脑和设备间流畅穿梭的?经过多年在嵌入式系统领域的实战,终于摸清了xHCI1.1…...