Skip to content

Commit 9320c33

Browse files
committed
Add bitcoin core v28.0
1 parent 03b8411 commit 9320c33

File tree

5 files changed

+310
-0
lines changed

5 files changed

+310
-0
lines changed

28/Dockerfile

Lines changed: 67 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
FROM debian:bookworm-slim
2+
3+
ARG UID=101
4+
ARG GID=101
5+
6+
LABEL maintainer.0="João Fonseca (@joaopaulofonseca)" \
7+
maintainer.1="Pedro Branco (@pedrobranco)" \
8+
maintainer.2="Rui Marinho (@ruimarinho)"
9+
10+
RUN groupadd --gid ${GID} bitcoin \
11+
&& useradd --create-home --no-log-init -u ${UID} -g ${GID} bitcoin \
12+
&& apt-get update -y \
13+
&& apt-get install -y curl gnupg gosu \
14+
&& apt-get clean \
15+
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
16+
17+
ARG TARGETPLATFORM
18+
ENV BITCOIN_VERSION=28.0
19+
ENV BITCOIN_DATA=/home/bitcoin/.bitcoin
20+
ENV PATH=/opt/bitcoin-${BITCOIN_VERSION}/bin:$PATH
21+
22+
RUN set -ex \
23+
&& if [ "${TARGETPLATFORM}" = "linux/amd64" ]; then export TARGETPLATFORM=x86_64-linux-gnu; fi \
24+
&& if [ "${TARGETPLATFORM}" = "linux/arm64" ]; then export TARGETPLATFORM=aarch64-linux-gnu; fi \
25+
&& if [ "${TARGETPLATFORM}" = "linux/arm/v7" ]; then export TARGETPLATFORM=arm-linux-gnueabihf; fi \
26+
&& for key in \
27+
101598DC823C1B5F9A6624ABA5E0907A0380E6C3 \
28+
6A8F9C266528E25AEB1D7731C2371D91CB716EA7 \
29+
2840EAABF4BC9F0FFD716AFAFBAFCC46DE2D3FE2 \
30+
E86AE73439625BBEE306AAE6B66D427F873CB1A3 \
31+
A0083660F235A27000CD3C81CE6EC49945C17EA6 \
32+
F19F5FF2B0589EC341220045BA03F4DBE0C63FB4 \
33+
637DB1E23370F84AFF88CCE03152347D07DA627C \
34+
ED9BDF7AD6A55E232E84524257FF9BDBCC301009 \
35+
CFB16E21C950F67FA95E558F2EEB9F5CC09526C1 \
36+
152812300785C96444D3334D17565732E08E5E41 \
37+
C388F6961FB972A95678E327F62711DBDCA8AE56 \
38+
9DEAE0DC7063249FB05474681E4AED62986CD25D \
39+
D1DBF2C4B96F2DEBF4C16654410108112E7EA81F \
40+
; do \
41+
gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" || \
42+
gpg --batch --keyserver keys.openpgp.org --recv-keys "$key" || \
43+
gpg --batch --keyserver pgp.mit.edu --recv-keys "$key" || \
44+
gpg --batch --keyserver keyserver.pgp.com --recv-keys "$key" || \
45+
gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys "$key" || \
46+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" ; \
47+
done \
48+
&& curl -SLO https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/bitcoin-${BITCOIN_VERSION}-${TARGETPLATFORM}.tar.gz \
49+
&& curl -SLO https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/SHA256SUMS \
50+
&& curl -SLO https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/SHA256SUMS.asc \
51+
&& gpg --verify SHA256SUMS.asc SHA256SUMS \
52+
&& grep " bitcoin-${BITCOIN_VERSION}-${TARGETPLATFORM}.tar.gz" SHA256SUMS | sha256sum -c - \
53+
&& tar -xzf *.tar.gz -C /opt \
54+
&& rm *.tar.gz *.asc \
55+
&& rm -rf /opt/bitcoin-${BITCOIN_VERSION}/bin/bitcoin-qt
56+
57+
COPY docker-entrypoint.sh /entrypoint.sh
58+
59+
VOLUME ["/home/bitcoin/.bitcoin"]
60+
61+
EXPOSE 8332 8333 18332 18333 18443 18444 38333 38332
62+
63+
ENTRYPOINT ["/entrypoint.sh"]
64+
65+
RUN bitcoind -version | grep "Bitcoin Core version v${BITCOIN_VERSION}"
66+
67+
CMD ["bitcoind"]

28/alpine/Dockerfile

Lines changed: 163 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,163 @@
1+
# Build stage for BerkeleyDB
2+
FROM alpine as berkeleydb
3+
4+
RUN sed -i 's/http\:\/\/dl-cdn.alpinelinux.org/https\:\/\/alpine.global.ssl.fastly.net/g' /etc/apk/repositories
5+
RUN apk --no-cache add autoconf
6+
RUN apk --no-cache add automake
7+
RUN apk --no-cache add build-base
8+
RUN apk --no-cache add libressl
9+
10+
ENV BERKELEYDB_VERSION=db-4.8.30.NC
11+
ENV BERKELEYDB_PREFIX=/opt/${BERKELEYDB_VERSION}
12+
13+
RUN wget https://download.oracle.com/berkeley-db/${BERKELEYDB_VERSION}.tar.gz
14+
RUN tar -xzf *.tar.gz
15+
RUN sed s/__atomic_compare_exchange/__atomic_compare_exchange_db/g -i ${BERKELEYDB_VERSION}/dbinc/atomic.h
16+
RUN mkdir -p ${BERKELEYDB_PREFIX}
17+
18+
WORKDIR /${BERKELEYDB_VERSION}/build_unix
19+
20+
RUN ../dist/configure --enable-cxx --disable-shared --with-pic --prefix=${BERKELEYDB_PREFIX} --build=aarch64-unknown-linux-gnu
21+
RUN make -j4
22+
RUN make install
23+
RUN rm -rf ${BERKELEYDB_PREFIX}/docs
24+
25+
# Build stage for Bitcoin Core
26+
FROM alpine as bitcoin-core
27+
28+
COPY --from=berkeleydb /opt /opt
29+
30+
ENV GNUPGHOME=/tmp/gnupg
31+
32+
RUN sed -i 's/http\:\/\/dl-cdn.alpinelinux.org/https\:\/\/alpine.global.ssl.fastly.net/g' /etc/apk/repositories
33+
RUN apk --no-cache add autoconf
34+
RUN apk --no-cache add automake
35+
RUN apk --no-cache add boost-dev
36+
RUN apk --no-cache add build-base
37+
RUN apk --no-cache add chrpath
38+
RUN apk --no-cache add file
39+
RUN apk --no-cache add gnupg
40+
RUN apk --no-cache add libevent-dev
41+
RUN apk --no-cache add libressl
42+
RUN apk --no-cache add libtool
43+
RUN apk --no-cache add linux-headers
44+
RUN apk --no-cache add sqlite-dev
45+
RUN apk --no-cache add zeromq-dev
46+
RUN mkdir -p ${GNUPGHOME}
47+
RUN set -ex \
48+
&& for key in \
49+
101598DC823C1B5F9A6624ABA5E0907A0380E6C3 \
50+
<<<<<<< HEAD
51+
F2CFC4ABD0B99D837EEBB7D09B79B45691DB4173 \
52+
152812300785C96444D3334D17565732E08E5E41 \
53+
0AD83877C1F0CD1EE9BD660AD7CC770B81FD22A8 \
54+
C060A6635913D98A3587D7DB1C2491FFEB0EF770 \
55+
CFB16E21C950F67FA95E558F2EEB9F5CC09526C1 \
56+
F19F5FF2B0589EC341220045BA03F4DBE0C63FB4 \
57+
F4FC70F07310028424EFC20A8E4256593F177720 \
58+
D1DBF2C4B96F2DEBF4C16654410108112E7EA81F \
59+
287AE4CA1187C68C08B49CB2D11BD4F33F1DB499 \
60+
9DEAE0DC7063249FB05474681E4AED62986CD25D \
61+
6A8F9C266528E25AEB1D7731C2371D91CB716EA7 \
62+
28E72909F1717FE9607754F8A7BEB2621678D37D \
63+
616516B8EB6ED02882FC4A7A8ADCB558C4F33D65 \
64+
ED9BDF7AD6A55E232E84524257FF9BDBCC301009 \
65+
C388F6961FB972A95678E327F62711DBDCA8AE56 \
66+
637DB1E23370F84AFF88CCE03152347D07DA627C \
67+
E86AE73439625BBEE306AAE6B66D427F873CB1A3 \
68+
E61773CD6E01040E2F1BD78CE7E2984B6289C93A \
69+
=======
70+
6A8F9C266528E25AEB1D7731C2371D91CB716EA7 \
71+
2840EAABF4BC9F0FFD716AFAFBAFCC46DE2D3FE2 \
72+
E86AE73439625BBEE306AAE6B66D427F873CB1A3 \
73+
A0083660F235A27000CD3C81CE6EC49945C17EA6 \
74+
F19F5FF2B0589EC341220045BA03F4DBE0C63FB4 \
75+
637DB1E23370F84AFF88CCE03152347D07DA627C \
76+
ED9BDF7AD6A55E232E84524257FF9BDBCC301009 \
77+
CFB16E21C950F67FA95E558F2EEB9F5CC09526C1 \
78+
152812300785C96444D3334D17565732E08E5E41 \
79+
C388F6961FB972A95678E327F62711DBDCA8AE56 \
80+
9DEAE0DC7063249FB05474681E4AED62986CD25D \
81+
D1DBF2C4B96F2DEBF4C16654410108112E7EA81F \
82+
>>>>>>> bcd1336 (Add bitcoin core v28.0)
83+
; do \
84+
gpg --batch --keyserver keyserver.ubuntu.com --recv-keys "$key" || \
85+
gpg --batch --keyserver keys.openpgp.org --recv-keys "$key" || \
86+
gpg --batch --keyserver keyserver.pgp.com --recv-keys "$key" || \
87+
gpg --batch --keyserver ha.pool.sks-keyservers.net --recv-keys "$key" || \
88+
gpg --batch --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys "$key" ; \
89+
done
90+
91+
ENV BITCOIN_VERSION=28.0
92+
ENV BITCOIN_PREFIX=/opt/bitcoin-${BITCOIN_VERSION}
93+
94+
RUN wget https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/SHA256SUMS
95+
RUN wget https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/SHA256SUMS.asc
96+
RUN wget https://bitcoincore.org/bin/bitcoin-core-${BITCOIN_VERSION}/bitcoin-${BITCOIN_VERSION}.tar.gz
97+
RUN gpg --verify SHA256SUMS.asc SHA256SUMS
98+
RUN grep " bitcoin-${BITCOIN_VERSION}.tar.gz\$" SHA256SUMS | sha256sum -c -
99+
RUN tar -xzf *.tar.gz
100+
101+
WORKDIR /bitcoin-${BITCOIN_VERSION}
102+
103+
RUN sed -i s:sys/fcntl.h:fcntl.h: src/compat/compat.h
104+
RUN ./autogen.sh
105+
RUN ./configure LDFLAGS=-L`ls -d /opt/db*`/lib/ CPPFLAGS=-I`ls -d /opt/db*`/include/ \
106+
--prefix=${BITCOIN_PREFIX} \
107+
--mandir=/usr/share/man \
108+
--disable-tests \
109+
--disable-bench \
110+
--disable-ccache \
111+
--with-gui=no \
112+
--with-utils \
113+
--with-libs \
114+
--with-sqlite=yes \
115+
--with-daemon
116+
RUN make -j4
117+
RUN make install
118+
RUN strip ${BITCOIN_PREFIX}/bin/bitcoin-cli
119+
RUN strip ${BITCOIN_PREFIX}/bin/bitcoin-tx
120+
RUN strip ${BITCOIN_PREFIX}/bin/bitcoind
121+
RUN strip ${BITCOIN_PREFIX}/lib/libbitcoinconsensus.a
122+
RUN strip ${BITCOIN_PREFIX}/lib/libbitcoinconsensus.so.0.0.0
123+
124+
# Build stage for compiled artifacts
125+
FROM alpine
126+
127+
ARG UID=100
128+
ARG GID=101
129+
130+
LABEL maintainer.0="João Fonseca (@joaopaulofonseca)" \
131+
maintainer.1="Pedro Branco (@pedrobranco)" \
132+
maintainer.2="Rui Marinho (@ruimarinho)"
133+
134+
RUN addgroup bitcoin --gid ${GID} --system
135+
RUN adduser --uid ${UID} --system bitcoin --ingroup bitcoin
136+
RUN sed -i 's/http\:\/\/dl-cdn.alpinelinux.org/https\:\/\/alpine.global.ssl.fastly.net/g' /etc/apk/repositories
137+
RUN apk --no-cache add \
138+
boost-filesystem \
139+
boost-system \
140+
boost-thread \
141+
libevent \
142+
libzmq \
143+
shadow \
144+
sqlite-dev \
145+
su-exec
146+
147+
ENV BITCOIN_DATA=/home/bitcoin/.bitcoin
148+
ENV BITCOIN_VERSION=28.0
149+
ENV BITCOIN_PREFIX=/opt/bitcoin-${BITCOIN_VERSION}
150+
ENV PATH=${BITCOIN_PREFIX}/bin:$PATH
151+
152+
COPY --from=bitcoin-core /opt /opt
153+
COPY docker-entrypoint.sh /entrypoint.sh
154+
155+
VOLUME ["/home/bitcoin/.bitcoin"]
156+
157+
EXPOSE 8332 8333 18332 18333 18444
158+
159+
ENTRYPOINT ["/entrypoint.sh"]
160+
161+
RUN bitcoind -version | grep "Bitcoin Core version v${BITCOIN_VERSION}"
162+
163+
CMD ["bitcoind"]

28/alpine/docker-entrypoint.sh

Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
#!/bin/sh
2+
set -e
3+
4+
if [ -n "${UID+x}" ] && [ "${UID}" != "0" ]; then
5+
usermod -u "$UID" bitcoin
6+
fi
7+
8+
if [ -n "${GID+x}" ] && [ "${GID}" != "0" ]; then
9+
groupmod -g "$GID" bitcoin
10+
fi
11+
12+
echo "$0: assuming uid:gid for bitcoin:bitcoin of $(id -u bitcoin):$(id -g bitcoin)"
13+
14+
if [ $(echo "$1" | cut -c1) = "-" ]; then
15+
echo "$0: assuming arguments for bitcoind"
16+
17+
set -- bitcoind "$@"
18+
fi
19+
20+
if [ $(echo "$1" | cut -c1) = "-" ] || [ "$1" = "bitcoind" ]; then
21+
mkdir -p "$BITCOIN_DATA"
22+
chmod 700 "$BITCOIN_DATA"
23+
# Fix permissions for home dir.
24+
chown -R bitcoin:bitcoin "$(getent passwd bitcoin | cut -d: -f6)"
25+
# Fix permissions for bitcoin data dir.
26+
chown -R bitcoin:bitcoin "$BITCOIN_DATA"
27+
28+
echo "$0: setting data directory to $BITCOIN_DATA"
29+
30+
set -- "$@" -datadir="$BITCOIN_DATA"
31+
fi
32+
33+
if [ "$1" = "bitcoind" ] || [ "$1" = "bitcoin-cli" ] || [ "$1" = "bitcoin-tx" ]; then
34+
echo
35+
exec su-exec bitcoin "$@"
36+
fi
37+
38+
echo
39+
exec "$@"

28/docker-entrypoint.sh

Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
#!/bin/bash
2+
set -e
3+
4+
if [ -n "${UID+x}" ] && [ "${UID}" != "0" ]; then
5+
usermod -u "$UID" bitcoin
6+
fi
7+
8+
if [ -n "${GID+x}" ] && [ "${GID}" != "0" ]; then
9+
groupmod -g "$GID" bitcoin
10+
fi
11+
12+
echo "$0: assuming uid:gid for bitcoin:bitcoin of $(id -u bitcoin):$(id -g bitcoin)"
13+
14+
if [ $(echo "$1" | cut -c1) = "-" ]; then
15+
echo "$0: assuming arguments for bitcoind"
16+
17+
set -- bitcoind "$@"
18+
fi
19+
20+
if [ $(echo "$1" | cut -c1) = "-" ] || [ "$1" = "bitcoind" ]; then
21+
mkdir -p "$BITCOIN_DATA"
22+
chmod 700 "$BITCOIN_DATA"
23+
# Fix permissions for home dir.
24+
chown -R bitcoin:bitcoin "$(getent passwd bitcoin | cut -d: -f6)"
25+
# Fix permissions for bitcoin data dir.
26+
chown -R bitcoin:bitcoin "$BITCOIN_DATA"
27+
28+
echo "$0: setting data directory to $BITCOIN_DATA"
29+
30+
set -- "$@" -datadir="$BITCOIN_DATA"
31+
fi
32+
33+
if [ "$1" = "bitcoind" ] || [ "$1" = "bitcoin-cli" ] || [ "$1" = "bitcoin-tx" ]; then
34+
echo
35+
exec gosu bitcoin "$@"
36+
fi
37+
38+
echo
39+
exec "$@"

README.md

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,8 @@ A bitcoin-core docker image with support for the following platforms:
99
[![lightninglabs/bitcoin-core][docker-pulls-image]][docker-hub-url] [![lightninglabs/bitcoin-core][docker-stars-image]][docker-hub-url] [![lightninglabs/bitcoin-core][docker-size-image]][docker-hub-url]
1010

1111
## Tags
12+
- `28.0`, `28` ([28/Dockerfile](https://github.com/lightninglabs/docker-bitcoin-core/blob/master/28/Dockerfile)) [**multi-arch**]
13+
- `28.0-alpine`, `28-alpine` ([27/alpine/Dockerfile](https://github.com/lightninglabs/docker-bitcoin-core/blob/master/28/alpine/Dockerfile))
1214

1315
- `27.0`, `27` ([27/Dockerfile](https://github.com/lightninglabs/docker-bitcoin-core/blob/master/27/Dockerfile)) [**multi-arch**]
1416
- `27.0-alpine`, `27-alpine` ([27/alpine/Dockerfile](https://github.com/lightninglabs/docker-bitcoin-core/blob/master/27/alpine/Dockerfile))

0 commit comments

Comments
 (0)