当前位置: 首页 > 面试题库 >

Linux群,如何“仅”锁定文件?

皇甫波峻
2023-03-14
问题内容

在Bash中,我试图使函数getLock与不同的锁名一起使用。

function getLock
{
    getLock_FILE="${1}"
    getLock_OP="${2}"
    case "${getLock_OP}" in
        "LOCK_UN")
            flock -u "${getLock_FILE}"
            rm -fr "${getLock_FILE}"
            ;;
        "LOCK_EX")
            flock -x "${getLock_FILE}"
    esac
}

但是羊群说 flock: bad number: myfilelock

如何仅锁定文件并在需要时释放它,而不必在集群执行命令?

它的用法如下:

getLock myfilelock LOCK_EX
somecommands
........
getLock myfilelock LOCK_UN

问题答案:

锁定文件:

exec 3>filename # open a file handle; this part will always succeed
flock -x 3      # lock the file handle; this part will block

释放锁:

exec 3>&-       # close the file handle

您也可以按照羊群手册页中的描述进行操作:

{
  flock -x 3
  ...other stuff here...
} 3>filename

…在这种情况下,文件退出时文件会自动关闭。(在这里也可以通过使用( )而不是来使用子外壳{ },但这应该是一个有意的决定-
因为子外壳会降低性能,并且会影响范围变量的修改和其他状态的改变)。

如果您正在运行足够新的bash版本,则无需手动管理文件描述符号:

# this requires a very new bash -- 4.2 or so.
exec {lock_fd}>filename
flock -x "$lock_fd"
exec $lock_fd>&-

…现在,对于您的功能,我们将需要关联数组和自动FD分配(并且,为了允许从不同路径对同一文件进行锁定和解锁,请使用GNU
readlink),因此这不适用于较旧的bash版本:

declare -A lock_fds=()                        # store FDs in an associative array
getLock() {
  local file=$(readlink -f "$1")              # declare locals; canonicalize name
  local op=$2
  case $op in
    LOCK_UN)
      [[ ${lock_fds[$file]} ]] || return      # if not locked, do nothing
      exec ${lock_fds[$file]}>&-              # close the FD, releasing the lock
      unset lock_fds[$file]                   # ...and clear the map entry.
      ;;
    LOCK_EX)
      [[ ${lock_fds[$file]} ]] && return      # if already locked, do nothing
      local new_lock_fd                       # don't leak this variable
      exec {new_lock_fd}>"$file"              # open the file...
      flock -x "$new_lock_fd"                 # ...lock the fd...
      lock_fds[$file]=$new_lock_fd            # ...and store the locked FD.
      ;;
  esac
}

如果您在无法使用GNU readlink的平台上,建议readlink -f使用Michael
Kropat的“
realpath从sh-
realpath替换呼叫”
(仅依靠广泛可用的readlink功能,而不是GNU扩展)。



 类似资料:
  • 问题内容: UNIX文件锁定非常简单:操作系统假定您知道自己在做什么,然后就可以按照自己的意愿进行操作: 例如,如果您尝试删除另一个进程已打开的文件,则操作系统通常会允许您执行此操作。原始进程仍将保留其文件句柄,直到它终止-这时文件系统将安静地回收磁盘资源。不用大惊小怪,这就是我喜欢的方式。 Windows上的不同之处:如果我尝试删除另一个进程正在使用的文件,则会出现操作系统错误。在原始进程释放它

  • 问题内容: 经过Google的几次搜索后,我想到的是: 这非常不方便,并且会输出不需要的文本,例如mime类型信息。有更好的解决方案吗?我在同一文件夹中有很多图像和其他二进制文件,还有很多文本文件需要搜索。 问题答案: 我知道这是一个旧线程,但是我偶然发现了它,并认为我会分享我的方法,我发现这是一种非常快速的方法,可用于仅查找非二进制文件: grep 的选项告诉它立即忽略二进制文件,而连同的选项会

  • 问题内容: 我正在用Java创建一个应用程序,对于该应用程序我只希望运行一个实例。为此,我创建了一个文件,并在我的应用程序运行时锁定了它。 我有以下代码可在Windows上运行,但在Linux上无法运行:一旦我获得了一个锁而没有将其解锁,则可以再获得一个锁。 问题答案: 我使用了与您相同的示例,并且在Mac OS X上遇到了同样的问题。似乎文件锁定不能防止在POSIX系统上删除文件。在解锁之前,您

  • 问题内容: 我有一个使用FileReader打开文件的Java进程。如何防止另一个(Java)进程打开该文件,或者至少通知第二个进程该文件已打开?如果文件已打开(这解决了我的问题),这是否使第二个进程自动获得异常?还是我必须在第一个进程中使用某种标记或参数来显式打开该文件? 澄清: 我有一个Java应用程序,其中列出了一个文件夹并打开列表中的每个文件进行处理。依次处理每个文件。每个文件的处理包括读

  • 我需要创建一个锁文件,不能被其他脚本或进程删除。我试过这个: 但是,从当前用户启动的任何其他进程都可以删除文件,即使文件句柄仍然由正在运行的脚本打开。如何解决此问题并防止其他人(即非PHP进程)删除该文件?进程退出时自动释放的锁?所有类似的问题都以RTM flock()结尾,但没有一个回答如何针对外部进程锁定文件。 OS是

  • 问题内容: 我有几个线程(其中一些由进程X产生,其他由进程Y 等产生 ),并且每个线程都需要写入文件。但是,如果开始写第一,那么,当开始写作,它需要等待到 释放文件 ,以便它可以读取写在该内容。换句话说,每个线程都会有一个方法,如下所示: 我的问题是:如何完成以上代码?我正在研究该类,但是它在Javadoc中说: “文件锁代表整个Java虚拟机持有。它们不适合控制同一虚拟机中多个线程对文件的访问。