-
-
Notifications
You must be signed in to change notification settings - Fork 10
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
10 changed files
with
220 additions
and
9 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,51 @@ | ||
# This file excludes paths from the Docker build context. | ||
# | ||
# By default, Docker's build context includes all files (and folders) in the | ||
# current directory. Even if a file isn't copied into the container it is still sent to | ||
# the Docker daemon. | ||
# | ||
# There are multiple reasons to exclude files from the build context: | ||
# | ||
# 1. Prevent nested folders from being copied into the container (ex: exclude | ||
# /assets/node_modules when copying /assets) | ||
# 2. Reduce the size of the build context and improve build time (ex. /build, /deps, /doc) | ||
# 3. Avoid sending files containing sensitive information | ||
# | ||
# More information on using .dockerignore is available here: | ||
# https://docs.docker.com/engine/reference/builder/#dockerignore-file | ||
|
||
.dockerignore | ||
|
||
# Ignore git, but keep git HEAD and refs to access current commit hash if needed: | ||
# | ||
# $ cat .git/HEAD | awk '{print ".git/"$2}' | xargs cat | ||
# d0b8727759e1e0e7aa3d41707d12376e373d5ecc | ||
.git | ||
!.git/HEAD | ||
!.git/refs | ||
.gitignore | ||
|
||
# Common development/test artifacts | ||
/cover/ | ||
/doc/ | ||
/test/ | ||
/tmp/ | ||
.elixir_ls | ||
|
||
# Mix artifacts | ||
/demo/_build/ | ||
/demo/deps/ | ||
*.ez | ||
|
||
# Generated on crash by the VM | ||
erl_crash.dump | ||
|
||
# Static artifacts - These should be fetched and built inside the Docker image | ||
/assets | ||
/demo/assets/build/ | ||
/demo/assets/node_modules/ | ||
/demo/priv/static/assets/** | ||
!/demo/priv/static/assets/icons | ||
!/demo/priv/static/assets/icons/** | ||
/demo/priv/static/cache_manifest.json | ||
/demo/test |
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,20 @@ | ||
name: Deploy | ||
|
||
on: | ||
workflow_dispatch: | ||
|
||
jobs: | ||
deploy: | ||
name: Deploy demo app | ||
runs-on: ubuntu-latest | ||
concurrency: deploy-group | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: 0 | ||
- uses: superfly/flyctl-actions/setup-flyctl@master | ||
- name: Store build timestamp | ||
run: echo "DOGGO_VERSION=$(git", ["describe", "--tags", "--always"])" >> $GITHUB_ENV | ||
- run: flyctl deploy --remote-only --build-arg="DOGGO_VERSION=${DOGGO_VERSION}" | ||
env: | ||
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }} |
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,113 @@ | ||
# Find eligible builder and runner images on Docker Hub. We use Ubuntu/Debian | ||
# instead of Alpine to avoid DNS resolution issues in production. | ||
# | ||
# https://hub.docker.com/r/hexpm/elixir/tags?page=1&name=ubuntu | ||
# https://hub.docker.com/_/ubuntu?tab=tags | ||
# | ||
# This file is based on these images: | ||
# | ||
# - https://hub.docker.com/r/hexpm/elixir/tags - for the build image | ||
# - https://hub.docker.com/_/debian?tab=tags&page=1&name=bullseye-20240701-slim - for the release image | ||
# - https://pkgs.org/ - resource for finding needed packages | ||
# - Ex: hexpm/elixir:1.17.1-erlang-27.0-debian-bullseye-20240701-slim | ||
# | ||
ARG ELIXIR_VERSION=1.17.2 | ||
ARG OTP_VERSION=27.0.1 | ||
ARG NODE_VERSION=22 | ||
ARG DEBIAN_VERSION=bookworm-20240722-slim | ||
|
||
ARG BUILDER_IMAGE="hexpm/elixir:${ELIXIR_VERSION}-erlang-${OTP_VERSION}-debian-${DEBIAN_VERSION}" | ||
ARG RUNNER_IMAGE="debian:${DEBIAN_VERSION}" | ||
|
||
FROM ${BUILDER_IMAGE} as builder | ||
|
||
ARG DOGGO_VERSION | ||
ARG NODE_VERSION | ||
|
||
# install build dependencies | ||
RUN apt-get update -y \ | ||
&& apt-get install -y build-essential curl git \ | ||
&& mkdir -p /etc/apt/keyrings \ | ||
&& curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg \ | ||
&& echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_${NODE_VERSION}.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list \ | ||
&& apt-get update -y && apt-get install -y nodejs \ | ||
&& corepack enable pnpm \ | ||
&& apt-get clean && rm -f /var/lib/apt/lists/*_* | ||
|
||
# prepare build dir | ||
WORKDIR /app | ||
|
||
# install hex + rebar | ||
RUN mix local.hex --force && \ | ||
mix local.rebar --force | ||
|
||
# set build ENV | ||
ENV MIX_ENV="prod" | ||
ENV VERSION=${DOGGO_VERSION} | ||
|
||
RUN mkdir demo | ||
|
||
# install mix dependencies | ||
COPY demo/mix.exs demo/mix.lock ./demo | ||
RUN cd demo && mix deps.get --only $MIX_ENV | ||
RUN cd demo && mkdir config | ||
|
||
COPY mix.exs mix.exs | ||
COPY mix.lock mix.lock | ||
COPY lib lib | ||
|
||
# copy compile-time config files before we compile dependencies | ||
# to ensure any relevant config change will trigger the dependencies | ||
# to be re-compiled. | ||
COPY demo/config/config.exs demo/config/${MIX_ENV}.exs config/ | ||
RUN cd demo && mix deps.compile | ||
|
||
COPY demo/priv demo/priv | ||
COPY demo/lib demo/lib | ||
COPY demo/assets demo/assets | ||
COPY demo/storybook demo/storybook | ||
|
||
# compile assets | ||
RUN cd demo && mix assets.setup && mix assets.deploy | ||
|
||
# Compile the release | ||
RUN cd demo && mix compile | ||
|
||
# Changes to config/runtime.exs don't require recompiling the code | ||
COPY demo/config/runtime.exs demo/config/ | ||
|
||
COPY demo/rel demo/rel | ||
RUN cd demo && mix release | ||
|
||
# start a new build stage so that the final image will only contain | ||
# the compiled release and other runtime necessities | ||
FROM ${RUNNER_IMAGE} | ||
|
||
RUN apt-get update -y && \ | ||
apt-get install -y libstdc++6 openssl libncurses5 locales ca-certificates \ | ||
&& apt-get clean && rm -f /var/lib/apt/lists/*_* | ||
|
||
# Set the locale | ||
RUN sed -i '/en_US.UTF-8/s/^# //g' /etc/locale.gen && locale-gen | ||
|
||
ENV LANG en_US.UTF-8 | ||
ENV LANGUAGE en_US:en | ||
ENV LC_ALL en_US.UTF-8 | ||
|
||
WORKDIR "/app" | ||
RUN chown nobody /app | ||
|
||
# set runner ENV | ||
ENV MIX_ENV="prod" | ||
|
||
# Only copy the final release from the build stage | ||
COPY --from=builder --chown=nobody:root /app/demo/_build/${MIX_ENV}/rel/demo ./ | ||
|
||
USER nobody | ||
|
||
# If using an environment that doesn't automatically reap zombie processes, it is | ||
# advised to add an init process such as tini via `apt-get install` | ||
# above and adding an entrypoint. See https://github.com/krallin/tini for details | ||
# ENTRYPOINT ["/tini", "--"] | ||
|
||
CMD ["/app/bin/server"] |
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 |
---|---|---|
|
@@ -35,5 +35,6 @@ | |
"phoenix": "link:../deps/phoenix", | ||
"phoenix_html": "link:../deps/phoenix_html", | ||
"phoenix_live_view": "link:../deps/phoenix_live_view" | ||
} | ||
}, | ||
"packageManager": "[email protected]+sha512.38dc6fba8dba35b39340b9700112c2fe1e12f10b17134715a4aa98ccf7bb035e76fd981cf0bb384dfa98f8d6af5481c2bef2f4266a24bfa20c34eb7147ce0b5e" | ||
} |
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
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
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
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,13 @@ | ||
#!/bin/sh | ||
|
||
# configure node for distributed erlang with IPV6 support | ||
export ERL_AFLAGS="-proto_dist inet6_tcp" | ||
export ECTO_IPV6="true" | ||
export DNS_CLUSTER_QUERY="${FLY_APP_NAME}.internal" | ||
export RELEASE_DISTRIBUTION="name" | ||
export RELEASE_NODE="${FLY_APP_NAME}-${FLY_IMAGE_REF##*-}@${FLY_PRIVATE_IP}" | ||
|
||
# Uncomment to send crash dumps to stderr | ||
# This can be useful for debugging, but may log sensitive information | ||
# export ERL_CRASH_DUMP=/dev/stderr | ||
# export ERL_CRASH_DUMP_BYTES=4096 |
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,5 @@ | ||
#!/bin/sh | ||
set -eu | ||
|
||
cd -P -- "$(dirname -- "$0")" | ||
PHX_SERVER=true exec ./demo start |
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,2 @@ | ||
set PHX_SERVER=true | ||
call "%~dp0\demo" start |