[发明专利]文件写入方法、装置、计算机设备及存储介质在审
| 申请号: | 202211105862.1 | 申请日: | 2022-09-09 |
| 公开(公告)号: | CN116303273A | 公开(公告)日: | 2023-06-23 |
| 发明(设计)人: | 刘启;郑明钟 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
| 主分类号: | G06F16/16 | 分类号: | G06F16/16;G06F9/48 |
| 代理公司: | 深圳市力道知识产权代理事务所(普通合伙) 44507 | 代理人: | 黄嘉嘉 |
| 地址: | 518057 广东省深圳市福田区福*** | 国省代码: | 广东;44 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 文件 写入 方法 装置 计算机 设备 存储 介质 | ||
本申请提供一种文件写入方法、装置、计算机设备及存储介质,方法包括:通过至少一个第一线程,从数据库中获取第一数据信息;当第一有界阻塞队列中存在剩余空间时,将第一数据信息存储于剩余空间内,作为第二数据信息;通过一个第二线程,读取第二数据信息,并将第二数据信息写入文件中;在第一预设时间段内,若第二数据信息无法写入文件中时,将第二数据信息存储于预设的第二有界阻塞队列中。本申请通过多个第一线程并行从数据库中获取第一数据信息并存入至第一有界阻塞队列中得到第二数据信息,提高了数据的获取速率,通过一个线程将第二数据信息写入第二有界阻塞队列中,避免多个线程处理速度不一致,导致整个业务流程缓慢的问题。
技术领域
本申请涉及写入文件领域,尤其涉及一种文件写入方法、装置、计算机设备及存储介质。
背景技术
在业务的日常处理中,工作人员经常使用文件和上下游系统进行交互。目前,随着业务的发展和业务的演变,上下游之间所传输的文件都有着比较强的时效性要求,这就导致在生产文件时,必须足够的稳定并且具有较高的速率。因此,就需要有能够快速的写入文件的解决方案。
例如,目前常用的处理方法是对业务数据进行拆分处理,把业务数据文件拆分多个模块,然后启用多线程并发进行写入处理。该方案的不足之处包括:拆分后的数据模块可能分布不均匀,各线程处理进度可能不一至,会有由于某一线程处理比较慢,导致整个业务流程缓慢。
发明内容
本申请提供了一种文件写入方法、装置、计算机设备及存储介质,旨在提高的写入文件效率。
第一方面,本申请提供一种文件写入方法,所述文件写入方法包括以下步骤:
通过至少一个第一线程,从数据库中获取第一数据信息;
当预设的第一有界阻塞队列中存在剩余空间时,将所述第一数据信息存储于所述剩余空间内,作为第二数据信息;
通过一个第二线程,读取所述第二数据信息,并将所述第二数据信息写入文件中;
在第一预设时间段内,若所述第二数据信息无法写入文件中时,将所述第二数据信息存储于预设的第二有界阻塞队列中,实现文件写入。
本申请用于通过多个第一线程并行从数据库中获取第一数据信息并存入至第一有界阻塞队列中得到第二数据信息,提高了数据的获取速率,然后再通过一个第二线程将第二数据信息写入第二有界阻塞队列中,因为第二线程的数量仅为一个,这样可以避免多个线程处理速度不一致,导致整个业务流程缓慢的问题,从而在第一数据信息读取、第二数据信息写入两个阶段都可以节省时间,有效地提高了写入文件的效率。
第二方面,本申请还提供一种文件写入装置,所述文件写入装置包括:
获取模块,用于通过至少一个第一线程,从数据库中获取第一数据信息;
第一存储模块,用于当预设的第一有界阻塞队列中存在剩余空间时,将所述第一数据信息存储于所述剩余空间内,作为第二数据信息;
写入模块,用于通过一个第二线程,读取所述第二数据信息,并将所述第二数据信息写入文件中;
第二存储模块,用于在第一预设时间段内,若所述第二数据信息无法写入文件中时,将所述第二数据信息存储于预设的第二有界阻塞队列中。
第三方面,本申请还提供一种计算机设备,所述计算机设备包括处理器、存储器、以及存储在所述存储器上并可被所述处理器执行的计算机程序,其中所述计算机程序被所述处理器执行时,实现如上述的文件写入方法的步骤。
第四方面,本申请还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,其中所述计算机程序被处理器执行时,实现如上述的文件写入方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202211105862.1/2.html,转载请声明来源钻瓜专利网。





