CN115384430B - 一种汽车仪表显示系统的启动方法、装置及存储介质 - Google Patents
一种汽车仪表显示系统的启动方法、装置及存储介质 Download PDFInfo
- Publication number
- CN115384430B CN115384430B CN202211342998.4A CN202211342998A CN115384430B CN 115384430 B CN115384430 B CN 115384430B CN 202211342998 A CN202211342998 A CN 202211342998A CN 115384430 B CN115384430 B CN 115384430B
- Authority
- CN
- China
- Prior art keywords
- container
- input
- starting
- display system
- instrument display
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 89
- 238000005192 partition Methods 0.000 claims abstract description 51
- 230000008569 process Effects 0.000 claims description 61
- 238000012545 processing Methods 0.000 claims description 24
- 238000004806 packaging method and process Methods 0.000 claims description 8
- 238000010276 construction Methods 0.000 claims description 4
- 238000011022 operating instruction Methods 0.000 claims description 4
- 230000006870 function Effects 0.000 description 26
- 239000000243 solution Substances 0.000 description 8
- 230000006872 improvement Effects 0.000 description 7
- 238000005516 engineering process Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 3
- 238000002955 isolation Methods 0.000 description 3
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000001816 cooling Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000012217 deletion Methods 0.000 description 1
- 230000037430 deletion Effects 0.000 description 1
- 238000002347 injection Methods 0.000 description 1
- 239000007924 injection Substances 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012856 packing Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 238000000926 separation method Methods 0.000 description 1
- 238000000638 solvent extraction Methods 0.000 description 1
Images
Classifications
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60R—VEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
- B60R16/00—Electric or fluid circuits specially adapted for vehicles and not otherwise provided for; Arrangement of elements of electric or fluid circuits specially adapted for vehicles and not otherwise provided for
- B60R16/02—Electric or fluid circuits specially adapted for vehicles and not otherwise provided for; Arrangement of elements of electric or fluid circuits specially adapted for vehicles and not otherwise provided for electric constitutive elements
- B60R16/023—Electric or fluid circuits specially adapted for vehicles and not otherwise provided for; Arrangement of elements of electric or fluid circuits specially adapted for vehicles and not otherwise provided for electric constitutive elements for transmission of signals between vehicle parts or subsystems
- B60R16/0231—Circuits relating to the driving or the functioning of the vehicle
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60K—ARRANGEMENT OR MOUNTING OF PROPULSION UNITS OR OF TRANSMISSIONS IN VEHICLES; ARRANGEMENT OR MOUNTING OF PLURAL DIVERSE PRIME-MOVERS IN VEHICLES; AUXILIARY DRIVES FOR VEHICLES; INSTRUMENTATION OR DASHBOARDS FOR VEHICLES; ARRANGEMENTS IN CONNECTION WITH COOLING, AIR INTAKE, GAS EXHAUST OR FUEL SUPPLY OF PROPULSION UNITS IN VEHICLES
- B60K35/00—Instruments specially adapted for vehicles; Arrangement of instruments in or on vehicles
- B60K35/80—Arrangements for controlling instruments
- B60K35/81—Arrangements for controlling instruments for controlling displays
Landscapes
- Engineering & Computer Science (AREA)
- Mechanical Engineering (AREA)
- Automation & Control Theory (AREA)
- Chemical & Material Sciences (AREA)
- Combustion & Propulsion (AREA)
- Transportation (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明公开了汽车仪表显示系统的启动方法、装置及存储介质,通过获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs,Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机,保证部署在任何操作系统环境中的软件都能始终如一地正常运行,可以提高汽车仪表显示系统的启动速度、安全性和灵活性。
Description
技术领域
本发明属于车辆工程技术领域,尤其涉及一种汽车仪表显示系统的启动方法、装置及存储介质。
背景技术
汽车仪表显示系统是汽车与驾驶员进行信息交互的界面,为驾驶员提供必要的汽车运行信息,同时也是维修人员发现和排除故障的重要工具。而现在的汽车仪表大多是全液晶屏幕制成,汽车仪表通常由地板数据处理MCU即微控制单元和核心板高性能SoC即系统级芯片组成,仪表的全液晶屏幕由SoC驱动显示,数据存放在外置的eMMC即内嵌式存储器中,且SoC内部需要运行大型操作系统时,系统调用时间增加,使得在汽车仪表显示系统开机时会出现启动慢的情况,同时限制了系统的灵活性,也影响了汽车仪表显示系统的安全性。
发明内容
有鉴于此,本发明提供了一种提高汽车仪表显示系统启动速度、安全故障隔离和提升使用体验的汽车仪表显示系统的启动方法、装置及存储介质,来解决上述存在的技术问题,具体采用以下技术方案来实现。
第一方面,本发明提供了一种汽车仪表显示系统的启动方法,包括以下步骤:
获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机。
作为上述技术方案的进一步改进,启动Lxc容器和初始化与rootfs所在的分区对应的Android系统以完成汽车仪表显示系统的正常开机,包括:
获取Lxc容器的运行环境并根据运行环境启动容器环境的内部命令生成容器运行指令,并在Android系统的内核中运行容器运行指令;
根据容器运行指令获取容器的进程信息,根据进程信息启动Android系统中的init进程得到Android的核心服务,其中,容器的进程信息包括init.Lxc、sh和ps,init.Lxc为容器的启动程序,sh为容器内部的shell,ps为调用的命令。
作为上述技术方案的进一步改进,Android系统的最底层为Linux的输入子系统,客户机作为Linux输入子系统的用户,通过对操作Linux输入子系统创建的设备节点和硬件层进行交互,Android系统的输入模块包括输入事件收集器、输入事件读取器、输入事件分发器和输入设备驱动;
输入事件收集器用于从输入设备中收集输入事件,对这些输入事件进行识别与封装,并提交给上一层进行处理;
输入事件读取器用于从输入事件收集器中获取输入事件,将事件交给输入事件分发器;
输入事件分发器用于接收输入事件读取器传来的事件信息并管理处理该事件的目标窗口;
输入设备驱动用于接收物理设备的事件输入得到事件信息,并将事件信息传给输入事件收集器;
当客户机对输入设备进行操作时,输入设备驱动会捕捉该操作,输入事件收集器不断从输入设备驱动中获取待处理的事件,输入事件读取器从输入事件收集器中获取原始事件并进行加工处理事件,将处理事件传给输入事件分发器,输入事件分发器将接收到的处理事件分发到合适的窗口中。
作为上述技术方案的进一步改进,输入事件收集器的执行过程包括:
获取当前容器的编号和当前运行环境的容器编号,若运行的容器环境不是当前容器对应的前台系统,则丢掉所有的输入事件;
若运行的容器环境是当前容器对应的前台系统,则不做任何的操作,将事件信息传给下个处理模块。
作为上述技术方案的进一步改进,Android系统的显示模块包括Android应用程序所产生的图像数据、在显示模块中用于管理应用程序所产生的图像数据的窗口管理服务、经过窗口管理服务加工处理后的显示数据、与硬件层的屏幕直接联系的系统服务,Android系统的显示模块执行过程包括:
每一个应用将自己的显示内容绘制到一个图像数据中,将图像数据传递给窗口管理服务进行处理,根据客户机当前显示的状态对图像数据添加相应的参数,系统服务获取到图像数据的参数后对所有图像数据合成为显示数据,系统服务将需要显示的显示数据传递给屏幕设备,屏幕显示该显示数据的内容。
作为上述技术方案的进一步改进,Linux内核将Lxc容器挂载至rootfs所在的分区,包括:
获取客户机中的,roofts并将rootfs输入Android系统的编译环境中,添加一个与rootfs对应的烧录分区;
将rootfs打包成lxcdata.img分区镜像,并将编译好的版本烧录至客户机以完成分区制作。
作为上述技术方案的进一步改进,根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,包括:
创建容器文件系统的创建只读层、容器读写层和挂载点,将只读层和读写层挂载到挂载点;
添加宿主机的文件夹到容器的数据卷和对应的标签得到挂载标签,判断数据卷是否为空;
若是,表示客户机未使用挂载标签,结束创建过程;
若否,则使用函数解析数据卷的字符串,当函数返回的字符数组长度为2,且数据元素均不为空时,则挂载数据卷;否则,提示客户机创建数据卷输入值不正确。
作为上述技术方案的进一步改进,挂载数据卷的过程包括:
读取宿主机的默认文件目录,根据默认文件目录创建宿主机的初始文件目录,在容器文件系统中创建与默认文件目录对应的装入点;
将数据卷从宿主机的初始文件目录中自动挂载到相应的容器中所需挂载的节点以启动容器的挂载过程。
第二方面,本发明还提供了一种汽车仪表显示系统的启动装置,包括:
获取单元,用于获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
构建单元,用于根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
启动单元,用于Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机。
第三方面,本发明还提供了一种存储介质,存储介质上存储有指令,指令被处理器执行时实现上述的汽车仪表显示系统的启动方法的步骤。
本发明提供了一种汽车仪表显示系统的启动方法、装置及存储介质,通过获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs,Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机,保证部署在任何操作系统环境中的软件都能始终如一地正常运行,可以提高汽车仪表显示系统的启动速度、安全性和灵活性。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本发明的汽车仪表显示系统的启动方法的流程图;
图2为本发明的输入事件收集器的执行过程的流程图;
图3为本发明的Lxc容器的创建过程图;
图4为本发明的挂载数据卷的流程图;
图5为本发明的汽车仪表显示系统的启动装置的结构框图;
图6为本发明的rootfs分区的结构示意图。
具体实施方式
下面详细描述本发明的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本发明,而不能理解为对本发明的限制。
参阅图1和图6,本发明提供了一种汽车仪表显示系统的启动方法,包括以下步骤:
S11:获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
S12:根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
S13:Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机。
本实施例中,启动Lxc容器和初始化与rootfs所在的分区对应的Android系统以完成汽车仪表显示系统的正常开机,包括:获取Lxc容器的运行环境并根据运行环境启动容器环境的内部命令生成容器运行指令,并在Android系统的内核中运行容器运行指令;根据容器运行指令获取容器的进程信息,根据进程信息启动Android系统中的init进程得到Android的核心服务,其中,容器的进程信息包括init.Lxc、sh和ps,init.Lxc为容器的启动程序,sh为容器内部的shell,ps为调用的命令。Lxc容器是Linux系统下通过轻量级虚拟化技术创建的容器,轻量级虚拟化技术的底层操作系统上不会实现一个虚拟化层来为虚拟机提供服务,轻量级虚拟化技术完全由底层操作系统及Linux内核提供支持,借助于内核的功能,可以在上层创建出多个隔离的进程运行空间,所有的独立空间共享同一个底层内核,一个隔离的空间如底层操作系统环境的一个拷贝,通过限制一个空间可用的内存等资源实现底层资源的划分,每个独立空间的擦走哦系统环境和底层系统是一致的,这里的独立空间即为容器。
需要说明的是,Lxc是Linux Containers的缩写,是一种开元的清凉虚拟化技术,Lxc提供一个软件包,客户机通过使用软件包里的一系列命令,可以对容器进行创建和销毁,或通过命令对Lxc容器进行配置。由于一个进程对应多个不同类型的命名空间,而同一个命名空间会被多个进程使用,为了辨识这种进程和命名空间之间多对多的关系,内核便设计类上述的数据结构作为两者之间的代理。每个创建的新进程都会有它自己的命名空间,在创建进程的过程中可以通过制定参数使得该进程具有新的命名空间,用户进程一般通过fork调用创建新的进程,但fork调用产生的进程和父进程属于同一个命名空间。通过设置flags的一些标志位可以制定新锦成是否需要创建新的命名空间。为了能在宿主机对虚拟Android进行操作和管理,需要在宿主机实现对输入设备和显示设备的复用,需要为每个容器分配一个数字ID,在启动容器的Lxc命令中以参数的形式为容器指定一个ID,之后容器中的进程可以通过读文件获取自己所在容器的ID。需要支持客户机配置一个所有容器可见的ID,表示允许使用本地显示设备和输入设备的Android容器的ID,实现一个Linux驱动,令该驱动在启动时自动加载,驱动加载成功后,会在Linux的proc文件系统中创建一个container_id文件,由于Android系统启动时会挂载Linux的proc文件系统,每个Android都能看到这个全局的container_id文件,客户机通过向container_id文件写入一个ID值来切换到对应的Android容器。
应理解,每个分区都是独立的实体,都拥有各自的私有数据空间,并且能防止其他分区非法访问或者破坏而实现数据隔离。分区间数据交换都是经过分区验证的信息,防止数据传输过程中被破坏,或者非法数据流对系统产生威胁而实现数据流控制。分区软件具有时间和空间隔离特性,能有效地避免系统资源无序竞争引发的安全性问题而实现系统资源保护。当某一个分区应用发生不可避免的失效情况时,分区软件能将失效影响范围控制在该分区内,避免其他正常分区应用受到影响,从而大大提高系统可靠性。容器不是去虚拟出主机硬件,然后在硬件基础上建立完整的软件操作系统,它的目的是把进程和进程隔离开来,有了这个容器,客户机可以将软件运行所需的所有系统资源打包并存放到一个与宿主机完全相互隔离的文件系统中,容器与其他传统虚拟机不同,不需要额外绑定一整套的操作系统,只需填软件工作所需的那部分库资源和相关设置,汽车仪表显示系统因此变得高效、轻量,并保证部署在任何操作系统环境中的软件都有能始终如一地正常运行,可以提高汽车仪表显示系统的启动速度和安全性。
可选地,Android系统的最底层为Linux的输入子系统,客户机作为Linux输入子系统的用户,通过对操作Linux输入子系统创建的设备节点和硬件层进行交互,Android系统的输入模块包括输入事件收集器、输入事件读取器、输入事件分发器和输入设备驱动;
输入事件收集器用于从输入设备中收集输入事件,对这些输入事件进行识别与封装,并提交给上一层进行处理;
输入事件读取器用于从输入事件收集器中获取输入事件,将事件交给输入事件分发器;
输入事件分发器用于接收输入事件读取器传来的事件信息并管理处理该事件的目标窗口;
输入设备驱动用于接收物理设备的事件输入得到事件信息,并将事件信息传给输入事件收集器;
当客户机对输入设备进行操作时,输入设备驱动会捕捉该操作,输入事件收集器不断从输入设备驱动中获取待处理的事件,输入事件读取器从输入事件收集器中获取原始事件并进行加工处理事件,将处理事件传给输入事件分发器,输入事件分发器将接收到的处理事件分发到合适的窗口中。
本实施例中,内核从preloader获得整个主机硬件的控制权,但这个过程却并不是轻松容易的,内核启动之前,文件系统并没有被装载,内核虽然要探测各种硬件,但内核本身必须得从某个分区上被装载,这个分区是由preloader来识别的,即preloader必须要能够识别内核未见所在的分区,而文件系统从逻辑上来看和从物理上来看是不一样的,从逻辑上看它们是有层次关系的。文件系统从根开始的,根下有许多一级目录如/user、/boot和/home等,这些目录中有些目录是可以单独关联到一个分区,而有些则不行,因为这些目录是与根自身完成初始化相关的,而每一个目录都通过根才能访问,根所在的分区通常就是操作系统,是内核能够实现进入用户空间的最核心的位置,因此这个分区有个特定的名称称为根文件系统rootfs,若把某个分区与根建立了关联关系,通过根所访问的所有文件都将以根作为访问入口,这个根就成了整个磁盘上的甚至于整个操作系统上访问其它任何存储设备的访问入口,根下有/bin、/sbin等很多目录,根本身挂载完成以后以后就要启动操作系统,而/bin、/sbin所放的这些二进制程序是操作系统自身启动就要用到的程序。当内核初始化完以后需要建立根文件系统,客户机系统告诉内核根在哪个分区上,即用户需要向内核传递一个参数,若内核驱动不了这个分区,它将不能访问rootfs,即内核必须要能通过驱动程序探测到分区,这样才能访问这个分区。在内核版本号命名的目录里,有该内核所需的各种外围模块,在这个目录下有许多文件,其中包含文件系统驱动程序模块,内核所需的模块就在这个设备上,要想访问这个设备得先有驱动,而要想拿到驱动得先能访问该设备。
需要说明的是,内核和要访问的设备之间再加一个层次,该层次只有一个简单的功能向内核提供这个设备的驱动,这个文件不是事先编译好的,内核是编译好的,模块也是编译好的,在安装操作系统时需要内核装起来,把内核模块装进来。
参阅图2,可选地,输入事件收集器的执行过程包括:
S22:获取当前容器的编号和当前运行环境的容器编号,若运行的容器环境不是当前容器对应的前台系统,则丢掉所有的输入事件;
S23:若运行的容器环境是当前容器对应的前台系统,则不做任何的操作,将事件信息传给下个处理模块。
本实施例中,Android系统的显示模块包括Android应用程序所产生的图像数据、在显示模块中用于管理应用程序所产生的图像数据的窗口管理服务、经过窗口管理服务加工处理后的显示数据、与硬件层的屏幕直接联系的系统服务,Android系统的显示模块执行过程包括:每一个应用将自己的显示内容绘制到一个图像数据中,将图像数据传递给窗口管理服务进行处理,根据客户机当前显示的状态对图像数据添加相应的参数,系统服务获取到图像数据的参数后对所有图像数据合成为显示数据,系统服务将需要显示的显示数据传递给屏幕设备,屏幕显示该显示数据的内容。
需要说明的是,EventHub模块是Android输入子系统的最底层,它直接访问Linux的输入设备文件和Linux输入子系统进行交互,EventHub模块初始化时会打开Linux在/dev/input/目录下创建的所有输入设备并进行管理,同时该模块会监控该目录下是否有设备节点的增删,新设备节点增加,则会打开新的设备文件,新设备节点增加,则会打开新的设备文件,设备节点减少,则会关闭已打开的设备文件,该模块通过epoll系统调用监控所有打开的设备文件,并将读到的原始输入事件转发给InputReader模块。InputReader模块是EventHub的使用者,从EventHub获取所有底层设备文件的输入,InputReader根据收到数据的类型通用不同的处理函数进行处理,InputReader还会监控EventHub发送的事件信息,包括设备的增、栅扫描事件,并进行相应的处理,最后InputReader会将收到的输入数据发到消息队列中供InputDispatcher处理。InputDispatcher从消息队列中取出InputReader产生的事件进行分发,InputDispatcher在分发前,会对输入进行过滤、拦截,当确定需要使用时,会根据输入内容选择合适的窗口,并写入窗口的事件接受管道中,最后由窗口进行处理,最后在界面上显示。在应用程序框架层注入需要考虑打包的情况,处理较为复杂,通过输入设备注入原始的输入数据,可以较细粒度的重现客户机操作,同时中间没有经过Android系统的任何处理,且宿主机是具有root权限的,最后选择在Linux设备上注入输入条件,可以降低延迟和提高效率,
可选地,Linux内核将Lxc容器挂载至rootfs所在的分区,包括:
获取客户机中的,roofts并将rootfs输入Android系统的编译环境中,添加一个与rootfs对应的烧录分区;
将rootfs打包成lxcdata.img分区镜像,并将编译好的版本烧录至客户机以完成分区制作。
参阅图3,可选地,根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,包括:
S33:创建容器文件系统的创建只读层、容器读写层和挂载点,将只读层和读写层挂载到挂载点;
S34:添加宿主机的文件夹到容器的数据卷和对应的标签得到挂载标签,判断数据卷是否为空;
S35:若是,表示客户机未使用挂载标签,结束创建过程;
S36:若否,则使用函数解析数据卷的字符串,当函数返回的字符数组长度为2,且数据元素均不为空时,则挂载数据卷;否则,提示客户机创建数据卷输入值不正确。
本实施例中,启动容器时,创建只读层busybox,创建读写层writeLayer(),创建挂载点mnt,并把只读层和读写层挂载到挂载点,将挂载点作为容器的根目录。容器退出时,卸载挂载点mnt的文件系统,删除挂载点,删除读写层writeLayer。只有在volume不为空,且使用volume函数解析volume字符串返回的字符数组长度为2,数据元素均为空时,才执行删除挂载函数来处理。对于其余部分,还使用前面的删除函数。删除挂载点和数据卷函数的处理逻辑过程为:卸载volume挂载点的文件系统,保证整个容器的挂载点没有被使用,卸载整个容器文件系统的装载点,删除容器文件系统的挂载点,整个容器退出过程中的文件系统处理就结束了。
参阅图4,可选地,挂载数据卷的过程包括:
S44:读取宿主机的默认文件目录,根据默认文件目录创建宿主机的初始文件目录,在容器文件系统中创建与默认文件目录对应的装入点;
S45:将数据卷从宿主机的初始文件目录中自动挂载到相应的容器中所需挂载的节点以启动容器的挂载过程。
本实施例中,将宿主机/root/busybox目录作为文件的根目录,但在容器内对文件的操作会直接影响到宿主机的/root/busybox目录,而真正的容器是要能做到将容器和镜像隔离的,实现在容器中进行的操作不会对镜像产生任何影响的功能。NewWorkSpace()函数是用来创建容器文件系统的,其包括CreateReadOnlyLayer(),CreatWriteLayer()和CreatMountPoint(),CreateReadOnlyLayer()函数新建busybox文件夹,将busybox.tar解压到busybox目录下,作为容器的只读层。CreatWriteLayer()函数创建了一个名为writeLayer的文件夹,作为容器唯一的可写层。在CreatMountPoint()函数中,首先创建了mnt文件夹,作为文件的挂载点,然后把writeLayer()目录和busybox目录mount到mnt目录下,最后在NewParentProcess()函数中将容器使用的宿主机目录/root/busybox替换成/root/mnt,在NewParentProcess()函数中将容器使用的宿主机目录/root/busybox替换成/root/mnt,这样,使用UFS系统启动容器的代码。将容器对应的writeLayer和Container-init Layer删除,而保留镜像所有的内容,本代码在容器退出时会删除writeLayer。UFS包装busybox实现了将容器和镜像的分离,但容器退出时,容器可写层的所有内容都会被删除,volume可以解决客户机需要将部分数据持久化在容器中的问题。通过将宿主机的目录作为数据卷挂载到容器中,且在容器退出后,数据卷中的内容还能保存在宿主机上。
需要说明的是,在容器退出时添加绑定宿主机文件夹到容器数据卷的功能,在文件的命令中添加-v标签,在函数中将volume传给创建容器的NewParentProcess函数和删除容器文件系统的DeleteWorkSpace()函数,继续把Volume值传给创建容器文件系统的NewWorkSpace()方法,从而提高容器的灵活性。容器在退出所有可写层的内容,commit子命令的目的是把运行状态下容器的内容存储成镜像保存下来。创建容器时使用UFS对busybox进行包装,使得容器在运行中,若进行写操作时会临时创建出一个可写层,以达到不破坏原有文件系统的目的,若不对容器的写操作做保存,则容器结束时,文件系统的内容与启动容器前相比不会有任何变化,这正好满足了容器的文件系统应采用分层的方法,实现了启动容器应具备的volume数据卷功能和对进行镜像打包的功能。
参阅图5,本发明还提供了一种汽车仪表显示系统的启动装置,包括:
获取单元,用于获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
构建单元,用于根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
启动单元,用于Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机。
本实施例中,Linux内核名字空间机制是将原来共享的全局资源拆分成很多个组进程共享的资源,当一个名字空间里面的所有进程都退出时,名字空间也会被内核销毁,即当名字空间是动态创建与销毁的,伴随进程创建,随着进程退出而销毁,基于角色访问控制的UTS名字空间随机化,来阻止主机信息泄露,将UTS名字空间固定的初始值进行随机化处理,根据客户机需求和可信程度,设立不同类别的角色,不同类别角色获得UTS名字空间的信息是不同的,宿主机返回用户,有需求且可信的角色可获得真实有用信息如系统版本信息,不可信的客户机获取的信息是进行随机化处理过的信息。UTS名字空间包含了运行内核的名称、版本、底层体系结构类型等信息,提供了主机名和域名的隔离,进程可以在调用函数clone()或unshare()时制定CLONE_NEWUTS标识来创建UTS名字空间,也可以根据需要创建自己独特的UTS名字空间,其中包含主机名和域名等,虽然UTS名字空间内包装的utsname是从原始数据复制而来,用户进程可以在UTS名字空间内拥有属于自己的主机名hostname和域名domainname标识,这个标识可让UTS名字空间内的执行环节独立于宿主机和其上的其他容器,从而提高了汽车仪表显示系统的启动速率。
在另一个可行的实施例中,本发明还提供了一种存储介质,存储介质上存储有指令,指令被处理器执行时实现上述的汽车仪表显示系统的启动方法的步骤。
在这里示出和描述的所有示例中,任何具体值应被解释为仅仅是示例性的,而不是作为限制,因此,示例性实施例的其他示例可以具有不同的值。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本发明范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。
Claims (9)
1.一种汽车仪表显示系统的启动方法,其特征在于,包括以下步骤:
获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机;
启动Lxc容器和初始化与rootfs所在的分区对应的Android系统以完成汽车仪表显示系统的正常开机,包括:
获取Lxc容器的运行环境并根据运行环境启动容器环境的内部命令生成容器运行指令,并在Android系统的内核中运行容器运行指令;
根据容器运行指令获取容器的进程信息,根据进程信息启动Android系统中的init进程得到Android的核心服务,其中,容器的进程信息包括init.Lxc、sh和ps,init.Lxc为容器的启动程序,sh为容器内部的shell,ps为调用的命令。
2.根据权利要求1所述的汽车仪表显示系统的启动方法,其特征在于,Android系统的最底层为Linux的输入子系统,客户机作为Linux输入子系统的用户,通过对操作Linux输入子系统创建的设备节点和硬件层进行交互,Android系统的输入模块包括输入事件收集器、输入事件读取器、输入事件分发器和输入设备驱动;
输入事件收集器用于从输入设备中收集输入事件,对这些输入事件进行识别与封装,并提交给上一层进行处理;
输入事件读取器用于从输入事件收集器中获取输入事件,将事件交给输入事件分发器;
输入事件分发器用于接收输入事件读取器传来的事件信息并管理处理该事件的目标窗口;
输入设备驱动用于接收物理设备的事件输入得到事件信息,并将事件信息传给输入事件收集器;
当客户机对输入设备进行操作时,输入设备驱动会捕捉该操作,输入事件收集器不断从输入设备驱动中获取待处理的事件,输入事件读取器从输入事件收集器中获取原始事件并进行加工处理事件,将处理事件传给输入事件分发器,输入事件分发器将接收到的处理事件分发到合适的窗口中。
3.根据权利要求2所述的汽车仪表显示系统的启动方法,其特征在于,输入事件收集器的执行过程包括:
获取当前容器的编号和当前运行环境的容器编号,若运行的容器环境不是当前容器对应的前台系统,则丢掉所有的输入事件;
若运行的容器环境是当前容器对应的前台系统,则不做任何的操作,将事件信息传给下个处理模块。
4.根据权利要求1所述的汽车仪表显示系统的启动方法,其特征在于,Android系统的显示模块包括Android应用程序所产生的图像数据、在显示模块中用于管理应用程序所产生的图像数据的窗口管理服务、经过窗口管理服务加工处理后的显示数据、与硬件层的屏幕直接联系的系统服务,Android系统的显示模块执行过程包括:
每一个应用将自己的显示内容绘制到一个图像数据中,将图像数据传递给窗口管理服务进行处理,根据客户机当前显示的状态对图像数据添加相应的参数,系统服务获取到图像数据的参数后对所有图像数据合成为显示数据,系统服务将需要显示的显示数据传递给屏幕设备,屏幕显示该显示数据的内容。
5.根据权利要求1所述的汽车仪表显示系统的启动方法,其特征在于,Linux内核将Lxc容器挂载至rootfs所在的分区,包括:
获取客户机中的,roofts并将rootfs输入Android系统的编译环境中,添加一个与rootfs对应的烧录分区;
将rootfs打包成lxcdata.img分区镜像,并将编译好的版本烧录至客户机以完成分区制作。
6.根据权利要求1所述的汽车仪表显示系统的启动方法,其特征在于,根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,包括:
创建容器文件系统的创建只读层、容器读写层和挂载点,将只读层和读写层挂载到挂载点;
添加宿主机的文件夹到容器的数据卷和对应的标签得到挂载标签,判断数据卷是否为空;
若是,表示客户机未使用挂载标签,结束创建过程;
若否,则使用函数解析数据卷的字符串,当函数返回的字符数组长度为2,且数据元素均不为空时,则挂载数据卷;否则,提示客户机创建数据卷输入值不正确。
7.根据权利要求6所述的汽车仪表显示系统的启动方法,其特征在于,挂载数据卷的过程包括:
读取宿主机的默认文件目录,根据默认文件目录创建宿主机的初始文件目录,在容器文件系统中创建与默认文件目录对应的装入点;
将数据卷从宿主机的初始文件目录中自动挂载到相应的容器中所需挂载的节点以启动容器的挂载过程。
8.一种根据权利要求1-7任一项所述的汽车仪表显示系统的启动方法执行的汽车仪表显示系统的启动装置,其特征在于,包括:
获取单元,用于获取汽车仪表显示系统的预加载指令,并对预加载指令进行编译获取Linux内核的属性信息,其中,汽车仪表显示系统包括宿主机、客户机和Linux内核,宿主机通过Linux内核与客户机连接,属性信息包括输入驱动信息、输出驱动信息和版本;
构建单元,用于根据Linux内核的属性信息对宿主机进行虚拟化得到Lxc容器,并在客户机内建立与Lxc容器对应的分区存放根目录记为rootfs;
启动单元,用于Linux内核将Lxc容器挂载至rootfs所在的分区,启动Lxc容器与rootfs所在的分区对应的操作系统以完成汽车仪表显示系统的正常开机。
9.一种存储介质,存储介质上存储有指令,指令被处理器执行时实现上述权利要求1-7任一项所述的汽车仪表显示系统的启动方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211342998.4A CN115384430B (zh) | 2022-10-31 | 2022-10-31 | 一种汽车仪表显示系统的启动方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211342998.4A CN115384430B (zh) | 2022-10-31 | 2022-10-31 | 一种汽车仪表显示系统的启动方法、装置及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115384430A CN115384430A (zh) | 2022-11-25 |
CN115384430B true CN115384430B (zh) | 2023-01-10 |
Family
ID=84115003
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211342998.4A Active CN115384430B (zh) | 2022-10-31 | 2022-10-31 | 一种汽车仪表显示系统的启动方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115384430B (zh) |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20160328254A1 (en) * | 2014-01-06 | 2016-11-10 | Johnson Controls Technology Company | Vehicle with multiple user interface operating domains |
CN110936908A (zh) * | 2019-11-21 | 2020-03-31 | 东风电驱动系统有限公司 | 一种基于操作系统的车载显示系统的快速响应方法及装置 |
CN114461287B (zh) * | 2022-01-29 | 2024-01-30 | 亿咖通(湖北)技术有限公司 | 操作系统启动方法、装置、电子设备和存储介质 |
CN114461396A (zh) * | 2022-02-08 | 2022-05-10 | 亿咖通(湖北)技术有限公司 | 基于lxc的资源调度方法、装置、设备及存储介质 |
-
2022
- 2022-10-31 CN CN202211342998.4A patent/CN115384430B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN115384430A (zh) | 2022-11-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8806479B2 (en) | Creating an application virtual machine image by isolating installation artifacts in shadow area | |
CN111338854B (zh) | 基于Kubernetes集群快速恢复数据的方法及系统 | |
US20110078681A1 (en) | Method and system for running virtual machine image | |
US8359593B2 (en) | Computer machine migration of file system images using a redo-log file | |
US20210011740A1 (en) | Method and system for constructing lightweight container-based user environment (cue), and medium | |
US9189263B1 (en) | Object synchronization in shared object space | |
US8924954B2 (en) | Application software installation method and application software installation apparatus | |
US20090070752A1 (en) | Method and system for optimization of an application | |
US10574524B2 (en) | Increasing reusability of and reducing storage resources required for virtual machine images | |
US7757034B1 (en) | Expansion of virtualized physical memory of virtual machine | |
US11010355B2 (en) | Layer-based file access method and apparatus of virtualization instance | |
EP2038740A2 (en) | Method and apparatus for virtualization of appliances | |
KR20110050452A (ko) | 가상 디스크를 포함하는 컴퓨터의 복구 | |
CN109614165A (zh) | 一种com组件的多版本并行运行方法和装置 | |
US10684884B1 (en) | Application containers running inside virtual machine | |
CN114168156A (zh) | 多租户数据持久化方法、装置、存储介质和计算机设备 | |
CN104517067A (zh) | 访问数据的方法、装置及系统 | |
US20230342134A1 (en) | Hybrid approach to performing a lazy pull of container images | |
CN115384430B (zh) | 一种汽车仪表显示系统的启动方法、装置及存储介质 | |
US10248449B1 (en) | Application containers running inside virtual machine | |
CN116594978A (zh) | 基于用户态文件系统的前端模块管理器、管理方法及系统 | |
US10102020B2 (en) | Methods, systems, and computer readable media for virtual machine (VM) deployment using read-only memory | |
CN113986858B (zh) | Linux兼容安卓系统的共享文件操作方法和装置 | |
CN114237814A (zh) | 跨虚拟化平台的虚拟机迁移方法、装置和计算机设备 | |
CN114840330A (zh) | 一种内存回收方法、装置及控制设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |