This repository replicates a recent DevOps interview technical challenge, with some details removed or anonymised.
This repository serves as a starting point for Laravel microservices at ACME Corp, including pre-configured Continuous Integration and Continuous Deployment (CI/CD) pipelines for testing and building applications. It's designed to streamline the development process and ensure code quality through automated testing and build steps.
Follow these steps to set up the project locally:
- Clone the Repository:
git clone https://github.com/markwcodes/laravel-microservice-base.git
cd laravel-microservice-base
- Install Dependencies:
Make sure you have Composer installed. Then run:
composer install
- Local Environment Configuration
Copy .env.example
and rename it to .env
Update any necessary configuration settings such as app name, database credentials, etc.
- Generate Application Key:
php artisan key:generate
- Run Migrations:
php artisan migrate
- Start the Development Server:
php artisan serve
- Access the Application:
Visit http://localhost:8000 in your browser to see the application in action.
Run this command from your project's root directory to launch the latest build in Docker:
docker run --publish 80:80 --env-file .env ghcr.io/markwcodes/laravel-microservice-base:latest
Note: You must be authenticated in Docker with your GHCR.io credentials to pull any images from the container registry.
You can then navigate to localhost and the status endpoint endpoints:
The repository includes pre-configured CI/CD pipelines in GitHub Actions for automated testing and building.
Opening a Pull Request to the main branch will trigger the test, build and publish workflow. If all tests pass, the workflow builds, tags and pushes the build to the repository's container registry (GHCR.io).
Commits in all branches in the repository are continuously unit tested by the CI workflow.
CI/CD pipelines are defined in the .github/workflows
directory. You can customise these workflows to fit your project's specific needs.
- Create nginx webserver side-car container instead of using the php-apache image
- Tidy and organise CI/CD Dockerfile and helper scripts. Consider moving infrastructure into its own repository eventually
- Add linting to CI pipeline
- Add test coverage to CI pipeline
- Use SQL service container in CI environments
- Configure additional build/deployment stages (Dev, Staging, UAT)
- Setup better nested workflows to avoid duplication
- Figure out correct
storage
directory user permissions in Dockerfile (777 for now) - Configure Front-end builds
- Protect master branch from direct push (needs paid GH account)
- Add git tags to commit milestones
- Processes to update composer, node packages & security scanning
- Using Laravel Sail for easier, Dockerised local dev setup
- Set up automated deployments