Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nwhovian/dfs-client
JS client for Distributed File System
https://github.com/nwhovian/dfs-client
Last synced: about 2 months ago
JSON representation
JS client for Distributed File System
- Host: GitHub
- URL: https://github.com/nwhovian/dfs-client
- Owner: nWhovian
- License: mit
- Created: 2019-10-27T16:48:06.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2022-03-02T06:05:03.000Z (almost 3 years ago)
- Last Synced: 2023-03-03T08:45:49.927Z (almost 2 years ago)
- Language: Vue
- Homepage:
- Size: 649 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Distributed File System client
>Client for communication with fault-tolerant file system that supports file reading, writing, copying, moving, deletion and different directory operations.>Written by Anastasiia Gromova (telegram: @n_whovian)
## Launch the system
The system consists of three main components: naming server, storage server (in our implementation there are 4 such servers) and client application.
Naming and storage servers (namenode and datanode) are written in Python and deployed on AWS instances using docker swarm.
You can find the images here: [datanode](https://hub.docker.com/repository/docker/onbehalfofme/dfs-datanode), [namenode](https://hub.docker.com/repository/docker/onbehalfofme/dfs-namenode).
Client web-application is written in JavaScript with Vue.js framework.
You can launch the dfs client:
```
# install dependencies
npm install# serve with hot reload at localhost:8080
npm run dev# build for production with minification
npm run build# build for production and view the bundle analyzer report
npm run build --report# run unit tests
npm run unit# run all tests
npm test
```
The client interacts with already deployed namenode and datanodes.## Architecture
As it was said before, the system consists of three components, that interact with each other:![](image.png )
#### Namenode -> Datanode
* GET /health - namenode checks the datanode every 30 sec
* GET /info - namenode requests a file info from datanode
* GET /delete - namenode tells datanode to delete a file
* GET /init - namenode tells datanode to initialize a storage
* GET /rmdir - namenode tells datanode to delete a directory
* GET /move - namenode tells datanode to move file
* GET /copy - namenode tells datanode to copy file#### Datanode -> Namenode
* GET /replicate - datanode asks a namenode where to send a replication#### Client -> Namenode
* GET /init - initialize new storage (delete everything and return the available size)
* GET /create - create an empty file
* GET /read - get a list of datanodes that contain such file (from where to download a file)
* GET /write - get a datanode IP (where to upload a file)
* GET /delete_file - delete a file from DFS
* GET /info - get information about a file
* GET /copy - create a copy of file
* GET /move - move a file
* GET /cd - change the current directory
* GET /ls - return a list of stored files/directories
* GET /mkdir - create a new directory
* GET /delete_dir - delete a directory#### Client -> Datanode
* GET /download - download the file from datanode
* POST /upload - send a file by chunks (of 1 Mb) to datanode
---
For a detailed explanation on how things work, check out the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader).