Linux信号前奏之文件锁

Linux文件锁详解
本文探讨了在多进程环境下Linux如何通过文件锁模型解决文件共享读写的问题,详细介绍了使用fcntl函数进行文件加锁的方法,并提供了具体的代码示例。

写在前面:小生纯业余选手,开此博仅仅是为了积累,纯当笔记来用。如有看官光临小生博客,请不要相信我的代码就是正确的。如果您发现了错误也恳请耽误您一点时间,请您在下面指出来,不胜感激!

如果发现一些笔记的说法完全是错误的请建议我删除!


在多进程下文件读写是共享的,所以会产生如下问题:如何知道一个文件正在被其他进程读写?

回答:Linux通过文件锁模型来解决这个问题。(文件锁包括强制锁与建议锁)
通过fcntl可以对文件加锁(至于加的是什么类型的锁,要弄明白)


对于以上函数的解释<来自某位网友>

函数说明:
int fcntl(
int fd,//被加锁的文件描述符号

int cmd,

//锁的操作方式:F_SETLK(已经加锁,异常返回) F_UNLK F_SETLKW(已经加锁,则阻塞等待)

struct flock *lk//锁的描述

    )


struct flock是一个描述锁的结构体

如下代码来说明对文件加锁,获取文件锁

加锁程序,由于程序结束后内核会自动释放文件锁,所以这里使用一个死循环(用来验证相同的锁是否可以被多次加在同一个文件上)

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>

int main()
{
    int fd;
    struct flock lk;
    int r;
    
    fd = open("a.txt",O_RDWR);
    if( fd == -1 )
    {
        printf(":%m\n");
        exit(-1);
    }
    
    lk.l_type = F_WRLCK;
    lk.l_whence = SEEK_SET;
    lk.l_start = 5;
    lk.l_len = 10;
    
    r = fcntl(fd,F_SETLK,&lk);
    if(r == 0)
        printf("add lock over!\n");
    else
        printf("add lock failed!\n");
    while(1);
} 


获取锁

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>

int main()
{
    struct flock lk;
    
    int fd = open("a.txt",O_RDWR);
    if( fd == -1)
    {
        printf("::%m\n");
        exit(-1);
    }
    
    int r = fcntl(fd,F_GETLK,&lk);
    
    if( r == 0 )
    {
        printf("get lock over\n");
    }
    
    if(lk.l_type == F_WRLCK)
        printf("get a write lock\n");
        
    printf("start:%d,len:%d\n",lk.l_start,lk.l_len);
    
    printf("PID:%d\n",lk.l_pid);
    return 0;
}


问题:

1.一个文件是否可以被加多个锁?

2.相同的锁是否可以加在同一个文件上

3.详细了解flock结构体





### Linux 系统中休眠唤醒时产生的 DBus 信号Linux 中,当系统进入休眠或者从休眠状态恢复时会触发特定的事件通知机制。DBus 是一种进程间通信协议,在此过程中扮演重要角色用于发送和接收消息。 对于电源管理操作如挂起到内存(suspend to RAM)或磁盘(hibernation),通常涉及 `org.freedesktop.UPower` 和 `org.freedesktop.login1` 接口下的多个对象路径发出的通知[^1]。具体来说: - 当即将执行睡眠动作之前会有预告性质的消息被广播出去; - 实际发生改变之后也会有相应的更新报告给监听者们知晓最新状况; 例如,通过 D-Bus 可以监控到如下两种类型的信号: #### Suspend/Resume Signals (来自 org.freedesktop.login1.Manager) 这类信号会在整个机器级别发生变化的时候分发出来,适用于所有用户空间的应用程序和服务来响应这些变化。 - **PrepareForSleep(bool active)**: 表明设备正准备进入低功耗模式(`true`)或是已经恢复正常运作(`false`). 这个布尔参数指示了当前阶段是前奏还是结束. ```bash dbus-monitor --system "interface='org.freedesktop.login1.Manager',member='PrepareForSleep'" ``` #### Sleep State Changes (来自 org.freedesktop.UPower.Device) 而 UPower 提供了一套更细致的方法来跟踪电池电量以及电源供应情况的变化, 同样也涵盖了有关于睡眠周期的信息传递。 - **Changed**: 设备属性发生了更改,这可能意味着进入了不同的省电模式. 为了捕捉上述任何一类活动,可以利用命令行工具 `dbus-monitor` 来实时观察感兴趣的对象所发布的动态。当然也可以编写应用程序订阅此类事件并作出适当反应[^3].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值