[发明专利]一种共享文件系统的访问方法、装置及设备在审
申请号: | 201811528511.5 | 申请日: | 2018-12-13 |
公开(公告)号: | CN109344136A | 公开(公告)日: | 2019-02-15 |
发明(设计)人: | 戚勇;吕玉彬;李佩 | 申请(专利权)人: | 浪潮(北京)电子信息产业有限公司 |
主分类号: | G06F16/176 | 分类号: | G06F16/176;G06F9/50 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 罗满 |
地址: | 100085 北京市海*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 共享文件系统 访问 装置及设备 访问装置 费用成本 节点访问 进程分配 数据泄露 访问量 数据块 | ||
本发明公开了一种共享文件系统的访问方法,在各个节点预访问共享文件系统时,只有为各节点的预访问进程分配了锁模式后,才允许各个节点访问共享文件系统,避免了共享文件系统中的数据块遭到恶意访问时引起数据泄露,共享文件系统中的数据的安全性较高,且避免了各个节点都访问共享文件系统时造成共享文件系统的访问量过大的问题,对应的,也就无须采用I/O性能较高的硬件,节省了费用成本。此外,本发明还公开了一种共享文件系统的访问装置和设备,效果如上。
技术领域
本发明涉及存储领域,特别涉及一种共享文件系统的访问方法、装置及设备。
背景技术
一些情况下用户希望两台计算机之间的文件系统能够更加紧密地结合在一起,让一台主机上的用户可以像使用本机的文件系统一样使用另一台主机的文件系统,这种功能可以通过共享文件系统来实现。
共享存储型文件系统是多台计算机可以识别同一个存储空间,并相互协调共同管理该存储空间的文件,所以又被简称为共享文件系统。目前各个节点在并行访问共享文件系统的同一存储空间的同一数据块时,各个节点可以直接对同一数据块进行访问及操作,但是采用该种方法,一方面,各个节点直接对同一数据块进行访问及操作,在共享文件系统中该数据块遭到恶意访问时很容易造成数据泄露或恶意篡改,共享文件系统中的数据的安全性较低。另一方面,当各个节点同时对共享文件系统中的数据块进行访问时,由于缺乏对各个节点访问共享文件系统时的进程管理,如此当各个节点都访问共享文件系统时会造成共享文件系统的访问量过大,因此,为了满足各节点对共享文件系统的访问要求,需要采用I/O性能较高的硬件,而采用I/O性能较高的硬件费用较高。
因此,如何控制各个节点访问共享文件系统,避免采用I/O性能较高的硬件而带来的高费用以及提高访问共享文件系统的安全性。
发明内容
本发明的目的在于提供一种共享文件系统的访问方法、装置及设备,在共享文件系统的访问量过大的情况下,对各个节点进行了控制,节省了采用I/O性能高的硬件而带来的高费用问题和提高了访问共享文件系统的安全性。
为实现上述目的,本发明实施例提供了如下技术方案:
第一,本发明实施例提供了一种共享文件系统的访问方法,基于分布式锁管理器,包括:
获取预访问共享文件系统的节点的预访问进程;
依据所述预访问进程的类型为所述预访问进程分配锁模式;
检测所述预访问进程是否成功分配所述锁模式;
若成功分配所述锁模式,则允许所述预访问进程对所述共享文件系统进行与所述锁模式对应的访问操作;
若未成功分配所述锁模式,则不允许所述预访问进程对所述共享文件系统进行访问操作。
可选的,所述预访问进程具体包括:对所述共享文件系统进行读取操作的第一预访问进程、对所述共享文件系统进行开启操作的第二预访问进程或对所述共享文件系统进行写操作的第三预访问进程;
对应的,所述依据所述预访问进程的类型为所述预访问进程分配锁模式包括:
若所述预访问进程的类型为所述第一预访问进程或所述第二预访问进程,则为所述预访问进程分配共享锁;
若所述预访问进程的类型为所述第三预访问进程,则为所述预访问进程分配排他锁。
可选的,所述依据所述预访问进程的类型为所述预访问进程分配锁模式包括:
检测当前对所述共享文件系统进行访问的所有的访问进程中是否存在与所述预访问进程的类型相同的访问进程;
若是,则将所述预访问进程放入等待队列,直至与所述预访问进程的类型相同的访问进程释放锁模式后,将释放后的所述锁模式分配至所述预访问进程。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于浪潮(北京)电子信息产业有限公司,未经浪潮(北京)电子信息产业有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811528511.5/2.html,转载请声明来源钻瓜专利网。