定制 fostam/filelock 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

fostam/filelock

最新稳定版本:v1.0.2

Composer 安装命令:

composer require fostam/filelock

包简介

Simple file based locking with lock timeout and exceptions

README 文档

README

Simple file based locking.

Features

  • file based locking with flock()
  • works on Unix-like systems as well as Windows
  • supports timeout for acquiring lock
  • no third-party dependencies

Install

The easiest way to install FileLock is by using composer:

$> composer require fostam/filelock 

Usage

<?php require "vendor/autoload.php"; $fl = new \Fostam\FileLock\FileLock('mylock'); if (!$fl->acquire()) { exit; } // do exclusive stuff $fl->release();

Locking

The name of the lock is passed as first argument to the constructor:

$fl = FileLock('mylock'); 

Acquiring the lock is done with the acquire() method:

$fl->acquire(); 

It will return true on success and false if the lock is already present. If an error occurs, an exception is thrown (see below).

Optionally, a timeout in seconds can be passed:

$fl->acquire(10); 

The acquire() method will try to get the lock once per second until the timeout has been reached. If the lock could not be acquired, false will be returned.

A value of 0 will immediately return false if the locking fails. This is also the default behaviour if no timeout is given.

Unlocking

Explicitly releasing the lock:

$fl->release(); 

The lock is also implicitly released in the desctructor of the FileLock class if still present on destruction of the object.

Lock File

The process id (PID) of the locking process is written into the lock file after acquiring the lock.

By default, the lock file is created in the system's temporary directory as returned by sys_get_temp_dir(). An alternative directory can be passed to the constructor as second parameter:

$fl = FileLock('mylock', '/var/run'); 

In this example, the lock file would be /var/run/mylock.lock.

If required, the full lock file name can be retrieved from the FileLock object:

$filename = $fl->getLockFileName(); 

If the lock file is kept in a place that is subject to periodic cleanups (e.g. /tmp on most Linux systems), it can be refreshed with the refresh() method:

$fl->refresh(); 

This will update the file's modification time to the current timestamp.

NOTE: To avoid race conditions, the lock file is not deleted when released.

Exceptions

All exceptions inherit the common LockFileException class.

The acquire() method might throw one of the following exceptions:

  • LockFileNotOpenableException: the lock file can not be created or opened
  • LockFileOperationFailedException: a file system operation on the lock file has failed
  • LockFileVanishedException: the lock file has vanished after acquiring the lock

The release() method will throw the LockFileOperationFailureException exception in case the unlock file system operation fails.

统计信息

  • 总下载量: 25.28k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固