應用環境
Ubuntu 20.04.6 LTS (GNU/Linux 5.15.0-139-generic x86_64)
Docker version 28.1.1, build 4eba377
文章目錄
- 一、部署Mongo
- 1. 拉取容器鏡像
- 2. 生成Run腳本
- 2.1 準備條件
- 2.2 參數解讀
- 2.3 實例腳本
- 3. 實例操作
- 3.1 Mongo bash控制臺
- 3.2 庫表操作
- 4. MongoDB Compass (GUI)
- 登錄連接配置
- 二、安裝Redis:7.4.1
- 1. 拉取容器鏡像
- 2. 生成Run腳本
- 2.1 實例腳本
- 2.2 運維管理
- 參考資料
一、部署Mongo
MongoDB是一個流行的開源文檔型數據庫,它使用類似 JSON 的文檔模型存儲數據,這使得數據存儲變得非常靈活。它基于文檔的 NoSQL 數據庫,由 MongoDB Inc. 公司用C++語言編寫,旨在為 WEB 應用提供可擴展的高性能數據存儲解決方案。
1. 拉取容器鏡像
# mongo:8.0
sudo docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/mongo:8.0# 添加標簽名Tag
sudo docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/mongo:8.0 docker.io/mongo:8.0# 移除標簽名Tag
docker rmi swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/mongo:8.0
國內鏡像參考:
渡渡鳥鏡像
2. 生成Run腳本
可參考:渡渡鳥-Run助手
2.1 準備條件
創建實例存儲路徑目錄
# 創建mongo實例目錄及config配置子目錄
sudo mkdir -p /mongo/config
創建實例配置文件sudo vim mongod.conf
,內容如下
# Dbase path
dbpath=/mongo/data# logs file path
logpath=/mongo/logs/mongod.log# lisen port
port=27017# All IP addresses are allowed to connect.
bind_ip=0.0.0.0# Enable log recording
journal=true# Whether to run in the background
fork=true# Enable authentication
auth=true
由于docker run
卷映射**-v**參數是會自動創建不存在的宿主機路徑目錄的,只需要把配置文件所在路徑及配置信息保存一下就可以了。
2.2 參數解讀
# 將鏡像進實例化成容器并運行
docker run# 【i】保持STDIN(標準輸入)開放,即使沒有附加任何東西。這通常用于讓容器的進程保持運行,即使沒有附加到終端。例如,你可以在容器內部運行一個交互式shell
# 【t】分配一個偽終端(pseudo-TTY),這對于交互式shell非常重要,比如當你想要在容器中運行bash或sh時。
# 【d】后臺運行,即所謂的“detached”模式。容器會在后臺啟動,并且你會得到容器的ID或名稱
-itd# 容器命名
--name mongo# 重啟策略
## no:不自動重啟,缺省時默認
## always:始終重啟
## unless-stopped:Docker 服務重啟后自動啟動容器,除非容器被手動停止。可指定最大重試次數,例如 --restart=on-failure:3(最多重啟3次)。
## on-failure:僅在容器非正常退出(退出狀態碼非0)時重啟。
--restart=always \# 【p】映射策略,<宿主端口>:<容器端口>
-p 27017:27017 \# 使用本地時區
-e TimeZone='Asia/Shanghai' \
-e TZ='Asia/Shanghai' \
-v /etc/localtime:/etc/localtime \# 掛載卷映射(宿主:容器)
## /data/config/mongod.conf:實例化配置文件
## /data/db:應用數據
## /mongo/logs:運行日志
-v /mongo/config/mongod.conf:/etc/mongod.conf \
-v /mongo/db:/data/db \
-v /mongo/logs:/var/log/mongodb \# 讓容器獲取宿主機root權限
--privileged=true \# 最后一行所引用的docker鏡像源
2.3 實例腳本
此處在卷標映射時,將配置文件以及數據庫一起存放到mongo父目錄,以便于維護和使用。
sudo docker run -itd --restart=always \
-p 17017:27017 \
-e TimeZone='Asia/Shanghai' \
-e TZ='Asia/Shanghai' \
-v /etc/localtime:/etc/localtime \
-v /mongo/config/mongod.conf:/etc/mongod.conf \
-v /mongo/db:/data/db \
-v /mongo/logs:/var/log/mongodb \
-e MONGO_INITDB_ROOT_USERNAME=root \
-e MONGO_INITDB_ROOT_PASSWORD="123456" \
--privileged=true \
--name mongo \
docker.io/mongo:8.0
3. 實例操作
3.1 Mongo bash控制臺
# 登錄到bash控制臺
sudo docker exec -it mongo mongosh
# 當配置文件,啟用auth=true時。需要以root身份登錄
sudo docker exec -it mongo mongosh -u root -p '123456' --authenticationDatabase admin
## 如果不指定,切換到admin庫,創建db用戶時會報錯
## 認證失敗:MongoServerError[AuthenticationFailed]: Authentication failed.# 打開系統admin庫
use admin
# 創建root用戶
db.auth("admin","123456")
執行結果如下
常用運維管理指令
# 更新用戶密碼
db.changeUserPassword("admin","123456")# 新增用戶權限
db.updateUser("admin",{roles:[{role:"readWrite",db:"admin"}]})# 刪除用戶
db.dropUser({'admin'})
# 查詢所有用戶
show users
3.2 庫表操作
具體請見官方文檔中文版,下面以創建一個庫表數據集并執行查詢為例
# 創建庫
use huchi
# 新增一個庫用戶并分配讀寫權限
db.createUser({user: "admin",pwd: "admin",roles:["readWrite"]})
# 開啟身份權限權限
db.auth('admin','admin')# 創建數據集
db.temp_sales.insert({ name:"abc", age:22, 'weight': '50斤'} )# 查詢數據集
db.temp_sales.find()
執行結果如下
4. MongoDB Compass (GUI)
MongoDB Compass 是一款功能強大的 GUI,用于在可視環境中查詢、聚合和分析 MongoDB 數據。
Compass 可免費使用并提供源代碼,并且可以在 macOS、Windows 和 Linux 上運行。
詳細操作文檔請見官方使用文檔,下載地址MongoDB Compass(GUI)。
登錄連接配置
只是沒有找到中文語言包,就這么用吧。
查詢temp_sales數據內容如下
二、安裝Redis:7.4.1
Redis 是由 Redis Ltd.開發的高性能開源內存數據庫,以其極速響應和靈活的數據結構(如字符串、哈希、列表)著稱,廣泛應用于緩存、實時消息隊列等場景。為應對復雜數據處理需求,它在Redis核心基礎上增加了一些高級功能和模塊,以支持更多的使用場景和需求。Redis Stack 包括以下幾個主要組件:
- JSON文檔:RedisJSON用于在 Redis 中存儲和操作 JSON 數據結構,支持復雜的 JSON 查詢和更新操作。
- 全文搜索:RediSearch提供全文搜索和二次索引功能,使得在 Redis 中可以進行復雜的搜索查詢。
- 圖數據庫:RedisGraph模塊,支持圖數據結構的存儲和查詢,適用于社交網絡、推薦系統等場景。
- 時序數據:RedisTimeSeries專門用于時間序列數據的存儲和分析,支持高效的時間序列數據寫入和查詢。
- 布隆過濾器:RedisBloom一種概率數據結構,旨在以高度節省內存的方式快速確定元素是否存在于集合中。
Redis Stack 通過這些模塊的組合,使得開發者可以在一個統一的平臺上處理多種類型的數據和查詢需求,極大地擴展了 Redis 的應用場景。官方提供了兩種鏡像版本:
- redis/redis-stack:包含 Redis Stack server 和 Redis Insight。該容器最適合本地開發。
- redis/redis-stack-server:僅提供 Redis Stack server 。該容器最適合生產部署。
兩者區別在于有沒有帶有 RedisInsight web可視化端。
1. 拉取容器鏡像
# redis:7.4.1
sudo docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis:7.4.1# 添加標簽名Tag
sudo docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis:7.4.1 redis:7.4.1# 移除標簽名Tag
sudo docker rmi swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis:7.4.1
國內鏡像參考:
渡渡鳥鏡像
2. 生成Run腳本
可參考:渡渡鳥-Run助手
2.1 實例腳本
首先,創建宿主機掛載目錄sudo mkdir -p /docker/redis/{conf,data}
,配置內容如下
# 拉取配置文件(拉取不了就只能[手工下載]https://download.redis.io/releases/ 對應的版本包)
sudo wget -O https://raw.githubusercontent.com/redis/redis/7.4/redis.conf docker/redis/conf/redis-server.conf# 編輯配置
sudo vim docker/redis/conf/redis-server.conf## 修改內容如下(:wq!保存)
bind 127.0.0.1 或者 bind 127.0.0.1 -::1 #注釋掉這部分,使redis可以外部訪問
daemonize no #用守護線程的方式啟動
logfile "redis.log" #日志文件路徑(選配)
requirepass 123456 #給redis設置密碼
appendonly yes #redis持久化 默認是no
tcp-keepalive 300 #防止出現遠程主機強迫關閉了一個現有的連接的錯誤 默認是300
再運行如下腳本
sudo docker run -itd \
--restart=unless-stopped \
-p 6379:6379 \
-e TimeZone='Asia/Shanghai' \
-e TZ='Asia/Shanghai' \
-v /etc/localtime:/etc/localtime \
-v /docker/redis/conf/redis-server.conf:/conf/redis.conf \
-v /docker/redis/data:/data \
--name redis \
--privileged=true \
redis:7.4.1 redis-server /etc/redis/redis.conf
2.2 運維管理
# 檢查容器狀態
sudo docker ps -a | grep redis
sudo docker inspect redis# 登錄bash后端
sudo docker exec -it redis bash# 直連Redis庫
sudo docker exec -it redis bash -c "redis-cli"
## 有密碼連接Redis
sudo docker exec -it redis bash -c "redis-cli -a 123456"
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
127.0.0.1:6379>## 也可以登錄bash控制臺后
root@57a9462ebf07:/data# redis-cli -h 127.0.0.1 -p 6379 -a 123456
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
127.0.0.1:6379># Redis數據測試
127.0.0.1:6379> set a 1
OK
127.0.0.1:6379> get a
"1"# 報錯:(error) NOAUTH Authentication required.
# 原因:redis身份驗證失敗,指令操作無效。# 獲取密碼
127.0.0.1:6379> config get requirepass
1) "requirepass"
2) "123456"# 修改密碼
config set requirepass 777888
## 需注意的是,該密碼不再重寫conf中該配置參數(重啟服務則仍以conf配置為主)。
參考資料
docker安裝Redis
Docker 安裝 Redis 詳細指南
docker安裝redis7.0
Docker部署redis,并掛載存儲,日志,配置文件