Package Data | |
---|---|
Maintainer Username: | limen |
Maintainer Contact: | limengxiang876@gmail.com (LI Mengxiang) |
Package Create Date: | 2016-11-22 |
Package Last Update: | 2017-04-05 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-18 03:02:53 |
Package Statistics | |
---|---|
Total Downloads: | 3 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 6 |
Total Watchers: | 1 |
Total Forks: | 1 |
Total Open Issues: | 0 |
A distributed file server utilizes mongodb(not mongo GridFS) as the storage backend for Larevel.
Recommend to install via composer.
composer require "limen/fileflake"
use Limen\Fileflake\Config;
$config = [
Config::KEY_FILE_META_CONNECTION => 'mongodb', // required, file meta connection
Config::KEY_FILE_META_COLLECTION => 'FileMeta', // required, file meta collection
Config::KEY_NODE_META_CONNECTION => 'mongodb', // required, node meta connection
Config::KEY_NODE_META_COLLECTION => 'NodeMeta', // required, node meta collection
Config::KEY_FILE_CHUNK_SIZE => 51200, // required, chunk size in byte
// if set to true, the load balance would consider file count and file volume of each storage node,
// or the load balance would pick one node randomly
Config::KEY_LOAD_BALANCE_STRICT => true, // optional, default value is false
// required
Config::KEY_FILE_CONTENT_STORAGE_NODES => [
[
'id' => 1, // storage node id, should be unique and unmodifiable
'connection' => 'mongodb', // storage node connection
'collection' => 'FileStorage1', // storage node collection
],
[
'id' => 2,
'connection' => 'mongodb',
'collection' => 'FileStorage2',
],
],
Config::KEY_LOCALIZE_DIR => '/tmp/fileflake/localize', // required, the temp local files stored in this directory
// optional, see default values below
Config::KEY_CONTRACT_CONCRETE_MAP => [
\Limen\Fileflake\Contracts\UidGeneratorContract::class => \Limen\Fileflake\Support\UidGenerator::class,
\Limen\Fileflake\Contracts\BalancerContract::class => \Limen\Fileflake\LoadBalancer::class,
\Limen\Fileflake\Contracts\LockContract::class => \Limen\Fileflake\Lock\RedLock::class,
\Limen\Fileflake\Contracts\FileContainerContract::class => \Limen\Fileflake\FileContainer::class,
\Limen\Fileflake\Contracts\FileMetaContract::class => \Limen\Fileflake\Storage\FileMetaStorage::class,
],
];
$filePath = '/path/to/file';
$file = new \Limen\Fileflake\Protocols\InputFile($filePath, 'fileflake.png', filesize($filePath), 'png', 'image/png');
$fileflake = new \Limen\Fileflake\Fileflake($config);
/** @var string $fileId md5 */
$fileId = $fileflake->put($file);
/** @var \Limen\Fileflake\Protocols\OutputFile only file meta data */
$fileMeta = $fileflake->getMeta($fileId);
/** @var \Limen\Fileflake\Protocols\OutputFile */
$localFile = $fileflake->get($fileId);
$localFile->localize(); // make a local copy
/** @var string $localPath path of local copy */
$localPath = $localFile->path;
while ($chunk = $localFile->nextChunk()) { // iterate file chunks without making a local copy
// do something
}
// remove file
$fileflake->remove($fileId);
$fileflake->get($fileId); // return null
Every file has a meta record.
The reference is similar to soft link in Linux file system.
A file is "source file" when it doesn't have a reference. On the contrary, the files which have reference are "soft links".
File's reference count (default 1) shows how many file(s) (including itself) are referring to it.
The system would only store the first one of the files which have same checksum and the others' references point to the first file.
When a soft link file is removed, its meta data would be deleted and the reference count of its source file would decrement by 1.
When a source file is removed, its reference count would decrement by 1.
When a source file's reference count decrement to 0, its meta data would be deleted and its chunks would be deleted from storage node.
The nodes store source file's chunks.
Store the nodes meta data that would be used to load balance
MIT