도커 설치 Redis
방법 1. Dockerfile을 통해 빌드
Dockerfile 만들기
먼저 나중에 관련 내용을 저장할 redis 디렉터리를 만듭니다.
php@php:~$ mkdir -p ~/redis ~/redis/data
데이터 디렉터리는 redis 데이터 지속성을 위한 저장소 디렉터리로 redis 컨테이너에서 구성한 /data 디렉터리에 매핑됩니다.
생성된 redis 디렉터리에 들어가서 Dockerfile을 생성합니다.
FROM 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.0 ENV REDIS_DOWNLOAD_URL http://download.redis.io/releases/redis-3.2.0.tar.gz ENV REDIS_DOWNLOAD_SHA1 0c1820931094369c8cc19fc1be62f598bc5961ca # for redis-sentinel see: http://redis.io/topics/sentinel RUN buildDeps='gcc libc6-dev make' \ && set -x \ && 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_SHA1 *redis.tar.gz" | sha1sum -c - \ && mkdir -p /usr/src/redis \ && tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1 \ && rm redis.tar.gz \ && 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" ]
Dockerfile을 통해 미러를 생성하고 교체합니다. 자신의 이름으로
php@php:~/redis$ docker build -t redis:3.2 .
생성이 완료되면 로컬 이미지 목록에서 새로 생성된 이미지를 찾을 수 있습니다
php@php:~/redis$ docker images redis REPOSITORY TAG IMAGE ID CREATED SIZE redis 3.2 43c923d57784 2 weeks ago 193.9 MB
방법 2, docker pull redis:3.2
Docker Hub에서 redis 이미지를 찾으세요
php@php:~/redis$ docker search redis NAME DESCRIPTION STARS OFFICIAL AUTOMATED redis Redis is an open source ... 2321 [OK] sameersbn/redis 32 [OK] torusware/speedus-redis Always updated official ... 29 [OK] bitnami/redis Bitnami Redis Docker Image 22 [OK] anapsix/redis 11MB Redis server image ... 6 [OK] webhippie/redis Docker images for redis 4 [OK] clue/redis-benchmark A minimal docker image t... 3 [OK] williamyeh/redis Redis image for Docker 3 [OK] unblibraries/redis Leverages phusion/baseim... 2 [OK] greytip/redis redis 3.0.3 1 [OK] servivum/redis Redis Docker Image 1 [OK] ...
여기서 공식 이미지를 가져오면 라벨은 3.2
php@php:~/redis$ docker pull redis:3.2
입니다. 다운로드가 완료될 때까지 기다린 후 로컬 이미지 목록에서 redis의 REPOSITORY와 라벨이 3.2인 이미지를 찾을 수 있습니다.
redis 이미지를 사용하여
컨테이너를 실행
php@php:~/redis$ docker run -p 6379:6379 -v $PWD/data:/data -d redis:3.2 redis-server --appendonly yes 43f7a65ec7f8bd64eb1c5d82bc4fb60e5eb31915979c4e7821759aac3b62f330 php@php:~/redis$
명령 지침:
-p 6379:6379:컨테이너의 6379 포트를 호스트의 6379 포트에 매핑
-v $PWD /data:/data: 호스트의 현재 디렉터리에 있는 데이터를 컨테이너의 /data
redis-server --appendonly yes :컨테이너에서 redis-server 시작 명령을 실행하고 redis 지속성 구성을 엽니다.
컨테이너 시작 상태 보기
php@php:~/redis$ docker ps CONTAINER ID IMAGE COMMAND ... PORTS NAMES 43f7a65ec7f8 redis:3.2 "docker-entrypoint.sh" ... 0.0.0.0:6379->6379/tcp agitated_cray
컨테이너 연결 및 보기
redis 이미지를 사용하여 redis-cli 명령을 실행하여 새로 시작된 컨테이너에 연결합니다. 호스트 IP는 172.17.0.1
php@php:~/redis$ docker run -it redis:3.2 redis-cli -h 172.17.0.1 172.17.0.1:6379> info # Server redis_version:3.2.0 redis_git_sha1:00000000 redis_git_dirty:0 redis_build_id:f449541256e7d446 redis_mode:standalone os:Linux 4.2.0-16-generic x86_64 arch_bits:64 multiplexing_api:epoll ...