部署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的数据库文件

相关推荐
Yc_sujiaodiban4 天前
技术复盘|2026东北商业老旧地胶翻新通病解析:简易铺贴为何普遍一年内失效
nosql
逻极5 天前
MongoDB 从入门到精通:文档数据库的灵活之道
分布式·mongodb·nosql·聚合框架
Irene19918 天前
关系型和非关系型数据库理解,什么是关系(关系 = 表与表之间的连接线(外键关联))
nosql·关系型数据库·非关系型数据库
阿演9 天前
DataDjinn 更新记录:从 AI 数据库客户端到 MongoDB + 达梦 DM 驱动管理增强
mongodb·ai·agent·达梦·mongo·数据库连接工具
小哈里10 天前
【K8S】云原生时代的GitOps最佳实践 —— ArgoCD
云原生·kubernetes·云计算·argocd·基础设施
常常有13 天前
从零开始的 Redis 主从架构搭建与实战验证
redis·架构·nosql
lifewange1 个月前
NoSQL
数据库·nosql
刘~浪地球1 个月前
MongoDB入门与安装配置:开启NoSQL数据库之旅
数据库·mongodb·nosql
Lumiya20881 个月前
一锅一码一匠心,从泥到火可追溯,京尚智慧厨房以数字化赋能品质升级
nosql
qq_40999093?1 个月前
NoSQL数据库解析:Redis
数据库·redis·nosql