symbolist/piny-db

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

Maintainers

Package info

github.com/Symbolist-Technology/piny-db

pkg:composer/symbolist/piny-db

Statistics

Installs: 247

Dependents: 0

Suggesters: 0

Stars: 1

Open Issues: 0


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