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

doc: add log rotation and log shipping sidecar examples #142

Closed
jasonodonnell opened this issue Dec 9, 2019 · 7 comments
Closed

doc: add log rotation and log shipping sidecar examples #142

jasonodonnell opened this issue Dec 9, 2019 · 7 comments
Labels
docs Improvements or additions to documentation enhancement New feature or request

Comments

@jasonodonnell
Copy link
Contributor

Add an example to the documentation that sets up Vault Helm to include a sidecar container that rotates Vault audit logs to satisfy this issue: #109.

This would use server.extraContainers to add in any other containers we may need.

References:

@jasonodonnell jasonodonnell added enhancement New feature or request docs Improvements or additions to documentation labels Dec 9, 2019
@jasonodonnell jasonodonnell changed the title doc: add log rotation sidecar example doc: add log rotation and log shipping sidecar examples Dec 9, 2019
@sidewinder12s
Copy link

Are there any examples of how to setup these sidecars?

I'm running into a lot of trouble trying to get this working correctly with the number of security bits enabled that make most off the shelf sidecar containers just break because they all assume they can run as root.

@reddy9694
Copy link

Have you found any workaround for this ..?

Are there any examples of how to setup these sidecars?

I'm running into a lot of trouble trying to get this working correctly with the number of security bits enabled that make most off the shelf sidecar containers just break because they all assume they can run as root.

@sidewinder12s
Copy link

sidewinder12s commented Apr 29, 2021

I ended up writing a custom container with logrotate & a go based cron scheduler. Due to the security settings on Vault most OSS log rotate containers just didn't work and I wish I had just started with something custom.

@lhw
Copy link

lhw commented Jun 9, 2022

I know reviving an old issue is kind of annoying. But this is the best fitting place right now as its the first search hit for the exact issue.

I ended up writing a custom container with logrotate & a go based cron scheduler. Due to the security settings on Vault most OSS log rotate containers just didn't work and I wish I had just started with something custom.

I took this as inspiration to update this old issue with a solution for the problem at hand:
Here is the go binary and container which is specifically setup for this helm chart deployment (uid/gid): https://github.com/HanseMerkur/vault-logrotate just build it according to the dockerfile and it should work.

The values for the most recent helm charts (v0.20.1) look something like this:

vault:
  server:
    # HUP signal for logrotate
    shareProcessNamespace: true
    # Add the lograte config from a config map
    volumes:
      - name: logrotate-config
        configMap:
          name: logrotate-config
    # And finally the container
    extraContainers:
     - name: auditlog-rotator
       image: vault-logrotate:latest
       imagePullPolicy: Always
       env:
         - name: CRONTAB
           value: "*/5 * * * *"
       volumeMounts:
       - mountPath: /etc/logrotate.conf
         name: logrotate-config
         subPath: logrotate.conf
         readOnly: true
       - mountPath: /vault/audit
         name: audit

The logrotate.conf ConfigMap can look something like this:

apiVersion: v1
kind: ConfigMap
metadata:
  name: logrotate-config
data:
  logrotate.conf: |    
    /vault/audit/vault.log {
        copytruncate
        size 100M
        missingok
        nocompress

        postrotate
            pkill -HUP vault
        endscript
    }

@Jaturu
Copy link

Jaturu commented Aug 30, 2022

Adding another example for a scenario that is using kubernetes, raft with integrated storage and persistent volumes that are ReadWriteOnce.

Dockerfile

There is an issue with Alpine's index for edge/community where the supercronic package is not included. In addition, it would be necessary to modify the /etc/apk/repositories file in order to pull the package so I choose to copy it in. You made need to change the arch type to match your environment.

FROM hashicorp/vault:latest

COPY logrotate.conf /etc/logrotate.conf
COPY --chown=vault:vault run.sh /tmp/run.sh
COPY --chown=vault:vault supercronic-0.2.1-r2.apk /tmp/supercronic-0.2.1-r2.apk
COPY docker-entrypoint.sh /usr/local/bin/docker-entrypoint.sh

RUN apk update && \
       apk add --no-cache \
       logrotate && \
       chmod 0755 /tmp/run.sh && \
       cd /tmp && \
       apk add --no-cache supercronic-0.2.1-r2.apk

ENTRYPOINT ["docker-entrypoint.sh"]

run.sh

#!/bin/sh
echo 'SHELL=/bin/sh' > /home/vault/vaultcrontab
echo '* * * * * /home/vault/logrotate.sh' >> /home/vault/vaultcrontab
echo '/usr/sbin/logrotate --state=/home/vault/logrotate.status /etc/logrotate.conf' >> /home/vault/logrotate.sh
chmod 0755 /home/vault/logrotate.sh

supercronic /home/vault/vaultcrontab &

docker-entrypoint.sh

I pulled the latest version and then added one line for starting supercronic using run.sh.

#!/usr/bin/dumb-init /bin/sh
set -e

# Note above that we run dumb-init as PID 1 in order to reap zombie processes
# as well as forward signals to all processes in its session. Normally, sh
# wouldn't do either of these functions so we'd leak zombies as well as do
# unclean termination of all our sub-processes.

# Prevent core dumps
ulimit -c 0

# Start supercronic
/tmp/run.sh
<snip>

logrotate.conf

/vault/audit/audit.log {
    copytruncate
    size 10M
    missingok
    nocompress
    notifempty
    rotate 7

    postrotate
        pkill -HUP vault
    endscript
}

@hajdukda
Copy link

hajdukda commented Jan 5, 2024

https://github.com/HanseMerkur/vault-logrotate

If anyone decides to use it - keep in mind that dockerfile is incorrectly built, rename the go binary, pkill/pgrep will point at self and kill itself causing interrupts.

This script also does not respect graceful shutdowns. Subscribe to system calls for SIGTERM and afterwards to ctx.Done() returned by cron.

@jpenghashi
Copy link

Thank you so much for the discussions!

I made a step-by-step tutorial based on the comment #142 (comment).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
docs Improvements or additions to documentation enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

7 participants