Dockerfile 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. # syntax=docker/dockerfile:1
  2. #checkov:skip=CKV_DOCKER_2
  3. #checkov:skip=CKV_DOCKER_3
  4. #checkov:skip=CKV_DOCKER_7
  5. FROM php-base AS common
  6. WORKDIR /app
  7. RUN apt-get update && \
  8. apt-get -y --no-install-recommends install \
  9. mailcap \
  10. libcap2-bin \
  11. && \
  12. apt-get clean && \
  13. rm -rf /var/lib/apt/lists/*
  14. RUN set -eux; \
  15. mkdir -p \
  16. /app/public \
  17. /config/caddy \
  18. /data/caddy \
  19. /etc/caddy; \
  20. sed -i 's/php/frankenphp run/g' /usr/local/bin/docker-php-entrypoint; \
  21. echo '<?php phpinfo();' > /app/public/index.php
  22. COPY --link caddy/frankenphp/Caddyfile /etc/caddy/Caddyfile
  23. RUN curl -sSLf \
  24. -o /usr/local/bin/install-php-extensions \
  25. https://github.com/mlocati/docker-php-extension-installer/releases/latest/download/install-php-extensions && \
  26. chmod +x /usr/local/bin/install-php-extensions
  27. CMD ["--config", "/etc/caddy/Caddyfile", "--adapter", "caddyfile"]
  28. HEALTHCHECK CMD curl -f http://localhost:2019/metrics || exit 1
  29. # See https://caddyserver.com/docs/conventions#file-locations for details
  30. ENV XDG_CONFIG_HOME=/config
  31. ENV XDG_DATA_HOME=/data
  32. EXPOSE 80
  33. EXPOSE 443
  34. EXPOSE 443/udp
  35. EXPOSE 2019
  36. LABEL org.opencontainers.image.title=FrankenPHP
  37. LABEL org.opencontainers.image.description="The modern PHP app server"
  38. LABEL org.opencontainers.image.url=https://frankenphp.dev
  39. LABEL org.opencontainers.image.source=https://github.com/dunglas/frankenphp
  40. LABEL org.opencontainers.image.licenses=MIT
  41. LABEL org.opencontainers.image.vendor="Kévin Dunglas"
  42. FROM common AS builder
  43. ARG FRANKENPHP_VERSION='dev'
  44. SHELL ["/bin/bash", "-o", "pipefail", "-c"]
  45. COPY --from=golang-base /usr/local/go /usr/local/go
  46. ENV PATH=/usr/local/go/bin:$PATH
  47. # This is required to link the FrankenPHP binary to the PHP binary
  48. RUN apt-get update && \
  49. apt-get -y --no-install-recommends install \
  50. libargon2-dev \
  51. libbrotli-dev \
  52. libcurl4-openssl-dev \
  53. libonig-dev \
  54. libreadline-dev \
  55. libsodium-dev \
  56. libsqlite3-dev \
  57. libssl-dev \
  58. libxml2-dev \
  59. zlib1g-dev \
  60. && \
  61. apt-get clean
  62. WORKDIR /go/src/app
  63. COPY --link go.mod go.sum ./
  64. RUN go mod graph | awk '{if ($1 !~ "@") print $2}' | xargs go get
  65. WORKDIR /go/src/app/caddy
  66. COPY --link caddy/go.mod caddy/go.sum ./
  67. RUN go mod graph | awk '{if ($1 !~ "@") print $2}' | xargs go get
  68. WORKDIR /go/src/app
  69. COPY --link *.* ./
  70. COPY --link caddy caddy
  71. COPY --link internal internal
  72. COPY --link testdata testdata
  73. # install edant/watcher (necessary for file watching)
  74. ARG EDANT_WATCHER_VERSION=release
  75. WORKDIR /usr/local/src/watcher
  76. RUN curl -L https://github.com/e-dant/watcher/archive/refs/heads/$EDANT_WATCHER_VERSION.tar.gz | tar xz
  77. WORKDIR /usr/local/src/watcher/watcher-$EDANT_WATCHER_VERSION/watcher-c
  78. RUN cc -o libwatcher.so ./src/watcher-c.cpp -I ./include -I ../include -std=c++17 -O3 -Wall -Wextra -fPIC -shared && \
  79. cp libwatcher.so /usr/local/lib/libwatcher.so && \
  80. ldconfig /usr/local/lib
  81. # See https://github.com/docker-library/php/blob/master/8.3/bookworm/zts/Dockerfile#L57-L59 for PHP values
  82. ENV CGO_CFLAGS="-DFRANKENPHP_VERSION=$FRANKENPHP_VERSION $PHP_CFLAGS"
  83. ENV CGO_CPPFLAGS=$PHP_CPPFLAGS
  84. ENV CGO_LDFLAGS="-lssl -lcrypto -lreadline -largon2 -lcurl -lonig -lz $PHP_LDFLAGS"
  85. WORKDIR /go/src/app/caddy/frankenphp
  86. RUN GOBIN=/usr/local/bin go install -tags 'nobadger,nomysql,nopgx' -ldflags "-w -s -X 'github.com/caddyserver/caddy/v2.CustomVersion=FrankenPHP $FRANKENPHP_VERSION PHP $PHP_VERSION Caddy'" && \
  87. setcap cap_net_bind_service=+ep /usr/local/bin/frankenphp && \
  88. cp Caddyfile /etc/caddy/Caddyfile && \
  89. frankenphp version
  90. WORKDIR /go/src/app
  91. FROM common AS runner
  92. ENV GODEBUG=cgocheck=0
  93. # copy watcher shared library
  94. COPY --from=builder /usr/local/lib/libwatcher* /usr/local/lib/
  95. # fix for the file watcher on arm
  96. RUN apt-get install -y --no-install-recommends libstdc++6 && \
  97. apt-get clean && \
  98. ldconfig
  99. COPY --from=builder /usr/local/bin/frankenphp /usr/local/bin/frankenphp
  100. RUN setcap cap_net_bind_service=+ep /usr/local/bin/frankenphp && \
  101. frankenphp version