Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/th-projects/filenest
A straightforward file-sharing server accessible through a web client. This project was developed as part of an examination for the Distributed Systems course at DHBW Heidenheim.
https://github.com/th-projects/filenest
distributed-systems docker docker-compose fastify file-sharing mariadb minio-storage reactjs
Last synced: 5 days ago
JSON representation
A straightforward file-sharing server accessible through a web client. This project was developed as part of an examination for the Distributed Systems course at DHBW Heidenheim.
- Host: GitHub
- URL: https://github.com/th-projects/filenest
- Owner: TH-Projects
- License: agpl-3.0
- Created: 2024-07-11T12:31:10.000Z (7 months ago)
- Default Branch: master
- Last Pushed: 2024-09-26T06:44:38.000Z (4 months ago)
- Last Synced: 2025-01-22T02:36:14.312Z (5 days ago)
- Topics: distributed-systems, docker, docker-compose, fastify, file-sharing, mariadb, minio-storage, reactjs
- Language: JavaScript
- Homepage:
- Size: 5.36 MB
- Stars: 0
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# FileNest
A straightforward file-sharing server accessible through a web client.
This project was developed as part of an examination for the Distributed Systems course at DHBW Heidenheim.## Get The Application running
First clone the repo with the project directory `FileNest` (name is mandatory).
```
https://github.com/TH-Projects/FileNest.git
```Before launching the system it is needed to define a .env file containing needed variables for running the application and configuring the infrastructure.
The .env-file has so define the following environmental variables:### Root .env
Place an .env file in the project root folder
```
#JWT
JWT_SECRET=#API Calls
NGINX_API=http://nginx:81 # Adapt Port for Nginx if needed#Minio
MINIO_ROOT_USER=
MINIO_ROOT_PASSWORD=
MINIO_ALIAS=myminio
MINIO_ACCESS_KEY=
MINIO_SECRET_KEY=
MINIO_USER=
MINIO_USER_ACCESS_KEY=
MINIO_SERVER_PORT=9000 # Adapt port for minIO if needed#MySQL
MYSQL_ROOT_PASSWORD=
MYSQL_DATABASE=filenest
MYSQL_USER=
MYSQL_PASSWORD=#URLs
URL_MINIO1=minio1 # Adapt if needed
URL_MINIO2=minio2 # Adapt if needed
URL_MINIO3=minio3 # Adapt if needed
URL_MINIO4=minio4 # Adapt if neededURL_METADB1=metadb1 # Adapt if needed
URL_METADB2=metadb2 # Adapt if needed
URL_METADB3=metadb3 # Adapt if neededURL_REACTAPP=reactapp # Adapt if needed
URL_NGINX=nginx
URL_SERVERMETADB1=servermetadb1 # Adapt if needed
URL_SERVERMETADB2=servermetadb2 # Adapt if needed
URL_SERVERMETADB3=servermetadb3 # Adapt if needed#Ports
PORT_MINIO=9000 # Adapt if neededPORT_SERVERFASTIFY=3000 # Adapt if needed
PORT_METADB=3306 # Adapt if needed
PORT_REACTAPP=3000 # Adapt if needed
PORT_BROKER=6001 # Adapt if needed
PORT_NGINX=81 # Adapt if needed
PORT_SERVERMETADB=3001 # Adapt if needed
PORT_ADMIN=3000 # Adapt if needed
```
### React .env
Place an .env in the `./client` folder```
VITE_APP_HOST= # e.g localhost
```### Launching the system
All containers can be launched by the command
```
docker-compose up -d --scale broker= --scale serverfastify= --build
```
The system is fully booted when the container createuser-1 has exited. This behaviour is expected.### Troubleshooting the system startup
Depending on your used hardware it can be the case that the metadbServer tries to connect to the database before it is set up.
In this case please restart your metadbServer-containers manually or adjust the sleep in the `app.js` of the metadbServer to a value that
the system starts without the containers exiting.## Project Documentation
A description of the structure and decisions in the project in german language is provided inside the `documentation`-Folder
Further information about used technologies can be found here:
- [Docker-Documentation](https://docs.docker.com/manuals/)
- [Nginx-Documentation](https://nginx.org/en/docs/)
- [minIO-Documentation](https://min.io/docs/minio/container/index.html)
- [React-Documentation](https://react.dev/learn)
- [Fastify-Documentation](https://fastify.dev/docs/latest/Guides/)
- [MariaDB-Documentation](https://mariadb.com/kb/en/documentation/)