Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/barrymun/cs4032-project
https://github.com/barrymun/cs4032-project
Last synced: 10 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/barrymun/cs4032-project
- Owner: barrymun
- Created: 2016-12-03T12:00:34.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2017-02-09T22:14:33.000Z (almost 8 years ago)
- Last Synced: 2024-11-07T00:27:18.553Z (about 2 months ago)
- Language: Python
- Size: 2.75 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Setting up the Distributed File System: (WITHOUT DOCKER)
## first, the authentication server must be initialised.
```bash
python authenticationserver.py
```A master_server is also created, and managed by the mongodb. All newly created master servers **must** be added to that collection in the db.
This will ensure that clients can be managed through creation **and** authentication.
## Create the worker servers, named dirserver in this instance.
```bash
python directoryserver.py
```Run the above three times. One master_server will be created.
The authentication server can be modified to allow for more than 3 instances, but this is the number that has been selected for testing purposes.
## Finally, run the test user to ensure that the requests are handled by the worker servers, and the master_server manages these instances correctly.
```bash
python user.py
```# Setting up the Distributed File System: (WITH DOCKER)
Use "sudo" before any (or all) docker commands where applicable.
Ensure that you are logged in:
```bash
docker login
```### Build the authentication_server image and generate container
Build your custom image:
```bash
docker build -t -f docker-authserver/Dockerfile .
```
List all currently available (successfully built) images:
```bash
docker images
```
Tag the image using your docker repo:
```bash
docker tag /:latest
```
Push your custom image to your docker repo:
```bash
docker push /
```
Create a container (Run the image):
(The following command ensures a mongod daemon is created, as opposed to a standard docker run command)
```bash
docker run -p 28001:27017 --name -d / --smallfiles
```
List all currently active containers:
```bash
docker ps -s
```### Create the container for this image
Build your custom image:
```bash
docker build -t -f docker-dirserver/Dockerfile .
```
List all currently available (successfully built) images:
```bash
docker images
```
Tag the image using your docker repo:
```bash
docker tag /:latest
```
Push your custom image to your docker repo:
```bash
docker push /
```
Create a container (Run the image):
(The following command ensures a mongod daemon is created, as opposed to a standard docker run command)
Let "X" below represent incrementing ports; (28002, 28003, 28004)
```bash
docker run -p :27017 --name -d / --smallfiles
```
List all currently active containers:
```bash
docker ps -s
```
Please see the attached testing/commands.txt for more information on the exact commands issued.### Run the user.py script to simulate test user interactions
```bash
python user.py
```
This python script will simulate file upload, download and delete operations and transactions.### Miscellaneous
Refer to the "testing" directory to view screenshots of tests, the system in action, etc.
Refer to "documentation" for a detailed description of the system.