-
Notifications
You must be signed in to change notification settings - Fork 15
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
9 changed files
with
195 additions
and
116 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
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,132 @@ | ||
# https://docs.ghost.org/faq/node-versions/ | ||
# https://github.com/nodejs/Release (looking for "LTS") | ||
# https://github.com/TryGhost/Ghost/blob/v4.1.2/package.json#L38 | ||
FROM node:18-bookworm | ||
|
||
# grab gosu for easy step-down from root | ||
# https://github.com/tianon/gosu/releases | ||
ENV GOSU_VERSION 1.16 | ||
RUN set -eux; \ | ||
# save list of currently installed packages for later so we can clean up | ||
savedAptMark="$(apt-mark showmanual)"; \ | ||
apt-get update && apt-get upgrade -y; \ | ||
apt-get install -y --no-install-recommends ca-certificates gnupg wget; \ | ||
rm -rf /var/lib/apt/lists/*; \ | ||
\ | ||
dpkgArch="$(dpkg --print-architecture | awk -F- '{ print $NF }')"; \ | ||
wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch"; \ | ||
wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch.asc"; \ | ||
\ | ||
# verify the signature | ||
export GNUPGHOME="$(mktemp -d)"; \ | ||
gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4; \ | ||
gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu; \ | ||
gpgconf --kill all; \ | ||
rm -rf "$GNUPGHOME" /usr/local/bin/gosu.asc; \ | ||
\ | ||
# clean up fetch dependencies | ||
apt-mark auto '.*' > /dev/null; \ | ||
[ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; \ | ||
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \ | ||
\ | ||
chmod +x /usr/local/bin/gosu; \ | ||
# verify that the binary works | ||
gosu --version; \ | ||
gosu nobody true | ||
|
||
ENV NODE_ENV production | ||
|
||
# ENV GHOST_CLI_VERSION 1.24.1 | ||
RUN set -eux; \ | ||
npm install -g "ghost-cli@latest"; \ | ||
npm cache clean --force | ||
|
||
ENV GHOST_INSTALL /var/lib/ghost | ||
ENV GHOST_CONTENT /var/lib/ghost/content | ||
|
||
ARG GHOST_VERSION | ||
ENV GHOST_VERSION $GHOST_VERSION | ||
|
||
RUN set -eux; \ | ||
mkdir -p "$GHOST_INSTALL"; \ | ||
chown node:node "$GHOST_INSTALL"; \ | ||
\ | ||
savedAptMark="$(apt-mark showmanual)"; \ | ||
aptPurge=; \ | ||
\ | ||
installCmd='gosu node ghost install "$GHOST_VERSION" --db mysql --dbhost mysql --no-prompt --no-stack --no-setup --dir "$GHOST_INSTALL"'; \ | ||
if ! eval "$installCmd"; then \ | ||
aptPurge=1; \ | ||
apt-get update && apt-get upgrade -y; \ | ||
apt-get install -y --no-install-recommends g++ make python3; \ | ||
eval "$installCmd"; \ | ||
fi; \ | ||
\ | ||
# Tell Ghost to listen on all ips and not prompt for additional configuration | ||
cd "$GHOST_INSTALL"; \ | ||
gosu node ghost config --no-prompt --ip '::' --port 2368 --url 'http://localhost:2368'; \ | ||
gosu node ghost config paths.contentPath "$GHOST_CONTENT"; \ | ||
\ | ||
# make a config.json symlink for NODE_ENV=development (and sanity check that it's correct) | ||
gosu node ln -s config.production.json "$GHOST_INSTALL/config.development.json"; \ | ||
readlink -f "$GHOST_INSTALL/config.development.json"; \ | ||
\ | ||
# need to save initial content for pre-seeding empty volumes | ||
mv "$GHOST_CONTENT" "$GHOST_INSTALL/content.orig"; \ | ||
mkdir -p "$GHOST_CONTENT"; \ | ||
chown node:node "$GHOST_CONTENT"; \ | ||
chmod 1777 "$GHOST_CONTENT"; \ | ||
\ | ||
# force install a few extra packages manually since they're "optional" dependencies | ||
# (which means that if it fails to install, like on ARM/ppc64le/s390x, the failure will be silently ignored and thus turn into a runtime error instead) | ||
# see https://github.com/TryGhost/Ghost/pull/7677 for more details | ||
cd "$GHOST_INSTALL/current"; \ | ||
# scrape the expected versions directly from Ghost/dependencies | ||
packages="$(node -p ' \ | ||
var ghost = require("./package.json"); \ | ||
var transform = require("./node_modules/@tryghost/image-transform/package.json"); \ | ||
[ \ | ||
"sharp@" + transform.optionalDependencies["sharp"], \ | ||
"sqlite3@" + ghost.optionalDependencies["sqlite3"], \ | ||
].join(" ") \ | ||
')"; \ | ||
if echo "$packages" | grep 'undefined'; then exit 1; fi; \ | ||
for package in $packages; do \ | ||
installCmd='gosu node yarn add "$package" --force'; \ | ||
if ! eval "$installCmd"; then \ | ||
# must be some non-amd64 architecture pre-built binaries aren't published for, so let's install some build deps and do-it-all-over-again | ||
aptPurge=1; \ | ||
apt-get update && apt-get upgrade -y; \ | ||
apt-get install -y --no-install-recommends g++ make python3; \ | ||
case "$package" in \ | ||
# TODO sharp@*) apt-get install -y --no-install-recommends libvips-dev ;; \ | ||
sharp@*) apt-get install -y --no-install-recommends libvips-dev ;; \ | ||
# sharp@*) echo >&2 "sorry: libvips 8.10 in Debian bullseye is not new enough (8.12.2+) for sharp 0.30 😞"; continue ;; \ | ||
esac; \ | ||
\ | ||
eval "$installCmd --build-from-source"; \ | ||
fi; \ | ||
done; \ | ||
\ | ||
if [ -n "$aptPurge" ]; then \ | ||
apt-mark showmanual | xargs apt-mark auto > /dev/null; \ | ||
[ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; \ | ||
apt-get purge -y --auto-remove; \ | ||
rm -rf /var/lib/apt/lists/*; \ | ||
fi; \ | ||
\ | ||
gosu node yarn cache clean; \ | ||
gosu node npm cache clean --force; \ | ||
npm cache clean --force; \ | ||
rm -rv /tmp/yarn* /tmp/v8* | ||
|
||
WORKDIR $GHOST_INSTALL | ||
VOLUME $GHOST_CONTENT | ||
|
||
COPY --chmod=0777 docker-entrypoint.sh /usr/local/bin/ | ||
RUN chmod +x /usr/local/bin/docker-entrypoint.sh | ||
ENV PATH $PATH:/usr/local/bin:$GHOST_INSTALL/current/node_modules/.bin | ||
ENTRYPOINT ["docker-entrypoint.sh"] | ||
|
||
EXPOSE 2368 | ||
CMD ["node", "current/index.js"] |
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
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,22 @@ | ||
#!/bin/bash | ||
set -e | ||
|
||
# allow the container to be started with `--user` | ||
if [[ "$*" == node*current/index.js* ]] && [ "$(id -u)" = '0' ]; then | ||
find "$GHOST_CONTENT" \! -user node -exec chown node '{}' + | ||
exec gosu node "$BASH_SOURCE" "$@" | ||
fi | ||
|
||
if [[ "$*" == node*current/index.js* ]]; then | ||
baseDir="$GHOST_INSTALL/content.orig" | ||
for src in "$baseDir"/*/ "$baseDir"/themes/*; do | ||
src="${src%/}" | ||
target="$GHOST_CONTENT/${src#$baseDir/}" | ||
mkdir -p "$(dirname "$target")" | ||
if [ ! -e "$target" ]; then | ||
tar -cC "$(dirname "$src")" "$(basename "$src")" | tar -xC "$(dirname "$target")" | ||
fi | ||
done | ||
fi | ||
|
||
exec "$@" |