承接 danil-kashin/file-lock 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱: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
  • 点击次数: 2
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固