symbolist/piny-db 问题修复 & 功能扩展

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

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

symbolist/piny-db

最新稳定版本:v0.0.14

Composer 安装命令:

composer require symbolist/piny-db

包简介

A tiny file-based JSON database for PHP with atomic locking, queue rotation, and optional TCP server.

README 文档

README

PineDB Logo

Tiny File-Based JSON Database for PHP

Install

php composer.phar require symbolist/piny-db

Usage

Start Server

./vendor/bin/pinydb-server -h 127.0.0.1 -P 9999 -d ./piny-data

Server CLI Options

  • --host, -h – Bind address (default: 127.0.0.1).
  • --port, -P – Port to listen on (default: 9999).
  • --data-dir, -d – Directory for table storage (default: current working directory + /pinydb-data).
  • --client-timeout, -t – Socket timeout in seconds for client connections (default: 5).
  • --logfile, -l – Log file path (default: /tmp/pinydb.log).
  • --max-children, -m – Maximum concurrent child processes when forking is available (default: 20).
  • --disable-flock – Skip file locking (useful on filesystems without flock).
  • --daemon – Run the server as a background process (writes the PID to the pidfile).
  • --pidfile=PATH – Override the pidfile location when using --daemon (default: /tmp/pinydb.pid).

Use Client (Interactive Mode)


./vendor/bin/pinydb-cli --host=127.0.0.1 --port=9999 ping

 

Example client Output

pinydb> ping
"PONG"
pinydb> 

Using PHP Client (SDK)

use PinyDB\PinyDBClient;

try{
    $client = new PinyDBClient("127.0.0.1", 9999);

    echo $client->ping();  // PONG
    //$record = array('foo' => 'bar.'.rand(99,9999));
    //echo $client->insert('records', $record);  // PONG
    $record=  $client->rotate('records');
    print_r($record);
    exit;
}
catch(Exception $e) {
    echo 'Caught exception: ',  $e->getMessage(), "\n";
    exit;
}

Disabling file locks

PinyDB uses flock for read and write operations by default. If you are working on a filesystem that does not support file locks (for example, some network mounts), you can disable locking:

use PinyDB\PinyDB;

$db = new PinyDB('/path/to/data', false); // disable flock

The TCP server can also skip locking via a flag:

./vendor/bin/pinydb-server --disable-flock -h 127.0.0.1 -P 9999 -d ./piny-data

Commands

  --help                        Show this help message
  -c <CMD>                      Run a single command
  PING                          Test connection
  CREATE <table>                Create a new table
  DROP <table>                  Drop a table
  COUNT  <table>                Count rows in table
  ALL    <table>                Get all rows
  GET    <table> <id>           Get 1 row
  INSERT <table> <json>         Insert row
  PUSH   <table> <json>         Push row to end
  UPDATE <table> <id> <json>    Update row
  DELETE <table> <id>           Delete row
  SHOW TABLES                   List tables
  TRUNCATE <table>              Remove all rows from table
  ROTATE <table>                Pop+rotate queue
  POP    <table>                Pop queue
  RANDOM <table>                Randomly pop+rotate queue

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-05