Dockerfile
FROM benyoo/centos:7.2.1511.20160630 MAINTAINER from www.dwhd.org by lookback ([email protected]) ENV REDIS_VERSION=3.2.1 ENV REDIS_DOWNLOAD_URL=http://download.redis.io/releases/redis-${REDIS_VERSION}.tar.gz \ REDIS_DOWNLOAD_SHA1=26c0fc282369121b4e278523fce122910b65fbbf RUN \ REDIS_FILE=${REDIS_DOWNLOAD_URL##*/} && \ mkdir /tmp/redis && \ cd /tmp/redis && \ curl -Lk "$REDIS_DOWNLOAD_URL" -o ${REDIS_DOWNLOAD_URL##*/} && \ tar xf ${REDIS_DOWNLOAD_URL##*/} && \ cd ${REDIS_FILE%.tar*} && \ #yum install -y http://cbs.centos.org/kojifiles/packages/jemalloc/3.6.0/1.el7/x86_64/jemalloc-3.6.0-1.el7.x86_64.rpm \ #http://cbs.centos.org/kojifiles/packages/jemalloc/3.6.0/1.el7/x86_64/jemalloc-devel-3.6.0-1.el7.x86_64.rpm && \ yum install jemalloc-devel -y && \ make -j $(awk '/processor/{i++}END{print i}' /proc/cpuinfo) && \ mkdir -p /usr/local/redis/{bin,etc,var} && \ cp -af src/{redis-benchmark,redis-check-aof,redis-check-rdb,redis-cli,redis-sentinel,redis-server} /usr/local/redis/bin/ && \ cp -a redis.conf /usr/local/redis/etc/ && \ echo "export PATH=/usr/local/redis/bin:\$PATH" > /etc/profile.d/redis.sh && \ source /etc/profile.d/redis.sh && \ useradd -r -s /sbin/nologin -c "Redis Server" -d /data -m -k no redis && \ #chmod +x /usr/local/redis/bin/entrypoint.sh && \ yum clean all && \ rm -rf /tmp/redis COPY entrypoint.sh /usr/local/redis/bin/entrypoint.sh RUN chmod +x /usr/local/redis/bin/entrypoint.sh VOLUME ["/data"] WORKDIR /data EXPOSE 6379/tcp ENTRYPOINT ["/usr/local/redis/bin/entrypoint.sh"] CMD ["redis-server"]
entrypoint.sh 脚本
#!/bin/bash ######################################################################### # File Name: entrypoint.sh # Author: LookBack # Email: admin#dwhd.org # Version: # Created Time: 2016年06月30日 星期四 19时38分40秒 ######################################################################### if ! which redis-server >/dev/null 2>&1; then source /etc/profile.d/redis.sh;fi set -e sysctl -w net.core.somaxconn=1024 >/dev/null 2>&1 sysctl -w vm.overcommit_memory=1 >/dev/null 2>&1 echo never > /sys/kernel/mm/transparent_hugepage/enabled echo never > /sys/kernel/mm/transparent_hugepage/defrag # 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 if [ "$1" = 'redis-server' ]; then # 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 doProtectedMode=1 configFile= if [ -f "$2" ]; then configFile="$2" if grep -q '^protected-mode' "$configFile"; then # if a config file is supplied and explicitly specifies "protected-mode", let it win doProtectedMode= fi fi if [ "$doProtectedMode" ]; then shift # "redis-server" if [ "$configFile" ]; then shift fi set -- --protected-mode no "$@" if [ "$configFile" ]; then set -- "$configFile" "$@" fi set -- redis-server "$@" # redis-server [config file] --protected-mode no [other options] # if this is supplied again, the "latest" wins, so "--protected-mode no --protected-mode yes" will result in an enabled status fi fi exec "$@"
如果需要基于此dockerfile基础上自己build,那么需要pull benyoo/centos:7.2.1511.20160630这个系统镜像,因为为了安装编译环境和尽可能的简写image的大小,我直接自己封了CentOS7.2.1511的系统image
如果不pull benyoo/centos:7.2.1511.20160630这个系统镜像,那么需要自己在CentOS系统镜像上完善编译环境。
使用方法:
docker run --name redis -d --privileged -p 6379:6379 benyoo/redis:3.2.1
--privileged参数是必须要的,因为启动redis服务的时候需要修改系统内核参数,如果不加在修改内核参数的时候会提示这是只读文件的错误
持久化存储:
docker run --name redis-server --privileged -p 6379:6379 -d benyoo/redis:3.2.1 --appendonly yes
如果想存在宿主机的存储上可以使用-v来挂载目录
docker run --name redis-server --privileged -p 6379:6379 -v /data/redis:/data -d benyoo/redis:3.2.1 --appendonly yes
您可以选择一种方式赞助本站
支付宝扫一扫赞助
微信钱包扫描赞助
赏