部署mongo容器单机

部署mongo容器单机

  • [1. 拉取镜像](#1. 拉取镜像)
  • [2. 创建目录用来存放mongo数据](#2. 创建目录用来存放mongo数据)
  • 3.初始化数据库和用户
  • [4. 测试](#4. 测试)

1. 拉取镜像

bash 复制代码
podman pull mongo

2. 创建目录用来存放mongo数据

bash 复制代码
mkdir ~/mongodb-data
bash 复制代码
podman run -d \
--name mongodb \
-p 27017:27017 \
-v ~/mongodb-data:/data/db \
-e MONGO_INITDB_ROOT_USERNAME=root \
-e MONGO_INITDB_ROOT_PASSWORD=123456 \
--restart=always \
mongo

3.初始化数据库和用户

bash 复制代码
# 直接在宿主机上执行mongosh,注意因为本案例使用了mongo 8.2.4版本,有mongosh,如果低于6,那么使用mongo

 podman exec -it mongodb mongosh
bash 复制代码
// 步骤1:认证root账号(已完成可跳过)
use admin;
db.auth("root", "123456");

// 步骤2:切换到xiongwu库(要给哪个库创建用户,就先切换到哪个库)
use xiongwu;

// 步骤3:创建专属业务用户(示例:用户名 xiongwu,密码 xiongwu_123456)权限:对xiongwu库拥有读写权限
db.createUser({
  user: "xiongwu",  
  pwd: "xiongwu_123456", 
  roles: [
    { role: "readWrite", db: "xiongwu" } 
  ]
});

4. 测试

建表插入数据,查询数据,测试下可用性

bash 复制代码
xiongwu> db.test.insert({ name: "test", value: 123 });
DeprecationWarning: Collection.insert() is deprecated. Use insertOne, insertMany, or bulkWrite.
{
  acknowledged: true,
  insertedIds: { '0': ObjectId('69835e5874372e578a8ce5b0') }
}
xiongwu> show collections;
test

xiongwu> show tables
test
xiongwu> db.test.find()
[
  { _id: ObjectId('69835e5874372e578a8ce5b0'), name: 'test', value: 123 }
]
xiongwu>

以上都正常,那么说明,这个环境可以用了。


本地可以看到mongo的数据库文件

相关推荐
qq_40999093?7 小时前
NoSQL数据库解析:Redis
数据库·redis·nosql
zs宝来了1 天前
Ray 分布式计算:Actor 模型与任务调度
机器学习·ai·基础设施
Francek Chen1 天前
【大数据存储与管理】NoSQL数据库:05 NoSQL的三大基石
大数据·数据库·分布式·nosql
豆瓣鸡7 天前
Redis笔记(黑马点评)
java·redis·nosql
zs宝来了7 天前
PyTorch DDP:分布式训练与梯度同步
机器学习·ai·基础设施
洛菡夕8 天前
NoSQL之Redis配置与优化
redis·git·nosql
kiku18189 天前
NoSQL之Redis集群
数据库·redis·nosql
卢傢蕊9 天前
NoSQL 之Redis 集群
数据库·redis·nosql
_下雨天.10 天前
NoSQL之Redis配置与优化
数据库·redis·nosql