在学习docker的时候,项目当中需要使用Redis 于是自己安装所走过的坑 记录下来:
- 首先在docker官网查看Redis的版本:
docker官网地址: https://hub.docker.com/_/redis
找到自己需要的版本然后在Linux中输入命令如下: docker pull redis:版本号
会得到
- 在安装Redis容器 命令如下:
先创建目录
mkdir /home/redis/data
mkdir /home/redis/conf
touch /home/redis/conf/redis.conf
再执行
docker run -p 6379:6379 --name myRedis -v /home/redis/data:/data -v /home/redis/conf/redis.conf:/etc/redis/redis.conf -d redis redis-server /etc/redis/redis.conf
注意:
容器当中的部分命令解释
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
-a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
-d: 后台运行容器,并返回容器ID;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-P: 随机端口映射,容器内部端口随机映射到主机的高端口
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
--name="redis": 为容器指定一个名称;
--dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
--dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
-h "127.0.0.1": 指定容器的hostname;
-e username="ritchie": 设置环境变量;
--env-file=[]: 从指定文件读入环境变量;
--cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
-m :设置容器使用内存最大值;
--net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
--link=[]: 添加链接到另一个容器;
--expose=[]: 开放一个端口或一组端口;
--volume , -v: 绑定一个卷 (把外面的配置绑定在容器里面 跟Vue的双向绑定类似)
至于为什么是这个目录
:/data | :/etc/redis/redis.conf |
---|---|
其实在官网里面有说明
但是有一个疑问? 就是我进入docker容器里面的目录却是 :
进入容器命令: docker exec -it 容器命 /bin/bansh
由于我在设置容器的时候并没有设置密码 那这个时候就可以使用 外部/home/redis/conf目录下的redis.conf
# 开启远程权限
bind 0.0.0.0
# 开启aof持久化## 启动redis
appendonly yes
# 设置Redis的密码为:123456
requirepass "123456"
要注意需要重新启动docker容器不然不会生效
docker restart 容器命/容器id
这样就大功告成啦