Redis快速部署為Docker容器的實(shí)現(xiàn)方法
Redis是一種內(nèi)存鍵值存儲(chǔ),可以保存高性能的抽象數(shù)據(jù)結(jié)構(gòu)。開源軟件通常用于數(shù)據(jù)庫、消息傳遞和緩存功能。
Docker 是將應(yīng)用程序打包到容器中的領(lǐng)先工具包。它允許您將軟件組件隔離到具有自己的文件系統(tǒng)的獨(dú)立環(huán)境中。
在本指南中,我們將使用 Docker 使用Docker Hub 上的官方鏡像快速部署 Redis 。與裸機(jī)安裝相比,Docker 實(shí)現(xiàn)了更簡單的設(shè)置過程,并且不會(huì)用新包污染您的主機(jī)。在繼續(xù)之前,請確保您的主機(jī)上安裝了正常運(yùn)行的 Docker。
入門
Redis 鏡像包括服務(wù)器組件和官方 CLI。它已預(yù)先配置為在您啟動(dòng)新容器時(shí)使用運(yùn)行的默認(rèn)配置值啟動(dòng)服務(wù)器。
映像的變體可用于覆蓋不同的 Redis 版本(5.0 和 6.0)和操作系統(tǒng)(Alpine 和 Debian)。瀏覽標(biāo)簽列表以找到適合您環(huán)境的最佳選項(xiàng)。
最簡單的部署如下:
docker run --name redis -d -p 6379:6379 redis:6.0
這將啟動(dòng)一個(gè)名為redisrunning Redis 6.0的新容器。該-d標(biāo)志用于從容器中分離。服務(wù)器將一直在后臺(tái)運(yùn)行,直到您使用docker stop redis.
Redis 默認(rèn)監(jiān)聽 6379 端口。該-p標(biāo)志將此端口綁定到您的主機(jī)。您的應(yīng)用程序?qū)⒛軌蛟L問 Redis localhost:6379。請注意,這是不安全的——如果您的機(jī)器暴露在互聯(lián)網(wǎng)上,任何人都可以訪問您的 Redis 數(shù)據(jù)!
數(shù)據(jù)存儲(chǔ)
Redis 支持多種持久性機(jī)制,可以將您的內(nèi)存數(shù)據(jù)庫保存到磁盤。數(shù)據(jù)將保存到/data容器中的目錄中。由于 Docker 容器是臨時(shí)的,您需要將卷掛載到此目錄。否則,當(dāng)您的容器停止時(shí),您的數(shù)據(jù)將丟失。
docker run --name redis -d \ -v redis-data:/data redis:6.0 --save 60 1
該–save標(biāo)志被傳遞到 Redis 服務(wù)器。它配置要使用的持久性策略。此示例每秒鐘寫入一次數(shù)據(jù)庫快照60。除非1自上次快照后發(fā)生數(shù)據(jù)庫寫入,否則將跳過該操作。
一個(gè)被調(diào)用的 Docker 卷redis-data由該-v標(biāo)志創(chuàng)建。這會(huì)將您的數(shù)據(jù)存儲(chǔ)在容器外,以便在重新啟動(dòng)后仍可訪問。該卷將一直存在,直到通過運(yùn)行將其刪除docker volumes rm redis-data。
配置您的服務(wù)器
添加配置參數(shù)的最快方法是將 CLI 參數(shù)作為docker run命令的一部分傳遞給 Redis 服務(wù)器。–save上面的例子說明了這一點(diǎn)。圖像名稱 in 之后的任何內(nèi)容docker run都將傳遞給在容器內(nèi)執(zhí)行的命令。對于 Redis 映像,該命令是 Redis 服務(wù)器。
使用 CLI 標(biāo)志很快就會(huì)變得重復(fù)。您可以通過將路徑作為服務(wù)器的第一個(gè)參數(shù)傳遞來使 Redis使用配置文件。該文件通常位于/usr/local/etc/redis/redis.conf. 使用 Docker 綁定安裝redis.conf從安裝到容器的本地文件系統(tǒng)獲?。?/p>
docker run --name redis -d \ -v redis-data:/data -v ./redis-conf:/usr/local/etc/redis redis:6.0 /usr/local/etc/redis.conf
在您的工作目錄中放置一個(gè)redis.confinside redis-conf。Docker 會(huì)將此路徑掛載到容器中,讓 Redis 可以訪問docker run命令中指定的文件。
管理Redis安全
默認(rèn)情況下,Redis Docker 映像配置為在不受保護(hù)的模式下運(yùn)行 Redis。這使得使用 Docker 網(wǎng)絡(luò)從其他 Docker 容器訪問 Redis 服務(wù)器變得更加容易。但是,這也意味著可以到達(dá)您的容器的任何東西都可以完全訪問您的數(shù)據(jù)。
保護(hù)模式是Redis 的一項(xiàng)功能,它僅響應(yīng)從主機(jī)的環(huán)回地址發(fā)出的未經(jīng)身份驗(yàn)證的查詢,例如localhost. 您可以通過添加protected-mode yes到您的redis.conf. 當(dāng)與 Dockerized 安裝一起使用時(shí),這將導(dǎo)致 Redis 只能在其自己的容器內(nèi)訪問,這通常并不理想。
您可以通過添加requirepass example到您的redis.conf. Redis 將只接受來自提供配置密碼的客戶端的查詢。Redis 6 還支持功能更齊全的訪問控制,讓您可以設(shè)置具有不同權(quán)限的多個(gè)用戶帳戶。
要使用身份驗(yàn)證,請按照上一節(jié)中的指導(dǎo)創(chuàng)建 Redis 配置文件并將其掛載到您的容器中。如果您不想設(shè)置密碼,只需將其加入應(yīng)用程序所需的 Docker 網(wǎng)絡(luò),即可確保您的安裝安全。不要在沒有先設(shè)置身份驗(yàn)證的情況下將端口 6379 綁定到您的主機(jī)。
使用您的 Redis 安裝
現(xiàn)在 Redis 已完全設(shè)置,您可以繼續(xù)從客戶端訪問它。如果您從主機(jī)連接,則可以使用 Docker 容器的 IP(通過運(yùn)行可見docker inspect redis,根據(jù)容器名稱進(jìn)行調(diào)整)和端口6379。
要從另一個(gè) Docker 容器訪問 Redis,最好將兩個(gè)容器都加入一個(gè) Docker 網(wǎng)絡(luò):
docker network create redis docker run --name redis --network redis -d redis:6.0 docker run --name api --network redis -d my-api:latest
現(xiàn)在,您的應(yīng)用程序容器將能夠通過redis主機(jī)名上的端口 6379 訪問 Redis 。當(dāng)它們共享一個(gè) Docker 網(wǎng)絡(luò)時(shí),Docker 使容器名稱可以作為主機(jī)名訪問。
您可以使用redis-cli容器映像中包含的二進(jìn)制文件手動(dòng)與數(shù)據(jù)庫交互。以分離模式 ( -d)啟動(dòng)您的容器,使其在后臺(tái)運(yùn)行。然后使用docker exec運(yùn)行redis-cli命令:
docker exec -it redis-container redis-cli
這將使您進(jìn)入容器內(nèi)的 Redis CLI 會(huì)話。
概括
Docker 可以讓您快速輕松地啟動(dòng)新的 Redis 實(shí)例,而無需將軟件安裝到您的機(jī)器上。使用官方 Docker 鏡像啟動(dòng)你的容器,然后添加命令標(biāo)志或掛載一個(gè)配置文件以滿足你的需要。
需要始終牢記的兩件事是存儲(chǔ)和安全性:如果您需要使用 Redis 持久性功能,則應(yīng)該使用 Docker 卷以避免丟失數(shù)據(jù)。請記住,Dockerized Redis 默認(rèn)為無保護(hù)模式且無需身份驗(yàn)證,因此在最壞的情況下,暴露 6379 端口可能會(huì)產(chǎn)生災(zāi)難性的后果。
到此這篇關(guān)于Redis快速部署為Docker容器的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)Redis部署為Docker容器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- docker部署redis報(bào)錯(cuò)內(nèi)存分配過度解決辦法
- Docker中部署Redis并掛載配置文件
- 使用Docker安裝部署MySQL和Redis的詳細(xì)過程
- Docker安裝部署Redis數(shù)據(jù)庫的實(shí)現(xiàn)步驟
- Docker中redis集群部署實(shí)戰(zhàn)
- 聊聊docker?單機(jī)部署redis集群的問題
- 關(guān)于docker容器部署redis步驟介紹
- 在docker中部署并啟動(dòng)redis的方法
- Docker 部署Mysql 服務(wù)和Redis 服務(wù)的方法
- Docker 部署單機(jī)版 Pulsar 和集群架構(gòu) Redis(開發(fā)神器)的方法
- redis快速部署為docker容器的方法實(shí)現(xiàn)
相關(guān)文章
修改docker容器端口映射到主機(jī)的方法實(shí)現(xiàn)
Docker容器的端口映射是通過docker run命令來啟動(dòng)容器,并指定端口映射參數(shù),本文主要介紹了修改docker容器端口映射到主機(jī)的方法實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09用Docker swarm快速部署Nebula Graph集群的教程
這篇文章主要介紹了用Docker swarm快速部署Nebula Graph集群的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09Docker實(shí)現(xiàn)分布式應(yīng)用功能教程
這篇文章主要介紹了Docker實(shí)現(xiàn)分布式應(yīng)用功能,涉及docker分布式應(yīng)用、負(fù)載均衡相關(guān)實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2018-06-06ubuntu docker搭建Hadoop集群環(huán)境的方法
這篇文章主要介紹了ubuntu docker搭建Hadoop集群環(huán)境,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-06docker-compose限制容器cpu和內(nèi)存方式
這篇文章主要介紹了docker-compose限制容器cpu和內(nèi)存方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01DOCKERFILE學(xué)習(xí)及使用注意事項(xiàng)
Dockerfile 由一行行命令語句組成,并且支持以 # 開頭的注釋行。一般的,Dockerfile分為四部分:基礎(chǔ)鏡像信息、維護(hù)者信息、鏡像操作指令、容器啟動(dòng)時(shí)執(zhí)行指令2017-02-02