1、拉取鏡像
docker pull redis:7.2.12
2、準備配置文件路徑
mkdir -p /home/docker/redis/conf
mkdir -p /home/docker/redis/data
mkdir -p /home/docker/redis/logs
3、編寫配置文件
vi /home/docker/redis/conf/redis.conf
配置
# Redis 服務器的端口號(默認:6379)
port 6379
# 綁定的 IP 地址,如果設置為 127.0.0.1,則只能本地訪問;若設置為 0.0.0.0,則監聽所有接口(默認:127.0.0.1)
bind 0.0.0.0
# 設置密碼,客户端連接時需要提供密碼才能進行操作,如果不設置密碼,可以註釋掉此行(默認:無)
# requirepass foobared
requirepass 123456
# 設置在客户端閒置一段時間後關閉連接,單位為秒(默認:0,表示禁用)
# timeout 0
# 是否以守護進程(daemon)模式運行,默認為 "no",設置為 "yes" 後 Redis 會在後台運行
daemonize no
# 設置日誌級別(默認:notice)。可以是 debug、verbose、notice、warning
loglevel notice
# 設置日誌文件的路徑(默認:空字符串),如果不設置,日誌會輸出到標準輸出
logfile ""
# 設置數據庫數量(默認:16),Redis 使用數據庫索引從 0 到 15
databases 16
# 是否啓用 AOF 持久化,默認為 "no"。如果設置為 "yes",將在每個寫操作執行時將其追加到文件中
appendonly no
# 設置 AOF 持久化的文件路徑(默認:appendonly.aof)
# appendfilename "appendonly.aof"
# AOF 持久化模式,默認為 "always"。可以是 always、everysec 或 no
# always:每個寫操作都立即同步到磁盤
# everysec:每秒鐘同步一次到磁盤
# no:完全依賴操作系統的行為,可能會丟失數據,但性能最高
# appendfsync always
# 設置是否在後台進行 AOF 文件重寫,默認為 "no"
# auto-aof-rewrite-on-rewrite no
# 設置 AOF 文件重寫觸發時,原 AOF 文件大小與新 AOF 文件大小之間的比率(默認:100)
# auto-aof-rewrite-percentage 100
# 設置是否開啓 RDB 持久化,默認為 "yes"。如果設置為 "no",禁用 RDB 持久化功能
save 900 1
save 300 10
save 60 10000
# 設置 RDB 持久化文件的名稱(默認:dump.rdb)
# dbfilename dump.rdb
# 設置 RDB 持久化文件的保存路徑,默認保存在當前目錄
# dir ./
# 設置是否開啓對主從同步的支持,默認為 "no"
# slaveof <masterip> <masterport>
# 設置主從同步時是否進行數據完整性校驗,默認為 "yes"
# repl-diskless-sync no
# 設置在複製時是否進行異步複製,默認為 "yes",可以加快複製速度,但會增加數據丟失的風險
# repl-backlog-size 1mb
# 設置是否開啓集羣模式(cluster mode),默認為 "no"
# cluster-enabled no
# 設置集羣中的節點超時時間(默認:15000毫秒)
# cluster-node-timeout 15000
# 設置集羣中節點間通信使用的端口號(默認:0)
# cluster-announce-port 0
# 設置集羣中節點間通信使用的 IP 地址
# cluster-announce-ip 127.0.0.1
# 設置是否開啓慢查詢日誌,默認為 "no"
# slowlog-log-slower-than 10000
# 設置慢查詢日誌的最大長度,默認為 128
# slowlog-max-len 128
# 設置每秒最大處理的寫入命令數量,用於保護 Redis 服務器不被超負荷寫入(默認:0,表示不限制)
# maxclients 10000
# 設置最大連接客户端數量(默認:10000,0 表示不限制)
# maxmemory <bytes>
# 設置最大使用內存的策略(默認:noeviction)。可以是 volatile-lru、allkeys-lru、volatile-random、allkeys-random、volatile-ttl 或 noeviction
# maxmemory-policy noeviction
# 設置允許最大使用內存的比例(默認:0),設置為 0 表示禁用
# maxmemory-samples 5
4、配置docker-compose.yml文件
version: '3'
services:
redis:
image: redis:7.2.12
container_name: redis
restart: always
ports:
- '16379:6379'
volumes:
- ./data:/data
- ./conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./logs:/logs
#配置文件啓動
command: redis-server /usr/local/etc/redis/redis.conf
5、啓動
docker-compose -f docker-compose.yml up -d
測試
docker exec -it redis bash
redis-cli
auth 123456
set key testhaha
get key
本文章為轉載內容,我們尊重原作者對文章享有的著作權。如有內容錯誤或侵權問題,歡迎原作者聯繫我們進行內容更正或刪除文章。