1. 首页
  2. 技术知识

docker安装redis挂载容器卷同时开启持久化

目录

    一、安装

      1.搜索redis容器镜像并拉取容器镜像2.在宿主机本地创建redis存储配置文件和数据的目录,我这里创建/docker/redis下3.配置文件4.启动容器

    二、进入容器,指定配置文件启动redis服务

      1.启动redis服务2.指定6380端口登陆客户端

    三、删除容器后重新启动容器

      1.删除,然后查看宿主机目录下是否有持久化文件,查看这一步可以放在上一步后2.重启容器

说明:centOS操作系统,操作系统已安装过redis,端口6379已被占用。容器将会使用6380端口。本次操作为了实例化redis数据,并挂载到宿主机,防止容器被删除导致的数据丢失!

一、安装


1.搜索redis容器镜像并拉取容器镜像

  1. [root@localhost]# docker search –limit 10 redis
  2. [root@localhost]# docker pull redis

复制代码
2.在宿主机本地创建redis存储配置文件和数据的目录,我这里创建/docker/redis下

  1. [root@localhost redis]# pwd
  2. /docker/redis

复制代码
3.配置文件

复制原有redis.conf到/docker/redis/目录下

修改配置(最重要主要4项:修改后台运行默认为no、端口、存放位置、开启持久化):

  1. requirepass 123
  2. maxclients 10000
  3. #如果要外网访问,请注释掉下面,或者修改为0.0.0.0,保险起见,也可以把protected-mode设置为no
  4. bind 0.0.0.0
  5. protected-mode no
  6. #注意修改这里端口,根据你实际暴露端口情况配置
  7. port 6380
  8. tcp-backlog 511
  9. timeout 0
  10. tcp-keepalive 300
  11. #注意这里要把后台运行设置为no,避免docker后台运行冲突
  12. daemonize no
  13. supervised no
  14. pidfile /docker/redis/redis.pid
  15. loglevel notice
  16. databases 16
  17. always-show-logo yes
  18. save 900 1
  19. save 300 10
  20. save 60 10000
  21. stop-writes-on-bgsave-error yes
  22. rdbcompression yes
  23. rdbchecksum yes
  24. dbfilename dump.rdb
  25. #注意修改这里的目录为容器内目录,默认reids进来是在/data/目录
  26. dir /data/
  27. replica-serve-stale-data yes
  28. replica-read-only yes
  29. repl-diskless-sync no
  30. repl-diskless-sync-delay 5
  31. repl-disable-tcp-nodelay no
  32. replica-priority 100
  33. lazyfree-lazy-eviction no
  34. lazyfree-lazy-expire no
  35. lazyfree-lazy-server-del no
  36. replica-lazy-flush no
  37. #注意修改这里的配置,yes开启持久化,no关闭持久化
  38. APPendonly yes
  39. appendfilename “appendonly.aof”
  40. appendfsync everysec
  41. no-appendfsync-on-rewrite no
  42. auto-aof-rewrite-percentage 100
  43. auto-aof-rewrite-min-size 64mb
  44. aof-load-truncated yes
  45. aof-use-rdb-preamble yes
  46. lua-time-limit 5000
  47. slowlog-log-slower-than 10000
  48. slowlog-max-len 128
  49. latency-monitor-threshold 0
  50. notify-keyspace-events “”
  51. hash-max-ziplist-entries 512
  52. hash-max-ziplist-value 64
  53. list-max-ziplist-size -2
  54. list-compress-depth 0
  55. set-max-intset-entries 512
  56. zset-max-ziplist-entries 128
  57. zset-max-ziplist-value 64
  58. hll-sparse-max-bytes 3000
  59. stream-node-max-bytes 4096
  60. stream-node-max-entries 100
  61. activerehashing yes
  62. client-output-buffer-limit normal 0 0 0
  63. client-output-buffer-limit replica 256mb 64mb 60
  64. client-output-buffer-limit pubsub 32mb 8mb 60
  65. hz 10
  66. dynamic-hz yes
  67. aof-rewrite-incremental-fsync yes
  68. rdb-save-incremental-fsync yes

复制代码
4.启动容器

启动命令:docker run -p 6380:6380 –name forredis2 –privileged=true -v /docker/redis/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data -d redis

效果如下:

  1. [root@localhost]# docker run -p 6380:6380 –name forredis2 –privileged=true -v /docker/redis/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data -d redis
  2. d536dd728243ccee23b78e0289e30f7ee25084d308766fb9aa317d691d0dea7d
  3. [root@localhost]# docker ps
  4. CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                                                 NAMES
  5. d536dd728243   redis     “docker-entrypoint.s…”   3 seconds ago   Up 2 seconds   6379/tcp, 0.0.0.0:6380->6380/tcp, :::6380->6380/tcp   forredis2参数讲解:

复制代码 参数介绍:

    docker run -p 6380:6380 –name forredis2  别名–privileged=true  挂载容器卷目录权限-v /docker/redis/redis.conf[宿主机配置文件]:/etc/redis/redis.conf  [容器配置文件]-v /docker/redis/data[宿主机数据存储位置]:/data [容器数据存储位置]-d redis[:版本号]


二、进入容器,指定配置文件启动redis服务


1.启动redis服务

  1. [root@localhost data]# docker exec -it forredis2 /bin/bash
  2. root@d536dd728243:/data# redis-server /etc/redis/redis.conf
  3. 24:C 02 Jun 2022 02:42:56.096 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
  4. 24:C 02 Jun 2022 02:42:56.096 # Redis version=6.2.6, bits=64, commit=00000000, modified=0, pid=24, just started
  5. 24:C 02 Jun 2022 02:42:56.096 # Configuration loaded
  6. 24:M 02 Jun 2022 02:42:56.097 * monotonic clock: POSIX clock_gettime
  7.                 _._
  8.            _.-“__ ”-._
  9.       _.-“    `.  `_.  ”-._           Redis 6.2.6 (00000000/0) 64 bit
  10.   .-“ .-“`.  “`\/    _.,_ ”-._
  11. (    ‘      ,       .-`  | `,    )     Running in standalone mode
  12. |`-._`-…-` __…-.“-._|’` _.-‘|     Port: 6380
  13. |    `-._   `._    /     _.-‘    |     PID: 24
  14.   `-._    `-._  `-./  _.-‘    _.-‘
  15. |`-._`-._    `-.__.-‘    _.-‘_.-‘|
  16. |    `-._`-._        _.-‘_.-‘    |           https://redis.io
  17.   `-._    `-._`-.__.-‘_.-‘    _.-‘
  18. |`-._`-._    `-.__.-‘    _.-‘_.-‘|
  19. |    `-._`-._        _.-‘_.-‘    |
  20.   `-._    `-._`-.__.-‘_.-‘    _.-‘
  21.       `-._    `-.__.-‘    _.-‘
  22.           `-._        _.-‘
  23.               `-.__.-‘

复制代码 如果要后台运行,将启动redis命令后加上&,即

redis-server /etc/redis/redis.conf &

“/etc/redis/redis.conf”为容器内配置文件,已通过启动容器时挂载到宿主机的/docker/redis/redis.conf

2.指定6380端口登陆客户端

  1. root@ce16f8c4fd8c:/data# redis-cli -p 6380
  2. 127.0.0.1:6380> auth 123
  3. OK
  4. 127.0.0.1:6380> keys *
  5. (empty array)
  6. 127.0.0.1:6380> set a 1
  7. OK
  8. 127.0.0.1:6380> keys *
  9. 1) “a”

复制代码
三、删除容器后重新启动容器

为了验证redis持久化,删除容器后数据在宿主机不会丢失,我们尝试删除容器后重新启动

1.删除,然后查看宿主机目录下是否有持久化文件,查看这一步可以放在上一步后

  1. [root@localhost ~]# docker rm -f forredis2
  2. forredis2
  3. [root@localhost ~]# docker ps -a
  4. CONTAINER ID   IMAGE           COMMAND                  CREATED        STATUS                      PORTS     NAMES
  5. e28f2bd4b59e   redis           “docker-entrypoint.s…”   10 hours ago   Exited (130) 10 hours ago             exciting_yalow
  6. 4e291d491cda   redis           “docker-entrypoint.s…”   10 hours ago   Exited (0) 10 hours ago               dreamy_rhodes
  7. be3f2f06ed9f   redis           “docker-entrypoint.s…”   12 hours ago   Exited (0) 12 hours ago               awesome_jones
  8. 9a206e517842   redis           “docker-entrypoint.s…”   12 hours ago   Exited (0) 12 hours ago               hopeful_volhard
  9. 69c9f429c98a   7614ae9453d1    “docker-entrypoint.s…”   16 hours ago   Exited (1) 16 hours ago               youthful_goodall
  10. 25f26d7892d5   redis           “docker-entrypoint.s…”   18 hours ago   Exited (0) 16 hours ago               amazing_lovelace
  11. [root@localhost ~]# docker ps
  12. CONTAINER ID   IMAGE     COMMAND   CREATED   STATUS    PORTS     NAMES
  13. [root@localhost ~]# cd /docker/redis/data/
  14. [root@localhost data]# ls
  15. appendonly.aof  dump.rdb

复制代码
2.重启容器

  1. [root@localhost data]# docker run -p 6380:6380 –name forredis2 –privileged=true -v /docker/redis/redis.conf:/etc/redis/redis.conf -v /docker/redis/data:/data -d redis
  2. d536dd728243ccee23b78e0289e30f7ee25084d308766fb9aa317d691d0dea7dc

复制代码 重复第【二】步的操作,进入redis,查看数据是否存在

  1. [root@localhost ~]# docker exec -it forredis2 /bin/bash
  2. root@d536dd728243:/data# redis-cli -p 6380
  3. 127.0.0.1:6380> auth 123
  4. 127.0.0.1:6380> keys *
  5. 1) “a”

复制代码 数据存在,成功!

到此这篇关于docker安装redis挂载容器卷同时开启持久化的文章就介绍到这了,更多相关docker 安装redis挂载容器卷内容请搜索软件技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件技术网!

原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/108934.html

联系我们