mirror of https://github.com/ENSL/ensl_gathers.git
Adding devcontainer
* added devcontainer to ease development * removed docker-compose file as it's not needed for development and specific to hosting * removed Procfile as it is related to heroku which is not used for hosting anymore
This commit is contained in:
parent
5fdbc3d0a0
commit
7496bb8984
|
@ -0,0 +1,25 @@
|
||||||
|
FROM mcr.microsoft.com/devcontainers/javascript-node:0-18
|
||||||
|
|
||||||
|
# Install MongoDB command line tools - though mongo-database-tools not available on arm64
|
||||||
|
ARG MONGO_TOOLS_VERSION=6.0
|
||||||
|
RUN . /etc/os-release \
|
||||||
|
&& curl -sSL "https://www.mongodb.org/static/pgp/server-${MONGO_TOOLS_VERSION}.asc" | gpg --dearmor > /usr/share/keyrings/mongodb-archive-keyring.gpg \
|
||||||
|
&& echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/mongodb-archive-keyring.gpg] http://repo.mongodb.org/apt/debian ${VERSION_CODENAME}/mongodb-org/${MONGO_TOOLS_VERSION} main" | tee /etc/apt/sources.list.d/mongodb-org-${MONGO_TOOLS_VERSION}.list \
|
||||||
|
&& apt-get update && export DEBIAN_FRONTEND=noninteractive \
|
||||||
|
&& apt-get install -y mongodb-mongosh \
|
||||||
|
&& if [ "$(dpkg --print-architecture)" = "amd64" ]; then apt-get install -y mongodb-database-tools; fi \
|
||||||
|
&& apt-get clean -y && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
# [Optional] Uncomment this section to install additional OS packages.
|
||||||
|
# RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
|
||||||
|
# && apt-get -y install --no-install-recommends <your-package-list-here>
|
||||||
|
|
||||||
|
# [Optional] Uncomment if you want to install an additional version of node using nvm
|
||||||
|
# ARG EXTRA_NODE_VERSION=10
|
||||||
|
# RUN su node -c "source /usr/local/share/nvm/nvm.sh && nvm install ${EXTRA_NODE_VERSION}"
|
||||||
|
|
||||||
|
# [Optional] Uncomment if you want to install more global node modules
|
||||||
|
# RUN su node -c "npm install -g <your-package-list-here>"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
// For format details, see https://aka.ms/devcontainer.json. For config options, see the
|
||||||
|
// README at: https://github.com/devcontainers/templates/tree/main/src/javascript-node-mongo
|
||||||
|
{
|
||||||
|
"name": "Node.js & Mongo DB",
|
||||||
|
"dockerComposeFile": "docker-compose.yml",
|
||||||
|
"service": "app",
|
||||||
|
"workspaceFolder": "/workspaces/${localWorkspaceFolderBasename}",
|
||||||
|
|
||||||
|
// Features to add to the dev container. More info: https://containers.dev/features.
|
||||||
|
// "features": {},
|
||||||
|
|
||||||
|
// Configure tool-specific properties.
|
||||||
|
"customizations": {
|
||||||
|
// Configure properties specific to VS Code.
|
||||||
|
"vscode": {
|
||||||
|
// Add the IDs of extensions you want installed when the container is created.
|
||||||
|
"extensions": [
|
||||||
|
"mongodb.mongodb-vscode"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Use 'forwardPorts' to make a list of ports inside the container available locally.
|
||||||
|
// "forwardPorts": [3000, 27017],
|
||||||
|
|
||||||
|
// Use 'postCreateCommand' to run commands after the container is created.
|
||||||
|
// "postCreateCommand": "yarn install",
|
||||||
|
|
||||||
|
// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root.
|
||||||
|
// "remoteUser": "root"
|
||||||
|
}
|
|
@ -0,0 +1,36 @@
|
||||||
|
version: '3.8'
|
||||||
|
|
||||||
|
services:
|
||||||
|
app:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: Dockerfile
|
||||||
|
volumes:
|
||||||
|
- ../..:/workspaces:cached
|
||||||
|
|
||||||
|
# Overrides default command so things don't shut down after the process ends.
|
||||||
|
command: sleep infinity
|
||||||
|
|
||||||
|
# Runs app on the same network as the database container, allows "forwardPorts" in devcontainer.json function.
|
||||||
|
network_mode: service:db
|
||||||
|
|
||||||
|
# Use "forwardPorts" in **devcontainer.json** to forward an app port locally.
|
||||||
|
# (Adding the "ports" property to this file will not forward from a Codespace.)
|
||||||
|
|
||||||
|
db:
|
||||||
|
image: mongo:6
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- mongodb-data:/data/db
|
||||||
|
|
||||||
|
# Uncomment to change startup options
|
||||||
|
# environment:
|
||||||
|
# MONGO_INITDB_ROOT_USERNAME: root
|
||||||
|
# MONGO_INITDB_ROOT_PASSWORD: example
|
||||||
|
# MONGO_INITDB_DATABASE: your-database-here
|
||||||
|
|
||||||
|
# Add "forwardPorts": ["27017"] to **devcontainer.json** to forward MongoDB locally.
|
||||||
|
# (Adding the "ports" property to this file will not forward from a Codespace.)
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
mongodb-data:
|
|
@ -1,39 +0,0 @@
|
||||||
version: "3.8"
|
|
||||||
services:
|
|
||||||
production:
|
|
||||||
container_name: ensl_gather_production
|
|
||||||
build:
|
|
||||||
context: ./
|
|
||||||
target: production
|
|
||||||
dockerfile: Dockerfile
|
|
||||||
depends_on:
|
|
||||||
- mongodb
|
|
||||||
command: ["/app/bin/entry.sh"]
|
|
||||||
user: web:web
|
|
||||||
environment:
|
|
||||||
- NODE_ENV=production
|
|
||||||
- PORT=$NODE_PORT
|
|
||||||
- "MONGOLAB_URI=mongodb://${MONGODB_USERNAME}:${MONGODB_PASSWORD}@mongodb/${MONGODB_DATABASE}"
|
|
||||||
- RAILS_SECRET
|
|
||||||
- NEW_RELIC_LICENSE_KEY
|
|
||||||
- GATHER_STEAM_ACCOUNT
|
|
||||||
- GATHER_STEAM_PASSWORD
|
|
||||||
- GATHER_DISCORD_HOOK_ID
|
|
||||||
- GATHER_DISCORD_HOOK_TOKEN
|
|
||||||
- RANDOM_USER
|
|
||||||
- FIXED_USER
|
|
||||||
ports:
|
|
||||||
- "${NODE_PORT}:${NODE_PORT}"
|
|
||||||
volumes:
|
|
||||||
- "./public:/app/public"
|
|
||||||
init: true
|
|
||||||
mongodb:
|
|
||||||
image: "bitnami/mongodb:4.4"
|
|
||||||
container_name: ensl_gather_mongodb
|
|
||||||
volumes:
|
|
||||||
- "./db/data:/bitnami/mongodb"
|
|
||||||
environment:
|
|
||||||
- MONGODB_USERNAME
|
|
||||||
- MONGODB_PASSWORD
|
|
||||||
- MONGODB_DATABASE
|
|
||||||
- MONGODB_ROOT_PASSWORD=$MONGODB_PASSWORD
|
|
Loading…
Reference in New Issue