danil-kashin/file-lock 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

danil-kashin/file-lock

最新稳定版本:v1.0.0

Composer 安装命令:

composer require danil-kashin/file-lock

包简介

File-based exclusive locking via flock().

README 文档

README

A lightweight PHP library for file-based exclusive locking using flock().

Requirements

  • PHP 8.1 or higher

Installation

composer require danil-kashin/file-lock

Usage

Basic acquire and release

use DanilKashin\FileLock\FileLock;

$lock = new FileLock('/tmp/my-process.lock');

$lock->acquire(); // blocks until the lock is obtained
// ... critical section ...
$lock->release();

Clean up the lock file after use

$lock = new FileLock('/tmp/my-process.lock');

$lock->acquire();
// ... critical section ...
$lock->release();
$lock->deleteFile();

Error handling

use DanilKashin\FileLock\Exceptions\FileLockException;

$lock = new FileLock('/tmp/my-process.lock');

try {
    $lock->acquire();
    // ... critical section ...
} catch (FileLockException $e) {
    // lock file could not be opened or the lock could not be acquired
    echo $e->getMessage();
} finally {
    $lock->release();
}

API

FileLock::__construct(string $lockFile)

Creates a new FileLock instance. The $lockFile path is the file used as the lock. The file is created automatically on the first call to acquire() if it does not exist.

acquire(): void

Acquires an exclusive lock (LOCK_EX). Blocks until the lock becomes available. Calling acquire() multiple times on the same instance is safe — the file handle is reused and flock is re-entrant on the same process.

Throws FileLockException if the lock file cannot be opened.

release(): void

Releases the exclusive lock (LOCK_UN). The lock file itself is kept on disk.

deleteFile(): void

Deletes the lock file from disk. Call this after release() when the file is no longer needed.

How it works

FileLock opens the target file in cb mode (create if missing, binary) and delegates all locking to the operating system via PHP's flock(). This makes it safe to use across multiple processes on the same machine.

Running tests

composer install
vendor/bin/phpunit

统计信息

  • 总下载量: 45
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 11
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2026-03-26