mirror of
https://gitee.com/kennylee/docker.git
synced 2024-12-01 19:38:30 +08:00
新增redis的构建镜像
This commit is contained in:
parent
4a2a7bac0a
commit
9723e9c01e
@ -47,7 +47,7 @@ When you combine this with using volumes-from things begin to get a bit more pow
|
||||
# NFS Server
|
||||
docker run -d -v /tmp ubuntu --name foo bash -c "echo foo > /tmp/foo"
|
||||
docker run -d --name nfs-server --privileged --volumes-from foo cpuguy83/nfs-server /tmp
|
||||
docker inspect --format '{{ .NetworkSettings.IPAddress }}' nfs-server
|
||||
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' nfs-server
|
||||
10.0.1.100
|
||||
```
|
||||
|
||||
|
@ -3,9 +3,38 @@ Docker NFS Server
|
||||
|
||||
fork for [cpuguy83/docker-nfs-server](https://github.com/cpuguy83/docker-nfs-server)
|
||||
|
||||
Test
|
||||
---
|
||||
```bash
|
||||
# 启动 nfs-server
|
||||
docker-compose up -d
|
||||
# 查看nfs-server的ip
|
||||
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' nfs-server
|
||||
# 创建,并且进入centos容器,连接nfs_default网络
|
||||
docker run -it --network="nfs_nfs" --privileged --rm registry.cn-hangzhou.aliyuncs.com/kennylee/centos:7 bash
|
||||
yum makecache && yum install -y showmount nfs-utils
|
||||
rpcbind start
|
||||
showmount -e 172.20.0.2
|
||||
```
|
||||
|
||||
正常的话,会看到下面信息
|
||||
|
||||
>[root@d9febac7e894 ~]# showmount -e 172.24.0.2
|
||||
>Export list for 172.24.0.2:
|
||||
>/tmp *
|
||||
|
||||
```
|
||||
# 挂载
|
||||
mkdir -p /usr/local/test
|
||||
mount -t nfs4 172.20.0.2:/tmp/ /usr/local/test
|
||||
```
|
||||
|
||||
Usage
|
||||
----
|
||||
```bash
|
||||
docker run -d --name nfs --privileged cpuguy83/nfs-server /path/to/share /path/to/share2 /path/to/shareN
|
||||
|
||||
|
||||
docker run -d --name nfs --privileged cpuguy83/nfs-server /path/to/share /path/to/share2 /path/to/shareN
|
||||
```
|
||||
|
||||
|
16
nfs/docker-compose.yml
Normal file
16
nfs/docker-compose.yml
Normal file
@ -0,0 +1,16 @@
|
||||
version: '2'
|
||||
|
||||
networks:
|
||||
&network nfs:
|
||||
driver: bridge
|
||||
|
||||
services:
|
||||
nfs-server:
|
||||
image: registry.cn-hangzhou.aliyuncs.com/kennylee/nfs
|
||||
container_name: "nfs-server"
|
||||
volumes:
|
||||
- /tmp/:/tmp/
|
||||
privileged: true
|
||||
command: /tmp/
|
||||
networks:
|
||||
- *network
|
3
redis/README.md
Normal file
3
redis/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
fork for https://github.com/docker-library/redis
|
||||
|
||||
|
71
redis/image-build/3.2/Dockerfile
Normal file
71
redis/image-build/3.2/Dockerfile
Normal file
@ -0,0 +1,71 @@
|
||||
FROM registry.cn-hangzhou.aliyuncs.com/kennylee/debian:jessie
|
||||
|
||||
# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
|
||||
RUN groupadd -r redis && useradd -r -g redis redis
|
||||
|
||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||
ca-certificates \
|
||||
wget \
|
||||
&& rm -rf /var/lib/apt/lists/*
|
||||
|
||||
# grab gosu for easy step-down from root
|
||||
ENV GOSU_VERSION 1.7
|
||||
RUN set -x \
|
||||
&& wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \
|
||||
&& wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \
|
||||
&& export GNUPGHOME="$(mktemp -d)" \
|
||||
&& gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \
|
||||
&& gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \
|
||||
&& rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \
|
||||
&& chmod +x /usr/local/bin/gosu \
|
||||
&& gosu nobody true
|
||||
|
||||
ENV REDIS_VERSION 3.2.9
|
||||
ENV REDIS_DOWNLOAD_URL http://download.redis.io/releases/redis-3.2.9.tar.gz
|
||||
ENV REDIS_DOWNLOAD_SHA 6eaacfa983b287e440d0839ead20c2231749d5d6b78bbe0e0ffa3a890c59ff26
|
||||
|
||||
# for redis-sentinel see: http://redis.io/topics/sentinel
|
||||
RUN set -ex \
|
||||
\
|
||||
&& buildDeps=' \
|
||||
gcc \
|
||||
libc6-dev \
|
||||
make \
|
||||
' \
|
||||
&& apt-get update \
|
||||
&& apt-get install -y $buildDeps --no-install-recommends \
|
||||
&& rm -rf /var/lib/apt/lists/* \
|
||||
\
|
||||
&& wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL" \
|
||||
&& echo "$REDIS_DOWNLOAD_SHA *redis.tar.gz" | sha256sum -c - \
|
||||
&& mkdir -p /usr/src/redis \
|
||||
&& tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1 \
|
||||
&& rm redis.tar.gz \
|
||||
\
|
||||
# Disable Redis protected mode [1] as it is unnecessary in context
|
||||
# of Docker. Ports are not automatically exposed when running inside
|
||||
# Docker, but rather explicitely by specifying -p / -P.
|
||||
# [1] https://github.com/antirez/redis/commit/edd4d555df57dc84265fdfb4ef59a4678832f6da
|
||||
&& grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 1$' /usr/src/redis/src/server.h \
|
||||
&& sed -ri 's!^(#define CONFIG_DEFAULT_PROTECTED_MODE) 1$!\1 0!' /usr/src/redis/src/server.h \
|
||||
&& grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 0$' /usr/src/redis/src/server.h \
|
||||
# for future reference, we modify this directly in the source instead of just supplying a default configuration flag because apparently "if you specify any argument to redis-server, [it assumes] you are going to specify everything"
|
||||
# see also https://github.com/docker-library/redis/issues/4#issuecomment-50780840
|
||||
# (more exactly, this makes sure the default behavior of "save on SIGTERM" stays functional by default)
|
||||
\
|
||||
&& make -C /usr/src/redis \
|
||||
&& make -C /usr/src/redis install \
|
||||
\
|
||||
&& rm -r /usr/src/redis \
|
||||
\
|
||||
&& apt-get purge -y --auto-remove $buildDeps
|
||||
|
||||
RUN mkdir /data && chown redis:redis /data
|
||||
VOLUME /data
|
||||
WORKDIR /data
|
||||
|
||||
COPY docker-entrypoint.sh /usr/local/bin/
|
||||
ENTRYPOINT ["docker-entrypoint.sh"]
|
||||
|
||||
EXPOSE 6379
|
||||
CMD [ "redis-server" ]
|
55
redis/image-build/3.2/alpine/Dockerfile
Normal file
55
redis/image-build/3.2/alpine/Dockerfile
Normal file
@ -0,0 +1,55 @@
|
||||
FROM registry.cn-hangzhou.aliyuncs.com/kennylee/alpine:3.4
|
||||
|
||||
# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
|
||||
RUN addgroup -S redis && adduser -S -G redis redis
|
||||
|
||||
# grab su-exec for easy step-down from root
|
||||
RUN apk add --no-cache 'su-exec>=0.2'
|
||||
|
||||
ENV REDIS_VERSION 3.2.9
|
||||
ENV REDIS_DOWNLOAD_URL http://download.redis.io/releases/redis-3.2.9.tar.gz
|
||||
ENV REDIS_DOWNLOAD_SHA 6eaacfa983b287e440d0839ead20c2231749d5d6b78bbe0e0ffa3a890c59ff26
|
||||
|
||||
# for redis-sentinel see: http://redis.io/topics/sentinel
|
||||
RUN set -ex \
|
||||
\
|
||||
&& apk add --no-cache --virtual .build-deps \
|
||||
gcc \
|
||||
linux-headers \
|
||||
make \
|
||||
musl-dev \
|
||||
tar \
|
||||
\
|
||||
&& wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL" \
|
||||
&& echo "$REDIS_DOWNLOAD_SHA *redis.tar.gz" | sha256sum -c - \
|
||||
&& mkdir -p /usr/src/redis \
|
||||
&& tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1 \
|
||||
&& rm redis.tar.gz \
|
||||
\
|
||||
# Disable Redis protected mode [1] as it is unnecessary in context
|
||||
# of Docker. Ports are not automatically exposed when running inside
|
||||
# Docker, but rather explicitely by specifying -p / -P.
|
||||
# [1] https://github.com/antirez/redis/commit/edd4d555df57dc84265fdfb4ef59a4678832f6da
|
||||
&& grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 1$' /usr/src/redis/src/server.h \
|
||||
&& sed -ri 's!^(#define CONFIG_DEFAULT_PROTECTED_MODE) 1$!\1 0!' /usr/src/redis/src/server.h \
|
||||
&& grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 0$' /usr/src/redis/src/server.h \
|
||||
# for future reference, we modify this directly in the source instead of just supplying a default configuration flag because apparently "if you specify any argument to redis-server, [it assumes] you are going to specify everything"
|
||||
# see also https://github.com/docker-library/redis/issues/4#issuecomment-50780840
|
||||
# (more exactly, this makes sure the default behavior of "save on SIGTERM" stays functional by default)
|
||||
\
|
||||
&& make -C /usr/src/redis \
|
||||
&& make -C /usr/src/redis install \
|
||||
\
|
||||
&& rm -r /usr/src/redis \
|
||||
\
|
||||
&& apk del .build-deps
|
||||
|
||||
RUN mkdir /data && chown redis:redis /data
|
||||
VOLUME /data
|
||||
WORKDIR /data
|
||||
|
||||
COPY docker-entrypoint.sh /usr/local/bin/
|
||||
ENTRYPOINT ["docker-entrypoint.sh"]
|
||||
|
||||
EXPOSE 6379
|
||||
CMD [ "redis-server" ]
|
16
redis/image-build/3.2/alpine/docker-entrypoint.sh
Normal file
16
redis/image-build/3.2/alpine/docker-entrypoint.sh
Normal file
@ -0,0 +1,16 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
# first arg is `-f` or `--some-option`
|
||||
# or first arg is `something.conf`
|
||||
if [ "${1#-}" != "$1" ] || [ "${1%.conf}" != "$1" ]; then
|
||||
set -- redis-server "$@"
|
||||
fi
|
||||
|
||||
# allow the container to be started with `--user`
|
||||
if [ "$1" = 'redis-server' -a "$(id -u)" = '0' ]; then
|
||||
chown -R redis .
|
||||
exec su-exec redis "$0" "$@"
|
||||
fi
|
||||
|
||||
exec "$@"
|
16
redis/image-build/3.2/docker-entrypoint.sh
Normal file
16
redis/image-build/3.2/docker-entrypoint.sh
Normal file
@ -0,0 +1,16 @@
|
||||
#!/bin/sh
|
||||
set -e
|
||||
|
||||
# first arg is `-f` or `--some-option`
|
||||
# or first arg is `something.conf`
|
||||
if [ "${1#-}" != "$1" ] || [ "${1%.conf}" != "$1" ]; then
|
||||
set -- redis-server "$@"
|
||||
fi
|
||||
|
||||
# allow the container to be started with `--user`
|
||||
if [ "$1" = 'redis-server' -a "$(id -u)" = '0' ]; then
|
||||
chown -R redis .
|
||||
exec gosu redis "$0" "$@"
|
||||
fi
|
||||
|
||||
exec "$@"
|
Loading…
Reference in New Issue
Block a user