CN111241594A - 交易信息的加签方法、装置、计算机设备和存储介质 - Google Patents
交易信息的加签方法、装置、计算机设备和存储介质 Download PDFInfo
- Publication number
- CN111241594A CN111241594A CN202010011301.XA CN202010011301A CN111241594A CN 111241594 A CN111241594 A CN 111241594A CN 202010011301 A CN202010011301 A CN 202010011301A CN 111241594 A CN111241594 A CN 111241594A
- Authority
- CN
- China
- Prior art keywords
- signing
- target
- transaction
- tagging
- mode
- 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.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/64—Protecting data integrity, e.g. using checksums, certificates or signatures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
- G06Q40/04—Trading; Exchange, e.g. stocks, commodities, derivatives or currency exchange
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Finance (AREA)
- Accounting & Taxation (AREA)
- Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Economics (AREA)
- Software Systems (AREA)
- General Health & Medical Sciences (AREA)
- Bioethics (AREA)
- Health & Medical Sciences (AREA)
- Development Economics (AREA)
- General Engineering & Computer Science (AREA)
- Marketing (AREA)
- Strategic Management (AREA)
- Technology Law (AREA)
- General Business, Economics & Management (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
本申请公开了一种基于区块链的高并发交易信息的加签方法,涉及区块链技术领域,所述方法包括:当检测到加签功能启动时,获取系统的CPU使用情况;根据所述CPU使用情况得到对应的目标加签方式;获取目标交易对应的交易结果信息,并基于所述交易结果信息得到对应的加签信息;根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信息进行加签处理。本申请还提供一种基于区块链的高并发交易信息的加签装置、计算机设备和存储介质。基于本申请所描述的实现方式,提高了高并发加签处理的稳定性以及系统CPU的使用率。
Description
技术领域
本申请涉及区块链技术领域,尤其涉及一种基于区块链的高并发交易信 息的加签方法、基于区块链的高并发交易信息的加签装置、计算机设备和存 储有计算机可读指令的存储介质。
背景技术
区块链一般被理解为一个分布式账本,它的本质也是一个分布式的数据 库。在现有的产品中,由于golang语言具有开发效率高和使用简单等特点, 很多的区块链系统中便将golang语言作为开发语言。
在区块链系统中,通常存在高并发的任务或者进程需要运行,比如对交 易结果信息进行加签处理,在出现需要进行高并发的加签验签时,由于golang 语言的轻量级线程以及垃圾回收管理机制的特点,使得系统的CPU使用率一 直处于以及较低的状态。同时在进行加签处理时,因为内存垃圾需要进行回 收,使得可能需要将当前执行加签处理的线程进行暂停,影响整体的加签验 签效率。
发明内容
本申请提供一种基于区块链的高并发交易信息的加签方法、装置、计算 机设备和存储介质,用于提高进行高并发加签处理操作的稳定性以及系统 CPU的使用率。
第一方面,本申请提供的一种基于区块链的高并发交易信息的加签方法, 所述基于区块链的高并发交易信息的加签方法包括:
当检测到加签功能启动时,获取系统的CPU使用情况;
根据所述CPU使用情况得到对应的目标加签方式;
获取目标交易对应的交易结果信息,并基于所述交易结果信息得到对应 的加签信息;
根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信 息进行加签处理。
第二方面,本申请还提供一种基于区块链的高并发交易信息的加签装置, 所述基于区块链的高并发交易信息的加签装置包括:
状态获取模块,用于当检测到加签功能启动时,获取系统的CPU使用情 况;
方式确定模块,用于根据所述CPU使用情况得到对应的目标加签方式;
信息生成模块,用于获取目标交易对应的交易结果信息,并基于所述交 易结果信息得到对应的加签信息;
加签处理模块,用于根据所述加签信息以及所述目标加签方式对所述目 标交易对应的交易信息进行加签处理。
第三方面,本申请还提供一种计算机设备,包括存储器和处理器,所述 存储器中存储有计算机可读指令,所述计算机可读指令被所述处理器执行时, 使得所述处理器执行上述基于区块链的高并发交易信息的加签方法的步骤。
第四方面,本申请还提供一种存储有计算机可读指令的存储介质,所述 计算机可读指令被一个或多个处理器执行时,使得一个或多个处理器执行上 述基于区块链的高并发交易信息的加签方法的步骤。
本申请公开的一种区块链的高并发交易信息的加签方法、装置、计算机 设备和存储介质,在检测到加签功能启动时,获取系统的CPU使用情况,进 而根据系统的CPU系统使用情况确定进行加签处理的目标加签方式,然后在 确定了进行加签处理的目标加签方式之后,获取目标交易对应的交易结果信 息,最后利用目标加签方式以及根据交易结果信息所得到的进行加签处理的 加签信息对交易信息进行相应的加签处理。实现在对高并发交易信息进行加 签处理时,通过对系统的CPU使用情况进行监控,并根据系统的CPU使用情况确定当前进行加签处理的加签方式,保证加签过程不受其他的影响,可以 正常完成加签操作,提了高并发加签处理的稳定性以及系统CPU的使用率。
附图说明
为了更清楚地说明本申请实施例技术方案,下面将对实施例描述中所需 要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本申请的一 些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下, 还可以根据这些附图获得其他的附图。
图1为本申请一个实施例中基于区块链的高并发交易信息的加签方法的 流程示意图;
图2为本申请一个实施例中确定是否变更默认加签方式的步骤的流程示 意图;
图3为本申请另一个实施例中基于区块链的高并发交易信息的加签方法 的流程示意图;
图4为本申请一个实施例中基于区块链的高并发交易信息的加签装置的 结构框图;
图5为本申请一个实施例中方式确定模块的结构框图;
图6为本申请另一个实施例中基于区块链的高并发交易信息的加签装置 的结构框图;
图7为本申请又一个实施例中基于区块链的高并发交易信息的加签装置 的结构框图;
图8为本申请一个实施例中计算机设备的结构示意性框图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行 清楚、完整地描述,显然,所描述的实施例是本申请一部分实施例,而不是 全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创 造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
附图中所示的流程图仅是示例说明,不是必须包括所有的内容和操作/步 骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解、组 合或部分合并,因此实际执行的顺序有可能根据实际情况改变。
应当理解,在此本申请说明书中所使用的术语仅仅是出于描述特定实施 例的目的而并不意在限制本申请。如在本申请说明书和所附权利要求书中所 使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一 个”及“该”意在包括复数形式。
还应当进理解,在本申请说明书和所附权利要求书中使用的术语“和/或” 是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包 括这些组合。
下面结合附图,对本申请的一些实施方式作详细说明。在不冲突的情况 下,下述的实施例及实施例中的特征可以相互组合。
参照图1,图1为本申请一个实施例中基于区块链的高并发交易信息的加 签方法的流程示意图。
具体地,该基于区块链的高并发交易信息的加签方法包括:
步骤S10、当检测到加签功能启动时,获取系统的CPU使用情况。
在进行交易过程中,为了保证交易信息的安全可靠性,通常需要对交易 信息进行相应的加密处理,以保证交易信息的安全。具体地,在检测到加签 功能启动时,将会获取系统的CPU使用情况,进而根据系统的CPU的实际使用 情况对当前进行交易的交易信息进行相应的加签处理。
在fimax区块链的开发中,所使用的基本的默认语言是golang语言,因此 在对交易信息进行加签处理时,一般情况下也将是利用golang语言对交易信息 进行加签处理。对于golang语言来说,其具有轻量级线程和垃圾回收管理机制 两大特征机制,使得在利用默认的golang语言进行加签处理时,无论线程是否 需要更多的CPU时间片,其都会进行切换,导致了每个线程并不能获取到更 多的CPU时间片,不能更大效率的使用CPU,大部分CPU时间片浪费在切换线 程机制中。
步骤S20、根据所述CPU使用情况得到对应的目标加签方式。
在得到系统的CPU使用情况之后,根据CPU使用情况得到对应的目标加签 方式。由于不同的加签方式所适用的场景不同,或者说不同情况下使用不同 的加签方式的效果有所不同,比如加签效率高、加签成功率高等,因此在选 择对应的加签方式时,根据实际的CPU使用情况来确定当前进行加签处理的 方式,进而更好的完成加签操作。
在fimax区块链的开发中,在进行加签处理时是基于golang语言对交易信 息进行加签处理,但是在实际应用时,由于golang语言本身的特征,使得有一 些情况不适合基于golang语言进行加签处理,比如在系统的CPU的使用率较高 时,由于在fimax区块链的系统中,系统会进行线程的切换,使得当前所进行 的加签过程会被中断,使得加签过程不能很好的完成。
另外,在实际进行加签处理时,存在进行加签方式切换的情况,对于fimax 区块链系统而言,所使用的默认加签方式是利用golang语言进行加签处理,在 系统不可以使用默认的语言完成加签处理时,需要进行加签方式的切换,以 在切换加签方式之后进行加签处理。
进一步地,在根据CPU使用情况得到对应的目标加签方式,包括:
根据CPU使用情况确定是否变更默认加签方式,以得到对应的目标加签 方式;若确定不变更默认加签方式,则目标加签方式为默认加签方式;若确 定变更默认加签方式,则目标加签方式为变更后的加签方式。
在根据系统的CPU使用情况得到对应的目标加签方式时,主要根据系统 CPU使用率的高低来确定当前进行加签处理的目标加签方式,在系统的CPU 使用情况较低和CPU使用情况较高的时候对应的加签方式会有所不同。对于 系统的CPU使用率而言,在系统CPU使用率较低时,可以使用系统默认的加签 方式进行加签处理,在系统CPU使用率较高时,将需要进行进行加签方式的 切换。
步骤S30、获取目标交易对应的交易结果信息,并基于所述交易结果信息 得到对应的加签信息。
在得到进行加签处理的目标加签方式时,获取目标交易对应的交易结果 信息,然后根据交易结果信息得到对应的加签信息,其中所得到的加签信息 包括有加签公钥和加签私钥,进而根据所得到的加签信息完成对目标交易所 对应的交易信息进行加签处理。
具体地,在进行加签处理时,需要有相应的加签信息,简单来说就是密 码,为了更好的保证加签信息的安全性,通常采用非对称加签的方式对交易 信息进行加签处理,对于进行加签处理的加签私钥和加密公钥,预先利用目 标交易对应的交易结果信息所得到。
在根据交易结果信息生成用于对所述目标交易进行保密传输处理的加签 私钥和加密公钥时,通过对交易结果信息进行解析以得到对应的加签私钥和 加密公钥,比如进行解析获取目标交易中的交易发起方的第一特征信息以及 交易接收方的第二特征信息,然后将第一特征信息作为用于对目标交易进行 保密传输处理的加签私钥,以及将第二特征信息作为用于对目标交易进行保 密传输处理的加密公钥。
目标交易对应的交易结果信息中会记录有交易的实际信息,包括交易时 间、交易发起方信息、交易接收方信息以及交易类型信息等,在实际应用中, 通常交易接收方是一个交易终端,所有人都可以与此交易终端进行交易,但 是由于交易发起方的不一样,使得加签私钥和加密公钥有所不同,可以更好 的保证加签的安全可靠。
步骤S40、基于所述加签私钥和加密公钥,利用所述目标加签方式对交易 信息进行加签处理。
在根据目标交易对应的交易结果得到进行加签处理的加签公钥和加签私 钥之后,将会利用加签公钥和加签私钥利用预先所得到的目标加签方式对交 易信息进行加签处理。具体地,在得到目标加签方式之后,将会根据所得到 的加签私钥和加密公钥利用目标加签方式对交易信息进行非对称加签处理。 在进行加签处理时,主要体现在不同的加签方式所适用的系统的CPU使用率 的高低不一样,进而可以更加快速准确的完成加签处理。
在上述基于区块链的高并发交易信息的加签方法中,在检测到加签功能 启动时,获取系统的CPU使用情况,进而根据系统的CPU系统使用情况确定进 行加签处理的目标加签方式,然后在确定了进行加签处理的目标加签方式之 后,获取目标交易对应的交易结果信息,最后利用目标加签方式以及根据交 易结果信息所得到的进行加签处理的加签信息对交易信息进行相应的加签处 理。实现在对高并发交易信息进行加签处理时,通过对系统的CPU使用情况 进行监控,并根据系统的CPU使用情况确定当前进行加签处理的加签方式,保证加签过程不受其他的影响,可以正常完成加签操作,提高了高并发加签 处理的稳定性以及系统CPU的使用率。
进一步地,参照图2,图2为本申请一个实施例中确定是否变更默认加签 方式的步骤的流程示意图。
具体地,在确定是否变更默认加签方式时包括:
步骤S21、读取所述系统的CPU总核数,并根据所述CPU使用情况以及所 述CPU总核数得到所述系统的CPU使用率。
步骤S22、将所述CPU使用率与CPU使用率阈值进行比较。
步骤S23、若所述CPU使用率小于所述CPU使用率阈值,则确定不变更默 认加签方式。
步骤S24、若所述CPU使用率大于或者等于所述CPU使用率阈值,则确定 变更默认加签方式。
其中,系统的CPU总核数系统中所有CPU的核数之和。CPU的核数是一块CPU上面能处理数据的芯片组的数量。
在得到系统的CPU的使用情况时,获取系统的CPU总核数,然后将CPU 使用情况与CPU总核数进行对比,得到对应的对应的CPU使用率,进而将CPU 使用率与对应的CPU使用率阈值进行比较,以根据比较结果确定是否需要进 行加签方式的变更。
比较结果用来确定系统的CPU使用率的高低,对应不同的系统的CPU使用 率会对应着不同的加签方式,用以提高系统CPU的使用率,保证在CPU使用率 达到一定的程度,但是并未饱和的情况下不进行线程的释放,同时保证可以 执行相应的操作指令。
在系统的CPU使用率较低时,即CPU使用率小于CPU使用率阈值时,那么 不需要进行加签方式的变更和切换,可以直接使用系统默认的加签方式对交 易结果信息进行加签处理,反之,则需要变更默认的加签方式,使用更加合 适的加签方式进行加签处理。
在得到CPU使用率时,将所得到的CPU使用率与对应的预设阈值进行比 较,以得到对应的目标加签方式,其中,CPU使用率阈值是CPU使用率的一个 临界值,且这个临界值的确定可以根据系统的实际运行来确定。在实际的系 统使用过程中,CPU使用率过高会影响系统的实际运行,在进行加签操作时, 由于受到golang语言的本身限制,且加签过程大部分由线程在运行,因此存在 加签过程并未完成便会对进行加签的线程进行释放,进而导致加签没有完成 需要使用另一线程接着进行加签处理,故而需要选择更加合适的加签方式。
在实际的加签过程中,不同的CPU使用率所对应的较为合适的加签方式 也是有所不同的,为了使得加签过程能够顺利准确的完成,需要有着更加合 适的加签方式。具体地,在CPU使用率较低时,采用任何一种加签方式都可 以,也就是并不会因为系统的实际运行而对加签过程或者系统的其他运行产 生影响,由于系统的默认使用语言为golang语言,且golang语言本身具有一定 的优点,那么此时可以直接使用golang语言进行加签处理,也就是不需要进行 语言切换即可顺利完成加签处理,但是在CPU使用率较高时,由于golang语言 的本身限制,则需要选择更为合理的加签方式进行加签处理。
在fimax区块链系统中,使用golang语言是看中了golang语言具有开发效率 高以及使用简单等特点。但是对于系统的使用而言,提高一定的工作效率必 定要做的,但是并不能忽略在提高工作效率的同时所带来的问题,比如系统 内存使用率不高,或者系统资源浪费等。在上述描述的实施例中,利用系统 CPU作为加签方式切换的判断依据,在保证系统运行正常以及不影响实际操 作的同时,选择更加合适的方式完成相应的加签处理,在一定程度上提高了 系统CPU的使用率。
进一步地,在一个实施例中,在确定需要变更默认加签方式时,需要进 行加签方式的切换和变更,此时将会在动态链接库中进行接口的调用,通过 调用目标加签方式所对应的接口,来实现对默认加签方式的切换变更。
具体地,预先可以设定相应的加签方式以适用于不同的场景需求,进而 在需要进行加签处理时,根据系统的实际运行场景和状态选择合适的加签方 式执行相应的加签操作。
在实际应用中,fimax区块链系统中所使用的默认加签方式是利用golang 语言对交易信息进行加签处理,为了实现加签方式的切换,在系统中设置相 应的接口地址,通过接口地址的获取实现加签方式的切换。根据golang语言在 系统运行中的不足,在进行加签方式的切换时,将加签方式切换为基于cgo技 术进行加签处理的加签方式。
在目标加签方式是使用cgo技术进行加签处理时,由于系统默认使用的是 golang语言进行系统运行,此时将会启动相应的调用程序进行语言调用,通过 调用C语言函数进行加签处理,也就是在需要使用cgo技术实现加签处理时, 需要进行接口的调用,在接口调用之后便可以使用cgo技术完成加签操作;在 目标加签方式是使用默认的golang语言进行加签处理时,利用语言内部自带的 线程调度机制使用相应的线程完成加签操作。
对于预先所设定的接口地址的数量可以是多个,也就是说,除了根据上 述描述设置一个接口地址之外,还可以根据实际的技术支持和场景或者运行 需求设定若干接口地址,同时对于不同的接口地址设定不同的调用条件,以 实现根据不同的需求选择不同的加签方式。
另外,在根据所得到的加签信息以及目标加签方式对目标交易对应的交 易信息进行加签处理之前,还包括:
在关联的动态链接库中获取相应的目标运行内存,并将与目标交易相关 联的数据导入至目标运行内存中,以在目标运行内存中对交易信息进行加签 处理,其中,与目标交易相关联的数据包括加签信息以及交易结果信息。以 及,获取进行加签处理的目标线程,并将所得到的目标线程标记为不可释放 状态,以基于目标线程对交易信息进行加签处理。
在进行接口调用之前,也就是进行系统构建或者管理时,预先使用C语言 实现一套内存池和C语言版本的加签验签算法,同时提供一个满足调用需求的 接口以供进行接口调用,然后进行包装形成动态链接库,在动态链接库中存 储有进行语言切换时的接口地址,通过获取接口地址实现语言的切换。在需 要进行接口调用时,使用cgo技术加载动态链接库,进而获取相应的接口地址, 以通过接口地址的切换实现语言切换。在需要高并发的加签操作时,即在短 时间内需要进行多次加签操作,首先在动态链接库中申请得到一块内存,也 就是目标运行内存,然后将进行加签操作的参数拷贝进该内存中,最后再调 用加签或者验签接口实现高并发。
在实际运行过程中,系统运行通常是处于高并发状态,即加签操作的触 发是短时间内多次且循环发生的,只是交易发起者不一样,在交易处于高并 发状态时,系统CPU使用率在一定程度上会处于一个比较高的状态,也就是 在进行加签处理时可能需要频繁的进行接口的调用,进而使用cgo技术实现加 签处理,对于系统而言,也会存在CPU使用率较低的时候,在使用率较低时, 将会使用默认的golang语言实现加签处理,由于存在加签方式的变化,因此还 可以根据CPU使用率对接口状态进行设定,避免频繁进行接口调用带来的运 行负担。
另外在实际的加签处理过程中,当目标加签方式是使用cgo技术进行加签 处理时,进行加签处理的线程处于不可释放状态,即在进行加签处理时该线 程将会被锁定,只有在加签完成之后才可进行线程的释放,然后其他的进程 可以使用此线程。而当目标加签方式是使用默认的golang语言进行加签处理 时,进行加签处理的线程处于可释放状态。
进一步地,参照图3,图3为本申请另一个实施例中基于区块链的高并发 交易信息的加签方法的流程示意图。
具体地,所述方法还包括:
步骤S50,当检测到线程释放指令时,获取待释放线程的状态信息。
步骤S60,根据所述状态信息确定是否对所述待释放线程进行释放。
步骤S70,若所述状态信息为可释放状态,则释放所述待释放线程。
步骤S80,若所述状态信息为不可释放状态,则将所述线程释放指令视为 无效指令。
在系统运行过程中,不同的操作和进程可以在不同的线程上实现,也就 是不同的线程执行着不同的进程。具体地,当检测到线程释放指令时,获取 待释放线程的状态信息,进而根据所得到的待释放线程的状态信息确定是否 可以对待释放线程进行释放。
在实际运行过程中,可能因为外界因素或者系统需求,需要对部分线程 进行释放,以使得系统可以运行其他的进程或者程序。在需要进行线程释放 时,除了系统运行负载较高需要进行释放之外,还可以能是golang语言自身的 性能所致。线程释放指令的触发可以是用户通过相应的操作而发出的,还可 以是系统根据系统自身的运行状态而发出的,具体不作限制。在检测到线程 释放指令时,将会获取需要进行释放的待释放线程的状态信息,其中状态信 息包括可释放状态以及不可释放状态,主要针对于不同的加签场景而得到的 状态信息。
在fimax区块链系统中,在对交易结果信息进行加签处理时,由于存在不 同的加签方式,并且不同的加签方式自身的限制,使得指令加签操作的线程 的状态信息有所不同,具体地,若所使用的加签方式是使用golang语言所完成 的方式,此时所使用的线程的状态信息为可释放状态,若所使用的加签方式 是使用cgo技术实现加签处理的方式,此时所使用的线程的状态信息为不可释 放状态。
在根据待释放线程的状态信息确定是否可以进行线程释放时,主要体现 在当前进行加签处理的方式是哪一种。由于在基于cgo技术实现加签处理时, 在进行加签处理时,会将当前所使用的线程进行锁定,也就是将当前所使用 的线程的状态信息标记为不可释放状态,然后在加签完成之后可以自动进行 线程释放。若当前所需要进行释放的线程正在执行基于cgo技术实现加签处理 的进程时,由于此时线程不可以进行释放,因此此时将会将所检测到的线程 释放指令视为无效指令,同时还可以发出相应的提示信息,比如当前线程不 可释放。
请参阅图4,图4为本申请一个实施例中基于区块链的高并发交易信息的 加签装置的结构框图,应用于执行前述的基于区块链的高并发交易信息的加 签方法。其中该基于区块链的高并发交易信息的加签装置可以配置与服务器。
如图4所示,该基于区块链的高并发交易信息的加签装置40包括:状态获 取模块41、方式确定模块42、信息生成模块43以及加签处理模块44。
状态获取模块41,用于当检测到加签功能启动时,获取系统的CPU使用 情况;
方式确定模块42,用于根据所述CPU使用情况得到对应的目标加签方式;
信息生成模块43,用于获取目标交易对应的交易结果信息,并基于所述 交易结果信息得到对应的加签信息;
加签处理模块44,用于根据所述加签信息以及所述目标加签方式对所述 目标交易对应的交易信息进行加签处理。
在一个实施例中,所述方式确定模块42具体还用于:
根据所述CPU使用情况确定是否变更默认加签方式,以得到对应的目标 加签方式;
若确定不变更默认加签方式,则所述目标加签方式为所述默认加签方式;
若确定变更默认加签方式,则所述目标加签方式为变更后的加签方式。
在一个实施例中,参照图5,图5为本申请一个实施例中方式确定模块的 结构框图。
具体地,所述方式确定模块42包括:信息读取单元421、比较判断单元422 以及结果确定单元423。
信息读取单元421,用于读取所述系统的CPU总核数,并根据所述CPU 使用情况以及所述CPU总核数得到所述系统的CPU使用率;
比较判断单元422,用于将所述CPU使用率与CPU使用率阈值进行比较;
结果确定单元423,用于若所述CPU使用率小于所述CPU使用率阈值, 则确定不变更默认加签方式;若所述CPU使用率大于或者等于所述CPU使用 率阈值,则确定变更默认加签方式。
在一个实施例中,参照图6,图6为本申请另一个实施例中基于区块链的 高并发交易信息的加签装置的结构框图。
具体地,所述基于区块链的高并发交易信息的加签装置40还包括:
接口调用模块45,用于在动态链接库中调用目标加签方式对应的接口, 以完成对默认加签方式的变更。
在一个实施例中,参照图7,图7为本申请又一个实施例中基于区块链的 高并发交易信息的加签装置的结构框图。
具体地,所述基于区块链的高并发交易信息的加签装置40还包括:
内存调用模块46,用于在所述动态链接库中获取相应的目标运行内存, 并将与所述目标交易相关联的数据导入至所述目标运行内存中,以在所述目 标运行内存中对所述交易信息进行加签处理,其中,与所述目标交易相关联 的数据包括所述交易结果信息以及所述加签信息。
在一个实施例中,所述基于区块链的高并发交易信息的加签装置40还包 括:
线程获取模块47,用于获取进行加签处理的目标线程,并将所述目标线 程标记为不可释放状态,以基于所述目标线程对所述交易信息进行加签处理。
需要说明的是,所属领域的技术人员可以清楚地了解到,为了描述的方 便和简洁,上述描述的装置和各模块的具体工作过程,可以参考前述方法实 施例中的对应过程,在此不再赘述。
上述的装置可以实现为一种计算机程序的形式,该计算机程序可以在如 图8所示的计算机设备上运行。
请参阅图8,图8为本申请一个实施例中计算机设备的结构示意性框图。 该计算机设备可以是服务器。
参阅图8,该计算机设备包括通过系统总线连接的处理器、存储器和网络 接口,其中,存储器可以包括非易失性存储介质和内存储器。
非易失性存储介质可存储操作系统和计算机程序。该计算机程序包括程 序指令,该程序指令被执行时,可使得处理器执行任意一种基于区块链的高 并发交易信息的加签方法。
处理器用于提供计算和控制能力,支撑整个计算机设备的运行。
内存储器为非易失性存储介质中的计算机程序的运行提供环境,该计算 机程序被处理器执行时,可使得处理器执行任意一种基于区块链的高并发交 易信息的加签方法。
该网络接口用于进行网络通信,如发送分配的任务等。本领域技术人员 可以理解,图8中示出的结构,仅仅是与本申请方案相关的部分结构的框图, 并不构成对本申请方案所应用于其上的计算机设备的限定,具体的计算机设 备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不 同的部件布置。
应当理解的是,处理器可以是中央处理单元(Central Processing Unit, CPU),该处理器还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、 现场可编程门阵列(Field-Programmable GateArray,FPGA)或者其他可编程 逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理 器可以是微处理器或者该处理器也可以是任何常规的处理器等。
其中,在一个实施例中,所述处理器用于运行存储在存储器中的计算机 程序,以实现如下步骤:
当检测到加签功能启动时,获取系统的CPU使用情况;
根据所述CPU使用情况得到对应的目标加签方式;
获取目标交易对应的交易结果信息,并基于所述交易结果信息得到对应 的加签信息;
根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信 息进行加签处理。
在一个实施例中,所述处理器在实现所述根据所述CPU使用情况得到对 应的目标加签方式时,还用于实现:
根据所述CPU使用情况确定是否变更默认加签方式,以得到对应的目标 加签方式;
若确定不变更默认加签方式,则所述目标加签方式为所述默认加签方式;
若确定变更默认加签方式,则所述目标加签方式为变更后的加签方式。
在一个实施例中,所述处理器执行所述根据所述CPU使用情况确定是否 变更默认加签方式时,还用于实现:
读取所述系统的CPU总核数,并根据所述CPU使用情况以及所述CPU 总核数得到所述系统的CPU使用率;
将所述CPU使用率与CPU使用率阈值进行比较;
若所述CPU使用率小于所述CPU使用率阈值,则确定不变更默认加签方 式;
若所述CPU使用率大于或者等于所述CPU使用率阈值,则确定变更默认加 签方式。
在一个实施例中,所述处理器执行所述若所述CPU使用率大于或者等于 所述CPU使用率阈值,则确定变更默认加签方式之后,还用于实现:
在动态链接库中调用目标加签方式对应的接口,以完成对默认加签方式 的变更。
在一个实施例中,所述处理器执行所述根据所述加签信息以及所述目标 加签方式对所述目标交易对应的交易信息进行加签处理之前,还用于实现:
在所述动态链接库中获取相应的目标运行内存,并将与所述目标交易相 关联的数据导入至所述目标运行内存中,以在所述目标运行内存中对所述交 易信息进行加签处理,其中,与所述目标交易相关联的数据包括所述交易结 果信息以及所述加签信息。
在一个实施例中,所述处理器执行所述根据所述加签信息以及所述目标 加签方式对所述目标交易对应的交易信息进行加签处理之前,还用于实现:
获取进行加签处理的目标线程,并将所述目标线程标记为不可释放状态, 以基于所述目标线程对所述交易信息进行加签处理。
在一个实施例中,所述处理器执行所述计算机程序时还实现以下步骤:
当检测到线程释放指令时,获取待释放线程的状态信息;
根据所述状态信息确定是否对所述待释放线程进行释放;
若所述状态信息为可释放状态,则释放所述待释放线程;
若所述状态信息为不可释放状态,则将所述线程释放指令视为无效指令。
本申请的实施例中还提供一种计算机可读存储介质,所述计算机可读存 储介质存储有计算机程序,所述计算机程序中包括程序指令,所述处理器执 行所述程序指令,实现本申请实施例提供的任一项基于区块链的高并发交易 信息的加签方法。
其中,所述计算机可读存储介质可以是前述实施例所述的计算机设备的 内部存储单元,例如所述计算机设备的硬盘或内存。所述计算机可读存储介 质也可以是所述计算机设备的外部存储设备,例如所述计算机设备上配备的 插接式硬盘,智能存储卡(SmartMedia Card,SMC),安全数字(Secure Digital, SD)卡,闪存卡(Flash Card)等。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限 于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易 想到各种等效的修改或替换,这些修改或替换都应涵盖在本申请的保护范围 之内。因此,本申请的保护范围应以权利要求的保护范围为准。
Claims (10)
1.一种基于区块链的高并发交易信息的加签方法,其特征在于,所述方法包括:
当检测到加签功能启动时,获取系统的CPU使用情况;
根据所述CPU使用情况得到对应的目标加签方式;
获取目标交易对应的交易结果信息,并基于所述交易结果信息得到对应的加签信息;
根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信息进行加签处理。
2.根据权利要求1所述的方法,其特征在于,所述根据所述CPU使用情况得到对应的目标加签方式,包括:
根据所述CPU使用情况确定是否变更默认加签方式,以得到对应的目标加签方式;
若确定不变更默认加签方式,则所述目标加签方式为所述默认加签方式;
若确定变更默认加签方式,则所述目标加签方式为变更后的加签方式。
3.根据权利要求2所述的方法,其特征在于,所述根据所述CPU使用情况确定是否变更默认加签方式,包括:
读取所述系统的CPU总核数,并根据所述CPU使用情况以及所述CPU总核数得到所述系统的CPU使用率;
将所述CPU使用率与CPU使用率阈值进行比较;
若所述CPU使用率小于所述CPU使用率阈值,则确定不变更默认加签方式;
若所述CPU使用率大于或者等于所述CPU使用率阈值,则确定变更默认加签方式。
4.根据权利要求3所述的方法,其特征在于,所述若所述CPU使用率大于或者等于所述CPU使用率阈值,则确定变更默认加签方式之后,还包括:
在动态链接库中调用目标加签方式对应的接口,以完成对默认加签方式的变更。
5.根据权利要求4所述的方法,其特征在于,所述根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信息进行加签处理之前,该方法还包括:
在所述动态链接库中获取相应的目标运行内存,并将与所述目标交易相关联的数据导入至所述目标运行内存中,以在所述目标运行内存中对所述交易信息进行加签处理,其中,与所述目标交易相关联的数据包括所述交易结果信息以及所述加签信息。
6.根据权利要求1所述的方法,其特征在于,所述根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信息进行加签处理之前,该方法还包括:
获取进行加签处理的目标线程,并将所述目标线程标记为不可释放状态,以基于所述目标线程对所述交易信息进行加签处理。
7.根据权利要求1至6中任一项所述的基于区块链的高并发交易信息的加签方法,其特征在于,所述方法还包括:
当检测到线程释放指令时,获取待释放线程的状态信息;
根据所述状态信息确定是否对所述待释放线程进行释放;
若所述状态信息为可释放状态,则释放所述待释放线程;
若所述状态信息为不可释放状态,则将所述线程释放指令视为无效指令。
8.一种基于区块链的高并发交易信息的加签装置,其特征在于,所述装置包括:
状态获取模块,用于当检测到加签功能启动时,获取系统的CPU使用情况;
方式确定模块,用于根据所述CPU使用情况得到对应的目标加签方式;
信息生成模块,用于获取目标交易对应的交易结果信息,并基于所述交易结果信息得到对应的加签信息;
加签处理模块,用于根据所述加签信息以及所述目标加签方式对所述目标交易对应的交易信息进行加签处理。
9.一种计算机设备,其特征在于,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述计算机可读指令被所述处理器执行时,使得所述处理器执行如权利要求1至7中任一项所述基于区块链的高并发交易信息的加签方法的步骤。
10.一种存储有计算机可读指令的存储介质,其特征在于,所述计算机可读指令被一个或多个处理器执行时,使得一个或多个处理器执行如权利要求1至7中任一项所述基于区块链的高并发交易信息的加签方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010011301.XA CN111241594B (zh) | 2020-01-06 | 2020-01-06 | 交易信息的加签方法、装置、计算机设备和存储介质 |
PCT/CN2020/099311 WO2021139113A1 (zh) | 2020-01-06 | 2020-06-30 | 交易信息的加签方法、装置、计算机设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010011301.XA CN111241594B (zh) | 2020-01-06 | 2020-01-06 | 交易信息的加签方法、装置、计算机设备和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111241594A true CN111241594A (zh) | 2020-06-05 |
CN111241594B CN111241594B (zh) | 2023-10-13 |
Family
ID=70866349
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010011301.XA Active CN111241594B (zh) | 2020-01-06 | 2020-01-06 | 交易信息的加签方法、装置、计算机设备和存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN111241594B (zh) |
WO (1) | WO2021139113A1 (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2021139113A1 (zh) * | 2020-01-06 | 2021-07-15 | 平安科技(深圳)有限公司 | 交易信息的加签方法、装置、计算机设备和存储介质 |
CN114979151A (zh) * | 2022-07-27 | 2022-08-30 | 江苏中创供应链服务有限公司 | 一种跨境电商动态调整加签服务的方法 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102053859A (zh) * | 2009-11-09 | 2011-05-11 | 中国移动通信集团甘肃有限公司 | 批量数据处理的方法与装置 |
CN107729137A (zh) * | 2017-09-04 | 2018-02-23 | 上海壹账通金融科技有限公司 | 服务器、区块链验签解密的方法及存储介质 |
US20180096042A1 (en) * | 2016-10-04 | 2018-04-05 | International Business Machines Corporation | Distribution of Software Signatures Using a Community Catalog Based on Blockchain |
WO2018137564A1 (zh) * | 2017-01-26 | 2018-08-02 | 阿里巴巴集团控股有限公司 | 一种业务处理方法及装置 |
CN109523385A (zh) * | 2018-12-07 | 2019-03-26 | 深圳市智税链科技有限公司 | 在区块链网络中查询交易信息的方法、记账节点和介质 |
CN109522698A (zh) * | 2018-10-11 | 2019-03-26 | 平安科技(深圳)有限公司 | 基于区块链的用户认证方法及终端设备 |
CN109614206A (zh) * | 2018-10-25 | 2019-04-12 | 深圳壹账通智能科技有限公司 | 区块链事务处理的装置、方法及存储介质 |
WO2019217729A1 (en) * | 2018-05-10 | 2019-11-14 | Alibaba Group Holding Limited | Blockchain data processing methods, apparatuses, processing devices, and systems |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10891383B2 (en) * | 2015-02-11 | 2021-01-12 | British Telecommunications Public Limited Company | Validating computer resource usage |
CN107833139B (zh) * | 2017-11-23 | 2021-08-24 | 深圳壹账通智能科技有限公司 | 交易数据处理方法、装置、计算机设备及存储介质 |
CN108830716B (zh) * | 2018-05-31 | 2021-12-17 | 上海万向区块链股份公司 | 基于区块链和加密处理的保护用户隐私的交易系统 |
CN110400223B (zh) * | 2019-07-26 | 2022-05-17 | 中国工商银行股份有限公司 | 基于区块链的交互日志加密、调取、防窃取方法、装置 |
CN111241594B (zh) * | 2020-01-06 | 2023-10-13 | 平安科技(深圳)有限公司 | 交易信息的加签方法、装置、计算机设备和存储介质 |
-
2020
- 2020-01-06 CN CN202010011301.XA patent/CN111241594B/zh active Active
- 2020-06-30 WO PCT/CN2020/099311 patent/WO2021139113A1/zh active Application Filing
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102053859A (zh) * | 2009-11-09 | 2011-05-11 | 中国移动通信集团甘肃有限公司 | 批量数据处理的方法与装置 |
US20180096042A1 (en) * | 2016-10-04 | 2018-04-05 | International Business Machines Corporation | Distribution of Software Signatures Using a Community Catalog Based on Blockchain |
WO2018137564A1 (zh) * | 2017-01-26 | 2018-08-02 | 阿里巴巴集团控股有限公司 | 一种业务处理方法及装置 |
CN107729137A (zh) * | 2017-09-04 | 2018-02-23 | 上海壹账通金融科技有限公司 | 服务器、区块链验签解密的方法及存储介质 |
WO2019217729A1 (en) * | 2018-05-10 | 2019-11-14 | Alibaba Group Holding Limited | Blockchain data processing methods, apparatuses, processing devices, and systems |
CN109522698A (zh) * | 2018-10-11 | 2019-03-26 | 平安科技(深圳)有限公司 | 基于区块链的用户认证方法及终端设备 |
CN109614206A (zh) * | 2018-10-25 | 2019-04-12 | 深圳壹账通智能科技有限公司 | 区块链事务处理的装置、方法及存储介质 |
CN109523385A (zh) * | 2018-12-07 | 2019-03-26 | 深圳市智税链科技有限公司 | 在区块链网络中查询交易信息的方法、记账节点和介质 |
Non-Patent Citations (2)
Title |
---|
许重建;李险峰;: "区块链交易数据隐私保护方法", 计算机科学, no. 03 * |
邓小鸿;朱年红;黄磊;王智强;王俊彬;: "基于区块链的身份托管模型研究", 计算机工程与应用, no. 04 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2021139113A1 (zh) * | 2020-01-06 | 2021-07-15 | 平安科技(深圳)有限公司 | 交易信息的加签方法、装置、计算机设备和存储介质 |
CN114979151A (zh) * | 2022-07-27 | 2022-08-30 | 江苏中创供应链服务有限公司 | 一种跨境电商动态调整加签服务的方法 |
CN114979151B (zh) * | 2022-07-27 | 2022-11-11 | 江苏中创供应链服务有限公司 | 一种跨境电商动态调整加签服务的方法 |
Also Published As
Publication number | Publication date |
---|---|
CN111241594B (zh) | 2023-10-13 |
WO2021139113A1 (zh) | 2021-07-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109951547B (zh) | 事务请求并行处理方法、装置、设备和介质 | |
US20190324772A1 (en) | Method and device for processing smart contracts | |
US20060168435A1 (en) | Operating-system-friendly bootloader | |
CN110928653B (zh) | 跨集群任务的执行方法、装置、计算机设备和存储介质 | |
CN110704177B (zh) | 计算任务处理方法、装置、计算机设备和存储介质 | |
CN111538659B (zh) | 业务场景的接口测试方法、系统、电子设备和存储介质 | |
CN107479981B (zh) | 一种基于异步调用实现同步调用的处理方法及装置 | |
CN111241594B (zh) | 交易信息的加签方法、装置、计算机设备和存储介质 | |
CN113190427B (zh) | 卡顿监控方法、装置、电子设备及存储介质 | |
CN112799791A (zh) | 分布式锁的调用方法、装置、电子设备和存储介质 | |
US20060195732A1 (en) | Method and system for executing test cases for a device under verification | |
CN105871960B (zh) | 调用数据共享的方法、装置及设备 | |
CN112181388B (zh) | Sdk组件的初始化方法、装置、存储介质及控制终端 | |
US9842018B2 (en) | Method of verifying integrity of program using hash | |
CN114691241B (zh) | 任务执行方法、装置、电子设备及存储介质 | |
CN111259299A (zh) | 数据处理方法、装置、计算机设备和存储介质 | |
CN113704107B (zh) | 应用测试方法、装置、设备及计算机可读存储介质 | |
CN115269117A (zh) | 一种资源创建方法、装置、计算机设备及存储介质 | |
CN111261206B (zh) | 一种读写方法、装置和电子设备及可读存储介质 | |
CN114489956A (zh) | 一种基于云平台的实例启动方法及装置 | |
CN114327673A (zh) | 一种任务启动方法、装置、电子设备及存储介质 | |
EP3244340A1 (en) | Method for securely running an application | |
CN109618121A (zh) | 视频会议信息安全的处理方法及装置 | |
CN105988804B (zh) | 一种软件转移方法及终端 | |
US20230237010A1 (en) | Power efficient memory value updates for arm architectures |
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 |