欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

docker安裝redis掛載容器卷同時開啟持久化

 更新時間:2022年06月10日 08:36:39   作者:Forpastime  
本文主要介紹了docker安裝redis掛載容器卷同時開啟持久化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

說明:centOS操作系統(tǒng),操作系統(tǒng)已安裝過redis,端口6379已被占用。容器將會使用6380端口。本次操作為了實(shí)例化redis數(shù)據(jù),并掛載到宿主機(jī),防止容器被刪除導(dǎo)致的數(shù)據(jù)丟失!

一、安裝

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

[root@localhost]# docker search --limit 10 redis
[root@localhost]# docker pull redis

2.在宿主機(jī)本地創(chuàng)建redis存儲配置文件和數(shù)據(jù)的目錄,我這里創(chuàng)建/docker/redis下

[root@localhost redis]# pwd
/docker/redis

3.配置文件

復(fù)制原有redis.conf到/docker/redis/目錄下

修改配置(最重要主要4項(xiàng):修改后臺運(yùn)行默認(rèn)為no、端口、存放位置、開啟持久化):

requirepass 123
maxclients 10000

#如果要外網(wǎng)訪問,請注釋掉下面,或者修改為0.0.0.0,保險起見,也可以把protected-mode設(shè)置為no
bind 0.0.0.0

protected-mode no

#注意修改這里端口,根據(jù)你實(shí)際暴露端口情況配置
port 6380

tcp-backlog 511
timeout 0
tcp-keepalive 300

#注意這里要把后臺運(yùn)行設(shè)置為no,避免docker后臺運(yùn)行沖突
daemonize no

supervised no
pidfile /docker/redis/redis.pid
loglevel notice

databases 16

always-show-logo yes
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb

#注意修改這里的目錄為容器內(nèi)目錄,默認(rèn)reids進(jìn)來是在/data/目錄
dir /data/

replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
replica-priority 100
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no

#注意修改這里的配置,yes開啟持久化,no關(guān)閉持久化
appendonly yes

appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
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

效果如下:

[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
d536dd728243ccee23b78e0289e30f7ee25084d308766fb9aa317d691d0dea7d
[root@localhost]# docker ps
CONTAINER ID   IMAGE     COMMAND                  CREATED         STATUS         PORTS                                                 NAMES
d536dd728243   redis     "docker-entrypoint.s…"   3 seconds ago   Up 2 seconds   6379/tcp, 0.0.0.0:6380->6380/tcp, :::6380->6380/tcp   forredis2參數(shù)講解:

參數(shù)介紹:

  • docker run -p 6380:6380 --name forredis2  別名
  • --privileged=true  掛載容器卷目錄權(quán)限
  • -v /docker/redis/redis.conf[宿主機(jī)配置文件]:/etc/redis/redis.conf  [容器配置文件]
  • -v /docker/redis/data[宿主機(jī)數(shù)據(jù)存儲位置]:/data [容器數(shù)據(jù)存儲位置]
  • -d redis[:版本號]

二、進(jìn)入容器,指定配置文件啟動redis服務(wù)

1.啟動redis服務(wù)

[root@localhost data]# docker exec -it forredis2 /bin/bash
root@d536dd728243:/data# redis-server /etc/redis/redis.conf
24:C 02 Jun 2022 02:42:56.096 # oO0OoO0OoO0Oo Redis is starting oO0OoO0OoO0Oo
24:C 02 Jun 2022 02:42:56.096 # Redis version=6.2.6, bits=64, commit=00000000, modified=0, pid=24, just started
24:C 02 Jun 2022 02:42:56.096 # Configuration loaded
24:M 02 Jun 2022 02:42:56.097 * monotonic clock: POSIX clock_gettime
                _._
           _.-``__ ''-._
      _.-``    `.  `_.  ''-._           Redis 6.2.6 (00000000/0) 64 bit
  .-`` .-```.  ```\/    _.,_ ''-._
 (    '      ,       .-`  | `,    )     Running in standalone mode
 |`-._`-...-` __...-.``-._|'` _.-'|     Port: 6380
 |    `-._   `._    /     _.-'    |     PID: 24
  `-._    `-._  `-./  _.-'    _.-'
 |`-._`-._    `-.__.-'    _.-'_.-'|
 |    `-._`-._        _.-'_.-'    |           https://redis.io
  `-._    `-._`-.__.-'_.-'    _.-'
 |`-._`-._    `-.__.-'    _.-'_.-'|
 |    `-._`-._        _.-'_.-'    |
  `-._    `-._`-.__.-'_.-'    _.-'
      `-._    `-.__.-'    _.-'
          `-._        _.-'
              `-.__.-'

如果要后臺運(yùn)行,將啟動redis命令后加上&,即

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

“/etc/redis/redis.conf”為容器內(nèi)配置文件,已通過啟動容器時掛載到宿主機(jī)的/docker/redis/redis.conf

2.指定6380端口登陸客戶端

root@ce16f8c4fd8c:/data# redis-cli -p 6380
127.0.0.1:6380> auth 123
OK
127.0.0.1:6380> keys *
(empty array)
127.0.0.1:6380> set a 1
OK
127.0.0.1:6380> keys *
1) "a"

三、刪除容器后重新啟動容器

為了驗(yàn)證redis持久化,刪除容器后數(shù)據(jù)在宿主機(jī)不會丟失,我們嘗試刪除容器后重新啟動

1.刪除,然后查看宿主機(jī)目錄下是否有持久化文件,查看這一步可以放在上一步后

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

2.重啟容器

[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
d536dd728243ccee23b78e0289e30f7ee25084d308766fb9aa317d691d0dea7dc

重復(fù)第【二】步的操作,進(jìn)入redis,查看數(shù)據(jù)是否存在

[root@localhost ~]# docker exec -it forredis2 /bin/bash
root@d536dd728243:/data# redis-cli -p 6380
127.0.0.1:6380> auth 123
127.0.0.1:6380> keys *
1) "a"

數(shù)據(jù)存在,成功!

到此這篇關(guān)于docker安裝redis掛載容器卷同時開啟持久化的文章就介紹到這了,更多相關(guān)docker 安裝redis掛載容器卷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • docker基本使用方法入門示例

    docker基本使用方法入門示例

    這篇文章主要介紹了docker基本使用方法入門示例,包含docker命令查詢方法,查詢鏡像和下拉鏡像,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • docker的鏡像存放地址在哪里

    docker的鏡像存放地址在哪里

    Docker鏡像(Image)是用于創(chuàng)建?Docker?容器的模板,下面這篇文章主要給大家介紹了關(guān)于docker的鏡像存放地址在哪里的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • docker基礎(chǔ)知識之掛載本地目錄的方法

    docker基礎(chǔ)知識之掛載本地目錄的方法

    本篇文章主要介紹了docker基礎(chǔ)知識之掛載本地目錄的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Docker容器如何更新打包并上傳到阿里云

    Docker容器如何更新打包并上傳到阿里云

    這篇文章主要介紹了Docker容器如何更新打包并上傳到阿里云,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • docker部署elasticsearch和xpack密碼的詳細(xì)過程

    docker部署elasticsearch和xpack密碼的詳細(xì)過程

    本文主要介紹在docker環(huán)境下如何快速部署elasticsearch單機(jī)版本和集群版本,和增加xpack簡單用戶名密碼配置,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下
    2024-01-01
  • Docker報錯Operation?not?permitted問題的解決方法

    Docker報錯Operation?not?permitted問題的解決方法

    剛開始接觸Docker的朋友經(jīng)常會遇到問題,下面這篇文章主要給大家介紹了關(guān)于Docker報錯Operation?not?permitted問題的解決方法,需要的朋友可以參考下
    2023-02-02
  • docker pull鏡像速度慢的問題解決方法

    docker pull鏡像速度慢的問題解決方法

    這篇文章主要介紹了docker pull鏡像速度慢的問題解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • docker部署springboot項(xiàng)目啟動時間與宿主機(jī)相差8小時的解決

    docker部署springboot項(xiàng)目啟動時間與宿主機(jī)相差8小時的解決

    項(xiàng)目部署到docker環(huán)境,數(shù)據(jù)庫中的時間總是少8個小時,本文就來介紹一下解決方法,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • docker如何查看容器啟動命令(已運(yùn)行的容器)

    docker如何查看容器啟動命令(已運(yùn)行的容器)

    Docker是一個開源的應(yīng)用容器引擎,讓開發(fā)者可以打包他們的應(yīng)用以及依賴包到一個可移植的容器中,然后發(fā)布到任何流行的Linux機(jī)器上,下面這篇文章主要給大家介紹了關(guān)于docker如何查看容器啟動命令(已運(yùn)行的容器)的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • Docker容器連接外部Mysql的幾種方案

    Docker容器連接外部Mysql的幾種方案

    這篇文章主要給大家介紹了關(guān)于Docker容器連接外部Mysql的幾種方案,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-06-06

最新評論