-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
40 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
# Deployment Strategy for Jelastic Environments | ||
|
||
The application is stored on https://app.jpe.infomaniak.com/ and consists of various parts as described below: | ||
|
||
## 1. PRODUCTION Environment Setup | ||
|
||
### Application Server (Docker container) | ||
Runs the application and is connected to Shopify via the Application Dashboard (API Configuration Section) | ||
|
||
**Automated Deployments:** | ||
- Image Building: Docker images are built automatically via GitHub Actions. The build process triggers on code changes and commits. | ||
- Deployment Notification: GitHub Actions will ping Jelastic via a REST API call with deployment details once the build is complete. | ||
- Tagging: Use branch-sha_commit tags (e.g., main-2d478ef) to keep track of versions. | ||
|
||
**Logs:** | ||
- Access logs in the run.log file within the Docker container for troubleshooting. | ||
|
||
**Environment Variables:** | ||
- Configure necessary environment variables using the Variables popup in Jelastic. | ||
|
||
### Nginx Load Balancer: | ||
|
||
- Port Configuration: Configure Nginx to listen on relevant application port (HTTP) and proxy traffic to the appropriate internal nodes based on IP addresses via HTTPS. | ||
- SSL Configuration: | ||
- Ensure Nginx is set up to handle SSL communication internally. | ||
- Use the ssl.conf configuration file to set up SSL keys for secure communication between components. | ||
|
||
### Postgres Container: | ||
Stores the internal data store | ||
- Links: Ensure proper linking between the Postgres container and other components. | ||
- Certificates: Use certificates to secure communication between the Postgres container and other services. | ||
|
||
### Creating new Environments: | ||
- Simplest way is to clone Environment by using the Jelastic environment cloning feature to duplicate the current setup. | ||
- This will create an exact replica of your existing environment. | ||
- Post-clone, adjust the following settings: | ||
- Update environment-specific settings, such as IP addresses, secrets, and environment variables. | ||
- Ensure any environment-specific configurations (e.g., database URLs, API keys) are updated. | ||
|
||
![Bildschirmfoto 2024-09-05 um 13 27 29](https://github.com/user-attachments/assets/eadf8d6a-44e8-45f6-96f5-60ae5aeb2cf9) |