Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
otherNet committed Feb 24, 2023
1 parent d31a626 commit 1e2f085
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 0 deletions.
12 changes: 12 additions & 0 deletions docs/environments/data-separation-concerns
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@

### Data separation of concerns
###### 1694
In order to discriminate data stored to the database it has been introduced a different database per each environment. So instead of working on the collection names or introducing new fields in the collection it has been preferred to implement the solution changing the whole database name against leaving different data for the different environments in the same database. The new db names are going to have the following format <environment>_db_name.

To the purpose of define the Environment name in a global and univocal manner it as been introduced a global .env file at the level of the root guardian folder next to the docker_compose file in a way that docker compose has the visibility to load the new GUARDIAN_ENV.
```
.env example:
GUARDIAN_ENV=prod
```
So beside the environment variables loaded in the docker compose file using the env_file as in 1604 it has been introduced the usage of “environment” specification to load the new GUARDIAN_ENV variable at docker-compose level. The usage of this environment variable has allowed to parametrize the database name in the common library: db-helper.ts
In this way the user will be able to use the same infrastructure and maintain their production Guardian environment data completely separated from his other environments data as test preview or demo environment. The switch through the different environments is allowed by the configuration of just one parameter in the .env file. If the GUARDIAN_ENV parameter is left blank, not configured, the system will keep behaving in the same way as now and the original database names will be used for the data. In this way the modification will not impact immediately but new logical environments usage are allowed to share the same infrastructure from now on without data environment separation concerns
6 changes: 6 additions & 0 deletions docs/environments/indipendent-services-images.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@

### Indipendent services images
###### 1604
The dockerized services images needs to be indipendent from the environment that describes the context in wich the images itself are running.
In each service loading .env files at build time by means of dockerfiles forces rebuilding the docker image for changes to be applied to the environment. To prevent this behavior the usage of “env_file” has been Introduced in the docker_compose file. In this way the environment variables are loaded in each container during the bootstrap of the application and passed to the image without the need to rebuild the image itself.
The dockerfiles have been changed accordingly: the command “copy” of the .env file was commented out. Actually the .env file is not needed at build time while it’s going to be charged during the bootstrap of the containers at the compose-level.

0 comments on commit 1e2f085

Please sign in to comment.