flock用于在shell脚本或命令行中管理文件锁。文件锁是一种机制,它允许您在多进程环境中对共享文件进行排他或共享访问的控制,起到进程独占与文件保护的作用。
文件保护示例:
场景描述:在一个终端使用flock锁定保护文件file,使用read等待用户输入,在另一个终端也使用flock写入文件file,观察文件file是否被写入及返回状态。
❯ flock -n ./tmp.lock -c 'read word && echo $word >> ./file'
说明:
-n以非阻塞的方式获取锁,运行这个命令里flock会先去判断./tmp.lock是否被占用,如果被占用即退出,返回状态码为‘1’。以上命令只是为了占用并保护file,可以不用-n
-c 后面跟要执行的命令,需要使用‘’将命令封起来,否则只会执行第一个命令read。
在另一终端执行以下命令
❯ flock -n ./tmp.lock -c "echo '0000' >> ./file"
执行后即退出,状态码为1,file文件没有被写入内容,起到保护作用。
上面命令不用-n时将处于阻塞状态,直到另一个终端输入完成才会被执行。