CN108984183A - 一种软件跨地域构建方法、装置、设备及存储介质 - Google Patents
一种软件跨地域构建方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN108984183A CN108984183A CN201810987601.4A CN201810987601A CN108984183A CN 108984183 A CN108984183 A CN 108984183A CN 201810987601 A CN201810987601 A CN 201810987601A CN 108984183 A CN108984183 A CN 108984183A
- Authority
- CN
- China
- Prior art keywords
- catalogue
- cloud server
- source code
- code
- software
- 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.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本申请公开了一种软件跨地域构建方法、装置、设备及存储介质,涉及计算机技术领域,用于解决软件规模较大且跨地域传输网络速率较慢时构建时间较长的问题,方法包括:将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。也即,本发明利用本地缓存空间中的临时代码目录保存与目标软件对应的全部源代码,进一步将临时目录中的源代码全部复制至用户构建目录,复制过程为本地传输,无需网络连接,能够具备较快传输速度,从而显著缩短软件跨地域构建时间,并提升工作效率,节省人力资源。
Description
技术领域
本发明涉及计算机技术领域,特别涉及一种软件跨地域构建方法、装置、设备及计算机可读存储介质。
背景技术
众所周知,团队使用的公共系统将极大地影响整个团队的效率,公共系统需要尽可能的快速高效,从而很好的提升工作效率,节约成本。
日常使用的软件版本构建系统中,多个开发者向同一个代码库提交代码,进行构建时需要先将最新的代码同步到构建机的各个用户的构建目录,再进一步启动编译。编译有增量编译和全量编译两种方式,增量编译只需要将构建目录下和代码库上的代码差异拉取到构建目录,使得构建目录下的代码与代码库代码一致,然后编译修改过的代码即可。全量编译则需要清空用户构建目录,然后通过网络将代码库上的整个代码目录拷贝到构建目录下重新构建。
日常工作中,全量编译是不可避免的。以git作为版本工具为例,开发过程中通常需要拉取新的临时分支进行修改,修改后通过验证,再将分支上的修改合入到开发主干分支。这些临时分支只能采用全量编译的方式进行构建。在代码规模较大且跨地市传输网络速率较慢时,从构建机直接从云端服务器的代码库中拷贝代码,整个构建过程耗费接近3小时,极大的影响了工作效率。鉴于此,提供一种解决上述问题的方法是本领域技术人员需要考虑的。
发明内容
有鉴于此,本发明的目的在于提供一种软件跨地域构建方法、装置、设备及介质,能够有效的提升软件跨地域构建的效率。其具体方案如下:
第一方面,本发明公开了一种软件跨地域构建方法,包括:
将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
可选的,还包括:
创建临时代码目录;
将所述云端服务器发送的与所述目标软件对应的全部源代码复制至所述临时代码目录中。
可选的,所述利用所述用户构建目录中的源代码进行全量编译处理,包括:
通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异;
如果是,则获取所述云端服务器发送的相应的第一增量代码,并利用所述用户构建目录中的源代码与所述第一增量代码进行全量编译处理;
如果否,则直接利用所述用户构建目录中的源代码进行全量编译处理。
可选的,所述通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异,包括:
通过所述云端服务器比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
可选的,所述通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异,包括:
通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述用户构建目录中的源代码的内容,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
可选的,还包括:
通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异;
如果是,则获取所述云端服务器发送的相应的第二增量代码,并利用所述第二增量代码,完成所述临时代码目录与所述云端代码库的同步。
第二方面,本发明公开了一种软件跨地域构建装置,包括:
代码复制模块,用于将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
软件构建模块,用于利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
第三方面,本发明公开了一种软件跨地域构建设备,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现前述公开的软件跨地域构建方法的步骤。
第四方面,本发明公开了一种计算机可读存储介质,用于存储计算机程序,其中,所述计算机程序被处理器执行时实现前述公开的软件跨地域构建方法的步骤。
可见,本发明通过将临时代码目录中的源代码全部复制至用户构建目录,其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。本发明通过将预先保存有云端服务器发送的与目标软件对应的全部源代码的临时代码目录中的源代码全部复制至用户构建目录,并对用户构建目录中的源代码全量编译,完成目标软件的构建,也即,本发明利用本地的缓存空间保存与目标软件对应的全部源代码,进一步将临时目录中的源代码全部复制至用户构建目录,复制过程为本地传输,无需网络连接,能够具备较快传输速度,从而缩短软件跨地域构建时间,并提升工作效率,节省人力资源。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。
图1为本发明公开的一种软件跨地域构建方法流程图;
图2为本发明公开的一种软件跨地域构建方法具体实施过程示意图;
图3为本发明公开的一种具体的软件跨地域构建方法流程图;
图4为本发明公开的一种软件跨地域构建装置结构示意图;
图5为本发明公开的一种具体的软件跨地域构建设备硬件结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
现有技术中,在代码规模较大且跨地市传输网络速率较慢时,从构建机直接从云端服务器的代码库中拷贝代码,整个构建过程耗费时间过长,极大的影响了工作效率。为此,本发明通过利用本地缓存空间中的临时代码目录存储代码,并将代码从临时代码目录复制至用户构建目录,缩短了构建时间,从而进一步提高工作效率。
本发明实施例公开了一种软件跨地域构建方法,参见图1所示,该方法包括:
步骤S101:将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
本实施例中,将本地的临时代码目录中保存的源代码全部复制至用户构建目录,具体地,可以采用Linux系统下的cp命令将构建机的临时代码目录中的源代码复制保存至本机的用户构建目录。
需要说明的是,本实施例还通过在构建机本地创建临时代码目录,并将云端服务器发送的与目标软件对应的全部源代码保存至所述临时代码目录中。
另外,本实施例中,为了避免非法用户随意对源代码进行操作,可以在代码复制之前对当前用户进行合法验证,具体地,可以采用消息采集接口采集用户特征数据,其中,所述消息采集接口可以为语音特征采集接口、虹膜特征采集接口、指纹特征采集接口、脸部特征采集接口或手势特征采集接口,所述用户特征数据可以为语音特征、虹膜特征、指纹特征、脸部特征或手势特征中任意一种或任意组合。
可以理解的是,本实施例在利用消息采集接口采集特征数据之前,预先将合法用户的指纹特征、虹膜特征等预设特征数据录入,在采集到用户特征数据之后,判断所述用户特征数据是否与预设特征数据一致,可以保证只有预设的合法用户才能够触发代码复制过程,保证了信息安全。
步骤S102:利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
本实施例中,利用所述用户构建目录中的源代码进行全量编译处理具体包括:通过云端服务器判断当前云端服务器中与目标软件对应的全部源代码与当前用户构建目录中的源代码之间是否存在差异,如果是,则获取云端服务器发送的第一增量代码,并利用用户构建目录中的源代码与所述第一增量代码进行全量编译处理;如果否,则直接利用用户构建目录中的源代码进行全量编译处理。
可以理解的是,用户构建目录中保存的源代码为预先复制临时代码目录中的源代码得到的代码,在临时代码目录获取到云端服务器发送的与目标软件对应的全部源代码之后,云端服务器中与目标软件对应的代码可能会有更新,也即,云端服务器中与目标软件对应的代码与临时代码目录中的源代码并不能实时同步,从而导致用户构建目录中保存的源代码不一定是最新的代码,若直接利用用户构建目录中保存的源代码进行全量编译,可能会造成一定的错误,从而影响工作效率。
由此,在全量编译之前,先判断当前云端服务器中与目标软件对应的全部源代码与当前用户构建目录中的源代码之间是否存在差异,若存在差异,表示云端服务器中与目标软件对应的代码进行了更新,则获取相应的第一增量代码,使得当前用户构建目录中的源代码与云端服务器中与目标软件对应的代码一致,再进行全量编译处理;若不存在差异,表示云端服务器中与目标软件对应的代码未进行更改,则当前用户构建目录中的源代码与云端服务器中与目标软件对应的代码一致,可以直接利用用户构建目录中的源代码进行全量编译处理。
利用上述具体实施过程,可以避免在代码规模较大且跨地市传输网络速率较慢时,直接从云端服务器复制与目标软件对应的代码至用户目录导致的传输时间过长,降低工作效率的问题。通常,本实施例能够将获取云端服务器中与目标软件对应的最新代码到用户构建目录的时间由现有技术1.5小时缩短到10分钟内,显著提高工作效率。
具体地,可以由构建机向云端服务器发起检测请求,通过云端服务器判断是否存在差异,若不存在差异,可以直接返回编译指令,提示用户构建目录可以直接进行全量编译处理;若存在差异,可以直接返回第一增量代码,以使用户构建机利用用户构建目录中的源代码和第一增量代码进行全量编译,或者,可以返回存在差异的消息,由构建机再次发起获取增量代码的请求,进一步获得第一增量代码。
当然,为了尽量减少用户的人工干预,提升用户的便捷体验,本实施例也可以直接由云端服务器判断当前云端服务器中与目标软件对应的全部源代码与当前用户构建目录中的源代码之间是否存在差异,进而构建机获取云端服务器发送的指令消息或增量代码,进行全量编译处理。
可见,本发明通过将临时代码目录中的源代码全部复制至用户构建目录,其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。本发明通过将预先保存有云端服务器发送的与目标软件对应的全部源代码的临时代码目录中的源代码全部复制至用户构建目录,并对用户构建目录中的源代码全量编译,完成目标软件的构建,也即,本发明利用本地的缓存空间保存与目标软件对应的全部源代码,进一步将临时目录中的源代码全部复制至用户构建目录,复制过程为本地传输,无需网络连接,能够具备较快传输速度,从而显著缩短软件跨地域构建时间,并提升工作效率,节省人力资源。
下面通过一种具体实施方式对本发明所提供的软件跨地域构建方法进行进一步详细阐述,该过程包括:
步骤S201:将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
步骤S202:通过所述云端服务器比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异;
本实施例中,通过云端服务器判断当前云端服务器中与目标软件对应的全部源代码与当前用户构建目录中的源代码之间是否存在差异,具体可以为:通过比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,判断云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
具体地,可以通过云端服务器接收构建机发出的检测请求,并获取当前云端服务器中与目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号;或,直接由云端服务器获取当前云端服务器中与目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,进一步对比两个版本号是否有差异,如果是,则进一步判断并获取源代码之间的差异。
步骤S203:如果是,则获取所述云端服务器发送的相应的第一增量代码,并利用所述用户构建目录中的源代码与所述第一增量代码进行全量编译处理,完成所述目标软件的构建;
步骤S204:如果否,则直接利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
本实施例中,在判定到云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间存在差异时,通过云端服务器获取相应的第一增量代码,并发送至构建机,以使用户构建机利用用户构建目录中的源代码和第一增量代码进行全量编译。
另外,还可以通过云端服务器对当前云端服务器中与目标软件对应的全部源代码进行实时监测,若监测到代码发送变化,则记录更改时间,统计相应的变化信息,进一步通过获取上次云端服务器发送与目标软件对应的全部源代码至临时代码目录的时间,分析对比获取第一增量代码。
下面通过一种具体实施方式对本发明所提供的软件跨地域构建方法进行进一步详细阐述,该过程包括:
步骤S301:将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
步骤S302:通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述用户构建目录中的源代码的内容,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异;
本实施例中,通过云端服务器判断当前云端服务器中与目标软件对应的全部源代码与当前用户构建目录中的源代码之间是否存在差异,具体可以为:通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述用户构建目录中的源代码的内容,判断云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
具体地,可以在获取到云端服务器中与目标软件对应的全部源代码的内容与用户构建目录中的源代码的内容之后,直接利用代码对比工具获取代码差异,得到第一增量代码。
步骤S303:如果是,则获取所述云端服务器发送的相应的第一增量代码,并利用所述用户构建目录中的源代码与所述第一增量代码进行全量编译处理,完成所述目标软件的构建;
步骤S304:如果否,则直接利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
关于上述步骤S303与S304的具体实施过程可以参考前述实施例,在此不再进行赘述。
本发明实施例公开了一种具体的软件跨地域构建方法,相对于上一实施例,本实施例对技术方案作了进一步的说明和优化。参见图2所示,具体的:
步骤S401:将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
步骤S402:利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建;
关于上述步骤S401与S402的具体实施过程可以参考前述实施例,在此不再进行赘述。
步骤S403:通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异;
可以理解的是,用户构建目录中保存的源代码为预先复制临时代码目录中的源代码得到的代码,在临时代码目录获取到云端服务器发送的与目标软件对应的全部源代码之后,云端服务器中的与所述目标软件对应的源代码可能会发生更新改变,此时,临时代码目录中的源代码与云端服务器中的与所述目标软件对应的源代码不一致,也即,云端服务器中与目标软件对应的代码与临时代码目录中的源代码并不能实时同步。
由此,可以通过云端服务器定期判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异,进而对代码进行同步。
具体地,可以由构建机按照预设检测周期定期向云端服务器发起检测请求,通过云端服务器判断是否存在差异;或,直接由云端服务器按照预设检测周期定期判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异。
可以理解的是,所述预设检测周期不宜设置过大的数值,以防云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间的增量代码过多,则同步代码的工作量则相应较大,从而耗费时间。例如,可以将预设检测周期设置为一周,即每隔一周检测一次云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异。
本实施例中,通过云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异可以具体为:通过比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述临时代码目录中的源代码的版本号,判断云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异;或,通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述临时代码目录中的源代码的内容,判断云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异。
步骤S404:如果是,则获取所述云端服务器发送的相应的第二增量代码,并利用所述第二增量代码,完成所述临时代码目录与所述云端代码库的同步。
本实施例中,获取云端服务器对所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异的判断结果之后,若不存在差异,可以返回提示信息,例如,提示信息可以为:当前代码为最新版本,无需同步;若存在差异,可以直接返回第二增量代码,以实现云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码的同步,或可以返回存在差异的消息,由构建机再次发起获取增量代码的请求,进一步获得第二增量代码,利用所述第二增量代码,完成所述临时代码目录与所述云端代码库的同步。
相应的,图3为本实施例具体实施过程的示意图。如图所示,可以有多个用户开发机,用于由多个用户共同对目标软件进行开发,并可以将开发的源代码上传至云端服务器中与目标软件对应的代码库中。另外,在构建机本地创建的临时代码目录中预先保存由云端服务器发送的与目标软件对应的代码库中的全部源代码,此时,若存在用户需要对目标软件进行开发,则可以将临时代码目录中的代码复制保存至各个用户对应的用户构建目录中,并进一步通过判断用户构建目录中的代码与云端服务器中与目标软件对应的代码库中的全部源代码是否有差异,如果是,则获取相应的第一增量代码,并利用第一增量代码与当前用户构建目录中的代码进行全量编译处理;如果否,则直接利用当前用户构建目录中的代码进行全量编译处理。进一步地,还可以定期获取云端服务器中与目标软件对应的代码库中的全部源代码与临时代码目录中的代码之间的第二增量代码,实现云端服务器中与目标软件对应的源代码与临时代码目录中的代码的同步。
相应的,本发明实施例还公开了一种软件跨地域构建装置,参见图4所示,装置包括:
代码复制模块100,用于将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
软件构建模块200,用于利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
本实施例中的软件跨地域构建装置用于实现前述的软件跨地域构建方法,因此关于软件跨地域构建装置中的各个模块更加具体的工作过程可以参考前述实施例公开的相应内容,在此不再赘述。
进一步地,本发明实施例还公开了一种软件跨地域构建设备,该软件跨地域构建设备包括存储器11和处理器12,其中,所述处理器12执行所述存储器11中保存的计算机程序时实现以下步骤:
将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
本实施例中,所述处理器12执行所述存储器11中保存的计算机子程序时,可以具体实现以下步骤:创建临时代码目录;将所述云端服务器发送的与所述目标软件对应的全部源代码复制至所述临时代码目录中。
本实施例中,所述处理器12执行所述存储器11中保存的计算机子程序时,可以具体实现以下步骤:通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异;如果是,则获取所述云端服务器发送的相应的第一增量代码,并利用所述用户构建目录中的源代码与所述第一增量代码进行全量编译处理;如果否,则直接利用所述用户构建目录中的源代码进行全量编译处理。
本实施例中,所述处理器12执行所述存储器11中保存的计算机子程序时,可以具体实现以下步骤:通过所述云端服务器比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
本实施例中,所述处理器12执行所述存储器11中保存的计算机子程序时,可以具体实现以下步骤:通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述用户构建目录中的源代码的内容,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
本实施例中,所述处理器12执行所述存储器11中保存的计算机子程序时,可以具体实现以下步骤:通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异;如果是,则获取所述云端服务器发送的相应的第二增量代码,并利用所述第二增量代码,完成所述临时代码目录与所述云端代码库的同步。
进一步地,参见图5所示,本实施例中的软件跨地域构建设备,还可以包括:
输入接口13,用于获取外界导入的计算机程序,并将获取到的计算机程序保存至所述存储器12中,还可以用于获取外界终端设备传输的各种指令和参数,并传输至处理器11中,以便处理器11利用上述各种指令和参数展开相应的处理。本实施例中,所述输入接口13具体可以包括但不限于USB接口、串行接口、语音输入接口、指纹输入接口、硬盘读取接口等。
输出接口14,用于将处理器11产生的各种数据输出至与其相连的终端设备,以便于与输出接口14相连的其他终端设备能够获取到处理器11产生的各种数据。本实施例中,所述输出接口14具体可以包括但不限于USB接口、串行接口等。
通信单元15,用于和外部服务器之间建立远程通信连接,获取外界终端发送的数据,然后发送至处理器11进行处理分析,另外,处理器11还可以将处理后得到的各种结果通过通信单元15发送至预设的各种数据接收端。本实施例中,上述通信单元15所采用的通信技术可以是有线通信技术或无线通信技术,如通用串行总线(USB)、无线保真技术(WiFi)、蓝牙通信技术、低功耗蓝牙通信技术(BLE)等。另外,通信单元15具体可以根据宽带码分多址(W-CDMA)、长期演进(LTE)和类似标准操作的蜂窝无线收发器。
显示单元16,用于对处理器11发送过来的数据进行显示。
在一些实施例中,软件跨地域构建设备还可以包括传感器17,用于获取用户的体征数据、音频输出装置的加速度数据或者用于探测充电盒的盒盖开闭状态等。具体的,上述传感器17可以包括体征传感器、加速度传感器和接近开关等。
进一步的,本发明实施例还公开了一种计算机可读存储介质,用于存储计算机程序,其中,所述计算机程序被处理器执行时实现前述公开的软件跨地域构建方法的步骤。关于该方法的具体步骤可以参考前述实施例中公开的相应内容,在此不再进行赘述。
本发明利用本地的缓存空间保存与目标软件对应的全部源代码,进一步将临时目录中的源代码全部复制至用户构建目录,复制过程为本地传输,无需网络连接,能够具备较快传输速度,从而显著缩短软件跨地域构建时间,并提升工作效率,节省人力资源。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。
专业人员还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。
以上对本发明所提供的软件跨地域构建方法、装置、设备及介质进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (9)
1.一种软件跨地域构建方法,其特征在于,包括:
将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
2.根据权利要求1所述的软件跨地域构建方法,其特征在于,还包括:
创建临时代码目录;
将所述云端服务器发送的与所述目标软件对应的全部源代码复制至所述临时代码目录中。
3.根据权利要求1所述的软件跨地域构建方法,其特征在于,所述利用所述用户构建目录中的源代码进行全量编译处理,包括:
通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异;
如果是,则获取所述云端服务器发送的相应的第一增量代码,并利用所述用户构建目录中的源代码与所述第一增量代码进行全量编译处理;
如果否,则直接利用所述用户构建目录中的源代码进行全量编译处理。
4.根据权利要求3所述的软件跨地域构建方法,其特征在于,所述通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异,包括:
通过所述云端服务器比对当前所述云端服务器中与所述目标软件对应的全部源代码的版本号与所述用户构建目录中的源代码的版本号,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
5.根据权利要求3所述的软件跨地域构建方法,其特征在于,所述通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异,包括:
通过所述云端服务器直接比对当前所述云端服务器中与所述目标软件对应的全部源代码的内容与所述用户构建目录中的源代码的内容,判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述用户构建目录中的源代码之间是否存在差异。
6.根据权利要求1至5任一项所述的软件跨地域构建方法,其特征在于,还包括:
通过所述云端服务器判断当前所述云端服务器中与所述目标软件对应的全部源代码与所述临时代码目录中的源代码之间是否存在差异;
如果是,则获取所述云端服务器发送的相应的第二增量代码,并利用所述第二增量代码,完成所述临时代码目录与所述云端代码库的同步。
7.一种软件跨地域构建装置,其特征在于,包括:
代码复制模块,用于将临时代码目录中的源代码全部复制至用户构建目录;其中,所述临时代码目录用于预先保存云端服务器发送的与目标软件对应的全部源代码;
软件构建模块,用于利用所述用户构建目录中的源代码进行全量编译处理,完成所述目标软件的构建。
8.一种软件跨地域构建设备,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至6任一项所述软件跨地域构建方法的步骤。
9.一种计算机可读存储介质,其特征在于,用于存储计算机程序,其中,所述计算机程序被处理器执行时实现如权利要求1至6任一项所述软件跨地域构建方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810987601.4A CN108984183A (zh) | 2018-08-28 | 2018-08-28 | 一种软件跨地域构建方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810987601.4A CN108984183A (zh) | 2018-08-28 | 2018-08-28 | 一种软件跨地域构建方法、装置、设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108984183A true CN108984183A (zh) | 2018-12-11 |
Family
ID=64546636
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810987601.4A Pending CN108984183A (zh) | 2018-08-28 | 2018-08-28 | 一种软件跨地域构建方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108984183A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109669692A (zh) * | 2018-12-21 | 2019-04-23 | 深圳Tcl新技术有限公司 | 源码共享方法、服务器、计算机可读存储介质及系统 |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102520952A (zh) * | 2011-12-14 | 2012-06-27 | 北京佳讯飞鸿电气股份有限公司 | 软件代码版本自动构建及发布方法 |
US20150324183A1 (en) * | 2012-02-13 | 2015-11-12 | Microsoft Technology Licensing, Llc | Generating and caching software code |
US20150331689A1 (en) * | 2014-05-14 | 2015-11-19 | Western Digital Technologies, Inc. | Virtualized software build system |
CN105302554A (zh) * | 2015-10-23 | 2016-02-03 | 深圳市创维电器科技有限公司 | 一种Android系统自动化程序构建方法及系统 |
CN105404519A (zh) * | 2015-12-07 | 2016-03-16 | 青岛海信电器股份有限公司 | 一种版本控制方法、代码测试方法及系统 |
CN105511933A (zh) * | 2015-12-03 | 2016-04-20 | 深圳市创维软件有限公司 | 一种源代码的编译方法及相关设备 |
CN107479881A (zh) * | 2017-07-31 | 2017-12-15 | 武汉斗鱼网络科技有限公司 | 差异代码的同步方法、存储介质、电子设备及系统 |
CN107729066A (zh) * | 2017-11-08 | 2018-02-23 | 重庆扬讯软件技术股份有限公司 | 一种基于svn资源库自动化构建发布方法与装置 |
CN107844300A (zh) * | 2017-11-03 | 2018-03-27 | 中国银行股份有限公司 | 脚本处理方法及系统 |
CN107968807A (zh) * | 2016-10-20 | 2018-04-27 | 法乐第(北京)网络科技有限公司 | 自动更新本地缓存资源的方法及装置 |
CN108241555A (zh) * | 2016-12-26 | 2018-07-03 | 阿里巴巴集团控股有限公司 | 一种分布式数据库的备份、恢复方法、装置和服务器 |
CN108366085A (zh) * | 2017-12-01 | 2018-08-03 | 孔朝晖 | 支持桌面文件同步协同共享的云系统 |
-
2018
- 2018-08-28 CN CN201810987601.4A patent/CN108984183A/zh active Pending
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102520952A (zh) * | 2011-12-14 | 2012-06-27 | 北京佳讯飞鸿电气股份有限公司 | 软件代码版本自动构建及发布方法 |
US20150324183A1 (en) * | 2012-02-13 | 2015-11-12 | Microsoft Technology Licensing, Llc | Generating and caching software code |
US20150331689A1 (en) * | 2014-05-14 | 2015-11-19 | Western Digital Technologies, Inc. | Virtualized software build system |
CN105302554A (zh) * | 2015-10-23 | 2016-02-03 | 深圳市创维电器科技有限公司 | 一种Android系统自动化程序构建方法及系统 |
CN105511933A (zh) * | 2015-12-03 | 2016-04-20 | 深圳市创维软件有限公司 | 一种源代码的编译方法及相关设备 |
CN105404519A (zh) * | 2015-12-07 | 2016-03-16 | 青岛海信电器股份有限公司 | 一种版本控制方法、代码测试方法及系统 |
CN107968807A (zh) * | 2016-10-20 | 2018-04-27 | 法乐第(北京)网络科技有限公司 | 自动更新本地缓存资源的方法及装置 |
CN108241555A (zh) * | 2016-12-26 | 2018-07-03 | 阿里巴巴集团控股有限公司 | 一种分布式数据库的备份、恢复方法、装置和服务器 |
CN107479881A (zh) * | 2017-07-31 | 2017-12-15 | 武汉斗鱼网络科技有限公司 | 差异代码的同步方法、存储介质、电子设备及系统 |
CN107844300A (zh) * | 2017-11-03 | 2018-03-27 | 中国银行股份有限公司 | 脚本处理方法及系统 |
CN107729066A (zh) * | 2017-11-08 | 2018-02-23 | 重庆扬讯软件技术股份有限公司 | 一种基于svn资源库自动化构建发布方法与装置 |
CN108366085A (zh) * | 2017-12-01 | 2018-08-03 | 孔朝晖 | 支持桌面文件同步协同共享的云系统 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109669692A (zh) * | 2018-12-21 | 2019-04-23 | 深圳Tcl新技术有限公司 | 源码共享方法、服务器、计算机可读存储介质及系统 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101821693B1 (ko) | 로밍 네트워크 액세스 방법 및 장치 | |
CN102609237B (zh) | 可扩展的随机数生成 | |
CN105677335B (zh) | 提高移动终端首次开机速度的方法及装置 | |
CN108536524A (zh) | 资源更新方法、装置、终端及存储介质 | |
EP3332309B1 (en) | Method and apparatus for facilitating a software update process over a network | |
CN102868732A (zh) | 一种基于账户密码的登录实现方法、系统及装置 | |
CN110334297A (zh) | 终端页面的加载方法、终端、服务器及存储介质 | |
CN103718164A (zh) | 虚拟计算机和服务 | |
KR101842558B1 (ko) | 로밍 네트워크 접속 방법 및 장치 | |
CN105323269A (zh) | 安卓系统中app的更新方法、终端及存储介质 | |
CN103645923B (zh) | 一种插件安装方法及系统 | |
KR102276795B1 (ko) | 블록체인 기반의 무선 충전을 위한 방법 및 이 방법을 수행하는 프로그램이 기록된 컴퓨터 판독 가능한 기록매체 | |
CN106713662A (zh) | 定位系统性能的优化方法、装置及移动终端 | |
CN105159728A (zh) | 一种基于android系统的获取NTP时间信息的方法和装置 | |
CN105765533A (zh) | 用于固件虚拟化的方法和装置 | |
Dong et al. | Optimizing relocatable code for efficient software update in networked embedded systems | |
CN107005586A (zh) | 一种管理虚拟网络功能的方法和装置 | |
CN109191078A (zh) | 一种流程业务建模方法、装置及设备 | |
CN108984183A (zh) | 一种软件跨地域构建方法、装置、设备及存储介质 | |
US10671366B2 (en) | App program running method and apparatus | |
CN106293814B (zh) | 升级方法及装置 | |
CN110609967A (zh) | 一种榜单生成方法、装置及存储介质 | |
CN111131373B (zh) | 呼吸机数据同步系统、方法、装置及存储介质 | |
WO2011143851A1 (zh) | 数据库服务器操作控制系统、方法及设备 | |
CN104869531B (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20181211 |