|
4 | 4 | ARG USER_ID
|
5 | 5 | ARG GROUP_ID
|
6 | 6 |
|
7 |
| -RUN apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 8842ce5e && \ |
8 |
| - echo "deb http://ppa.launchpad.net/bitcoin/bitcoin/ubuntu xenial main" > /etc/apt/sources.list.d/bitcoin.list |
9 |
| - |
10 |
| -RUN apt-get update && \ |
11 |
| - apt-get install -y bitcoind && \ |
12 |
| - apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* |
13 |
| - |
14 | 7 | ENV HOME /bitcoin
|
15 | 8 |
|
16 | 9 | # add user with specified (or default) user/group ids
|
17 | 10 | ENV USER_ID ${USER_ID:-1000}
|
18 | 11 | ENV GROUP_ID ${GROUP_ID:-1000}
|
19 |
| -RUN groupadd -g ${GROUP_ID} bitcoin |
20 |
| -RUN useradd -u ${USER_ID} -g bitcoin -s /bin/bash -m -d /bitcoin bitcoin |
21 | 12 |
|
22 |
| -RUN chown bitcoin:bitcoin -R /bitcoin |
| 13 | +# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added |
| 14 | +RUN groupadd -g ${GROUP_ID} bitcoin \ |
| 15 | + && useradd -u ${USER_ID} -g bitcoin -s /bin/bash -m -d /bitcoin bitcoin |
23 | 16 |
|
24 |
| -ADD ./bin /usr/local/bin |
25 |
| -RUN chmod a+x /usr/local/bin/* |
| 17 | +RUN apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 8842ce5e && \ |
| 18 | + echo "deb http://ppa.launchpad.net/bitcoin/bitcoin/ubuntu xenial main" > /etc/apt/sources.list.d/bitcoin.list |
| 19 | + |
| 20 | +RUN apt-get update && apt-get install -y --no-install-recommends \ |
| 21 | + bitcoind \ |
| 22 | + && apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* |
| 23 | + |
| 24 | +# grab gosu for easy step-down from root |
| 25 | +ENV GOSU_VERSION 1.7 |
| 26 | +RUN set -x \ |
| 27 | + && apt-get update && apt-get install -y --no-install-recommends \ |
| 28 | + ca-certificates \ |
| 29 | + wget \ |
| 30 | + && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \ |
| 31 | + && wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \ |
| 32 | + && export GNUPGHOME="$(mktemp -d)" \ |
| 33 | + && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \ |
| 34 | + && gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \ |
| 35 | + && rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \ |
| 36 | + && chmod +x /usr/local/bin/gosu \ |
| 37 | + && gosu nobody true \ |
| 38 | + && apt-get purge \ |
| 39 | + ca-certificates \ |
| 40 | + wget \ |
| 41 | + && apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* |
26 | 42 |
|
27 |
| -# For some reason, docker.io (0.9.1~dfsg1-2) pkg in Ubuntu 14.04 has permission |
28 |
| -# denied issues when executing /bin/bash from trusted builds. Building locally |
29 |
| -# works fine (strange). Using the upstream docker (0.11.1) pkg from |
30 |
| -# http://get.docker.io/ubuntu works fine also and seems simpler. |
31 |
| -USER bitcoin |
| 43 | +ADD ./bin /usr/local/bin |
32 | 44 |
|
33 | 45 | VOLUME ["/bitcoin"]
|
34 | 46 |
|
35 | 47 | EXPOSE 8332 8333 18332 18333
|
36 | 48 |
|
37 | 49 | WORKDIR /bitcoin
|
38 | 50 |
|
39 |
| -CMD ["btc_oneshot"] |
| 51 | +COPY docker-entrypoint.sh /usr/local/bin/ |
| 52 | +ENTRYPOINT ["docker-entrypoint.sh"] |
40 | 53 |
|
| 54 | +CMD ["btc_oneshot"] |
0 commit comments