This is a fork of dexafree/ghostbin Dockerfile but include recent package and security update for ghostbin/spectre
- Dockerfile :
- golang : 1.17.6 -> 1.21.0
- alpine : 3.15 -> 3.18
- Ghostbin/spectre :
- use the latest version
- Dockerfile :
- golang : 1.8.3 -> 1.17.6
- alpine : 3.06 -> 3.15
This is a repository I've created in order to have a Docker image for running Ghostbin in a private server.
It allows you to run it in your own computer, internally in your company, or host it in a public server.
The Ghostbin project is also Open Source, but due to its hard setup, I thought that creating a Dockerfile and a Docker image would be helpful for people like me who want to host it on their own hardware.
The base image used for this Dockerfile is golang:1.8.3-alpine3.6
:
- Golang as Ghostbin is written in Go, an thus is needed to compile it.
- Alpine as it provides a smaller base image, and therefore the resulting image will also be smaller.
In order for expiration, encryption and syntax highlighting to work, you need to be using Docker in a Linux system.
This is due to a difference in the internal Filesystem Docker for Linux uses: The FS driver used on Docker for macOS and Docker for Windows does not support the use of xattrs
(extended attributes: saving metadata for a file in the filesystem), and Ghostbin relies on those attributes for saving the paste properties, such as the language, the encryption password and the expiration (if any of those is set).
So, you will need to run it on a host using Docker for Linux in order for them to work.
As the master branch of the Ghostbin project (link to the latest master commit at the time of writing this readme) is not stable right now (it has mixed namespaces and is in the middle of a refactor), this Dockerfile uses the latest commit in the v1-stable
branch, so it will probably not be running the exact same Ghostbin version the production server is running.
I spoke to the author and he told me he is working in making it stable, so in the future this image should adapt to the latest version.
In order to run the image, you need to know three things:
- Ports: This image exposes the 8619 port for serving the Ghostbin site.
- Logs volume: This image exposes a
logs
volume, so you are able to read the logs that Ghostbin outputs. The path inside the container will be/logs
- Data volume: This image exposes a
data
volume, so you are able to access and persist things like pastes, session keys and accounts through containers (and survive restarts).
So, a way to run this container exposing all 3 things would be:
docker run -it -d --name="ghostbin" -p 8619:8619 -v /var/log/ghostbin:/logs -v /var/data/ghostbin:/data borrougagnou/ghostbin-updated
It would expose the 8619 port of the host machine, mount the logs
volume at the local path /var/log/ghostbin
and mount the data
volume at the local path /var/data/ghostbin
. You can adapt it to any use you need.