Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/iglazunoff/docker-mongo-php
Docker compose for projects with MongoDB, PHP and Redis
https://github.com/iglazunoff/docker-mongo-php
composer docker docker-compose makefile mongodb php php82 vitejs
Last synced: about 2 months ago
JSON representation
Docker compose for projects with MongoDB, PHP and Redis
- Host: GitHub
- URL: https://github.com/iglazunoff/docker-mongo-php
- Owner: iglazunoff
- License: mit
- Created: 2023-03-12T10:54:00.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2023-04-10T21:10:07.000Z (over 1 year ago)
- Last Synced: 2024-10-13T13:01:47.056Z (3 months ago)
- Topics: composer, docker, docker-compose, makefile, mongodb, php, php82, vitejs
- Language: Makefile
- Homepage: https://github.com/iglazunoff/docker-mongo-php
- Size: 33.2 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# Docker Mongo and PHP
Starter kit for projects with MongoDB, PHP and Redis.## Navigation
- [Introduction](#introduction)
- [Quickstart](#quickstart)## Introduction
### Containers
This starter kit includes the following containers and configurations for them:
- **PHP** (8.2.4 fpm)
- **Redis** (alpine)
- **MongoDB** (6.0.5)
- **Supervisor** (based on PHP container)
- **Nginx** like web-server### Docker resources
Provide the following resources for Docker to work correctly:
- **RAM:** 2G and more
- **CPU:** 2 cores and more
- **Storage:** 6G and more
- **Swap:** 512M and more### Environments
All default environment variables are located by paths:
- docker/environments/.env.example - for build containers
- docker/environments/.env.app.example - for your applications### Make helpers
For simple project management, we recommend using the commands from the Makefile.
For show all make commands write in your terminal:
```shell
make help
```
OR
```shell
make
```For open container terminal write in your terminal:
```shell
# php container
make php
```
```shell
# supervisor container
make supervisor
```
```shell
# MongoDB container
make mongo
```
Stop all containers:
```shell
make stop
```
Start all containers:
```shell
make start
```
Restart all containers:
```shell
make restart
```
Rebuild all containers:
```shell
make reload
```## Quickstart
To initialize Docker containers and install composer and npm packages, write in your terminal:
```shell
make env
```
#### Write actual values to environment variables
```shell
make init
```
### OR
```shell
cp docker/environments/.env.example .env
cp docker/environments/.env.app.example .env.app
```
#### Write actual values to environment variables
```shell
docker network create \
-o com.docker.network.bridge.name=$(PROJECT_NAME) \
--driver=bridge \
app-networkdocker-compose build --no-cache
docker-compose up -d
docker exec -it "$(PROJECT_NAME)-php" composer install
docker exec -it "$(PROJECT_NAME)-php" npm install
```## Nice!
### Follow these steps
- Initialization and first run will take 5 minutes or more, depending on the characteristics of your hardware and the resources allocated to Docker
- Write your code or install framework and then more
- It is recommended to use **root** or **src** as working directory
- The entry point will be the file **public/index.php**
- In the public directory, you can place all public files, such as robots.txt, sitemap.xml, etc.
- Frontend assets will be in the directory **assets**#### Good luck!