Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ensure php-fpm-exporter binary is patched #323

Merged
merged 4 commits into from
Oct 31, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions gh-actions-bake.hcl
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,17 @@ target "php-fpm" {
"org.opencontainers.image.source" = "https://github.com/dpc-sdp/bay/blob/6.x/images/bay-php/Dockerfile.fpm"
}
}
target "php-fpm-exporter" {
inherits = ["docker-metadata-action"]
context = "${CONTEXT}/php-fpm-exporter"
dockerfile = "Dockerfile"

platforms = ["linux/amd64", "linux/arm64"]

labels = {
"org.opencontainers.image.source" = "https://github.com/dpc-sdp/bay/blob/6.x/images/bay-php-exporter/Dockerfile"
}
}
target "ripple-static" {
inherits = ["docker-metadata-action"]
context = "${CONTEXT}/ripple-static"
Expand Down
18 changes: 18 additions & 0 deletions images/php-fpm-exporter/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
FROM golang:latest as builder
RUN git clone https://github.com/hipages/php-fpm_exporter.git /workspace
WORKDIR /workspace
RUN make deps
RUN TARGETPLATFORM=${TARGETPLATFORM:-linux/amd64}; \
GOOS=${TARGETPLATFORM%%/*} GOARCH=${TARGETPLATFORM#*/} go build -o php-fpm-exporter .

FROM gcr.io/distroless/static:nonroot
LABEL org.opencontainers.image.authors="Single Digital Presence"
LABEL org.opencontainers.image.description="Utility to export php-fpm data as prometheus metrics"
LABEL org.opencontainers.image.source="https://github.com/dpc-sdp/bay"

WORKDIR /
EXPOSE 9253
COPY --from=builder /workspace/php-fpm-exporter .
USER nonroot:nonroot
ENTRYPOINT ["/php-fpm-exporter"]
CMD ["server"]
15 changes: 15 additions & 0 deletions images/php-fpm-exporter/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# # Container Image - php-fpm-exporter

Provides a [php-fpm-exporter](https://github.com/hipages/php-fpm_exporter/) image.

## Usage

Container needs to be able to access the php-fpm status endpoint, so should be deployed as a sidecar alongside a php-fpm container.

## Environment Variables

None

## Ports

- `9253` - metrics server
7 changes: 3 additions & 4 deletions images/php/Dockerfile.fpm
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
ARG PHP_VERSION=8.3
FROM ghcr.io/dpc-sdp/bay/php-fpm-exporter:6.x AS php-fpm-exporter
FROM uselagoon/php-${PHP_VERSION}-fpm:latest

ARG BAY_CLI_VERSION=v1.1.3
ARG PHP_FPM_EXPORTER_VERSION=2.2.0

RUN mkdir /bay
COPY 01-bay.ini /usr/local/etc/php/conf.d/
COPY bay-php-config.sh /bay

# Ensure temp dir exists if required
COPY entrypoints/bay-shared-temp-files-dir-check.sh /lagoon/entrypoints
COPY entrypoints/bay-php-fpm_exporter.sh /lagoon/entrypoints
COPY entrypoints/bay-php-fpm-exporter.sh /lagoon/entrypoints

# Add common drupal config.
COPY redis-unavailable.services.yml /bay
Expand All @@ -34,8 +34,7 @@ RUN chmod +x /tmp/bay
RUN mv /tmp/bay /bin/bay

# Install php-fpm_exporter
RUN curl -s -L "https://github.com/hipages/php-fpm_exporter/releases/download/v${PHP_FPM_EXPORTER_VERSION}/php-fpm_exporter_${PHP_FPM_EXPORTER_VERSION}_$(echo ${TARGETPLATFORM:-linux/amd64} | tr '/' '_')" --output /bin/php-fpm_exporter
RUN chmod +x /bin/php-fpm_exporter
COPY --from=php-fpm-exporter /php-fpm-exporter /bin/
EXPOSE 9253

ONBUILD ARG BAY_DISABLE_FUNCTIONS=phpinfo,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,system,exec,shell_exec,passthru,phpinfo,show_source,highlight_file,popen,fopen_with_path,dbmopen,dbase_open,filepro,filepro_rowcount,filepro_retrieve,posix_mkfifo
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#!/usr/bin/env sh
set -euo pipefail

#/ Usage: PHP_FPM_EXPORTER_ENABLED=true ./bay-php-fpm_exporter.sh
#/ Usage: PHP_FPM_EXPORTER_ENABLED=true ./bay-php-fpm-exporter.sh
#/ Options:
#/ --help: Display this help message
usage() { grep '^#/' "$0" | cut -c4- ; exit 0 ; }
Expand All @@ -14,8 +14,8 @@ error() { echoerr "[ERROR] $*" ; }
fatal() { echoerr "[FATAL] $*" ; exit 1 ; }

if [ "${PHP_FPM_EXPORTER_ENABLED:-false}" = "true" ]; then
info starting php-fpm_exporter metrics server
php-fpm_exporter server &
info starting php-fpm-exporter metrics server
php-fpm-exporter server &
else
info php-fpm_exporter metrics server disabled
info php-fpm-exporter metrics server disabled
fi
Loading