Dockerising the cloudapi application

This commit is contained in:
Tom Gallacher 2016-10-17 16:41:17 +01:00
parent 495665088b
commit e6dfbeec51
6 changed files with 77 additions and 1 deletions

View File

@ -64,6 +64,9 @@ write_env_file() {
[[ -f .env ]] || {
echo '# Consul discovery via Triton CNS' >> .env
echo CONSUL=consul.svc.${TRITON_ACCOUNT}.${TRITON_DC}.cns.joyent.com >> .env
echo SDC_KEY_ID=${SDC_KEY_ID} >> .env
echo SDC_ACCOUNT=${SDC_ACCOUNT} >> .env
echo SDC_URL=${SDC_URL} >> .env
echo >> .env
}
}

View File

@ -0,0 +1,32 @@
FROM node:slim
RUN set -x \
&& apt-key adv --keyserver pgp.mit.edu --recv D101F7899D41F3C3 \
&& echo "deb http://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \
&& apt-get update && apt-get install -y git yarn --no-install-recommends \
&& rm -rf /var/lib/apt/lists/* \
&& groupadd -g 433 -r nodejs \
&& useradd -u 431 -r -g nodejs -d /home/nodejs -s /sbin/nologin -c "Docker image user" nodejs \
&& mkdir -p /home/nodejs/ \
&& chown -R nodejs:nodejs /home/nodejs/
# Get and configure containerpilot
ENV CONTAINERPILOT_VERSION 2.4.1
ENV CONTAINERPILOT file:///etc/containerpilot.json
RUN export CP_SHA1=198d96c8d7bfafb1ab6df96653c29701510b833c \
&& curl -Lso /tmp/containerpilot.tar.gz \
"https://github.com/joyent/containerpilot/releases/download/${CONTAINERPILOT_VERSION}/containerpilot-${CONTAINERPILOT_VERSION}.tar.gz" \
&& echo "${CP_SHA1} /tmp/containerpilot.tar.gz" | sha1sum -c \
&& tar zxf /tmp/containerpilot.tar.gz -C /bin \
&& rm /tmp/containerpilot.tar.gz
COPY ./etc/containerpilot.json /etc/
USER nodejs
WORKDIR /home/nodejs/
ADD package.json .
RUN npm install # yarn
ADD . .
CMD [ "/bin/containerpilot", "node", "src/index.js" ]

View File

@ -0,0 +1,14 @@
{
"consul": "{{ .CONSUL }}:8500",
"services": [
{
"name": "cloudapi-graphql",
"port": 3000,
"health": "/usr/bin/curl -o /dev/null --fail -s http://localhost:3000/",
"poll": 3,
"ttl": 10
}
],
"backends": [
]
}

View File

@ -1,4 +1,9 @@
const credentials = require('../../credentials.json');
const credentials = {
url: process.env.SDC_URL,
account: process.env.SDC_ACCOUNT,
user: process.env.SDC_USER || '',
keyId: process.env.SDC_KEY_ID,
};
const auth = require('smartdc-auth');
const cloudapi = require('triton/lib/cloudapi2');

View File

@ -18,3 +18,15 @@ consul:
ports:
- 8500:8500
command: -server -bootstrap -ui-dir /ui
#############################################################################
# CloudAPI GraphQL
#############################################################################
cloudapi:
build: ./cloudapi-graphql
labels:
- triton.cns.services=cloudapi
env_file: .env
environment:
- PORT=3000
ports:
- 3000:3000

View File

@ -4,3 +4,13 @@ consul:
service: consul
ports:
- 8500:8500
cloudapi:
extends:
file: docker-compose.yml
service: cloudapi
links:
- consul:consul
environment:
- PORT=3000
- ROOT_URL=http://localhost:3000
- CONSUL=consul