用DDRNet-23-slim在RTX 3060笔记本上搞定细胞图像分割:从数据标注到模型训练全流程避坑
2026/5/16 10:35:31
你需要一份在openEuler系统下安装MongoDB的技术教程,我会按照环境准备→安装部署→配置启动→功能验证的流程,提供详细且可直接操作的步骤,同时覆盖开源版MongoDB(社区版)的核心配置要点。
# 切换到root用户(若已为root可跳过)suroot# 更新系统包dnf update -y# 安装基础依赖(MongoDB运行所需)dnfinstall-ywgetnet-tools libcurl opensslopenEuler基于RPM包管理,直接使用MongoDB官方yum源更便捷:
# 创建MongoDB的yum源配置文件vim/etc/yum.repos.d/mongodb-org-7.0.repo将以下内容粘贴到文件中(适配openEuler的RHEL兼容架构):
[mongodb-org-7.0] name=MongoDB Repository baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/7.0/x86_64/ gpgcheck=1 enabled=1 gpgkey=https://www.mongodb.org/static/pgp/server-7.0.asc说明:如果是ARM64架构,将
x86_64替换为aarch64即可。
# 安装MongoDB完整包(包含服务端、客户端、工具)dnfinstall-y mongodb-org# 验证安装版本(确认安装成功)mongod --version安装成功后,会输出类似如下版本信息:
db version v7.0.8 Build Info: { "version": "7.0.8", "gitVersion": "xxx", "openSSLVersion": "OpenSSL 1.1.1k 25 Mar 2021", "modules": [], "allocator": "tcmalloc", "environment": { "distmod": "rhel8", "distarch": "x86_64", "target_arch": "x86_64" } }# 创建数据存储目录mkdir-p /var/lib/mongo# 创建日志存储目录mkdir-p /var/log/mongodb# 设置目录权限为mongodb用户(安装后自动创建的系统用户)chown-R mongodb:mongodb /var/lib/mongo /var/log/mongodbchmod-R755/var/lib/mongo /var/log/mongodbMongoDB默认配置文件为/etc/mongod.conf,需调整关键配置以适配生产/测试环境:
vim/etc/mongod.conf修改后的核心配置如下(保留注释,关键项修改):
# 网络配置net:port:27017# 默认端口,可自定义bindIp:0.0.0.0# 允许所有IP访问,测试环境用;生产环境改为具体IP# 数据存储storage:dbPath:/var/lib/mongo# 数据目录,对应上面创建的路径engine:wiredTiger# 默认存储引擎,高性能# 日志配置systemLog:destination:filepath:/var/log/mongodb/mongod.log# 日志文件路径logAppend:true# 日志追加模式,不覆盖旧日志# 进程管理processManagement:fork:true# 以守护进程方式运行pidFilePath:/var/run/mongodb/mongod.pid# PID文件路径# 副本集/单节点配置(单节点无需配置replicaSet,注释即可)# replication:# replSetName: rs0# 安全配置(测试环境可先关闭,生产环境必须开启认证)security:authorization:disabled# 临时关闭认证,后续可开启说明:生产环境需开启
authorization: enabled(认证),并创建管理员账户。
# 启动mongod服务systemctl start mongod# 设置开机自启systemctlenablemongod# 查看服务状态(确认是否active running)systemctl status mongod若状态显示active (running),说明服务启动成功;若失败,可查看日志/var/log/mongodb/mongod.log定位问题。
如果客户端无法连接MongoDB,可临时关闭防火墙和SELinux(生产环境需配置规则,而非直接关闭):
# 临时关闭防火墙systemctl stop firewalld systemctl disable firewalld# 临时关闭SELinuxsetenforce0# 永久关闭SELinux(需重启服务器)sed-i's/^SELINUX=enforcing/SELINUX=disabled/'/etc/selinux/config# 本地连接(默认无认证)mongo# 或使用新的客户端命令(MongoDB 6.0+推荐)mongosh// 1. 创建/切换到test数据库(MongoDB无显式创建,首次写入即创建)use test// 2. 创建集合并插入数据db.user.insertOne({name:"openEuler",age:5,platform:"openEuler 22.03"})// 3. 查询数据db.user.find()// 4. 退出客户端exit执行后若能看到插入的文档数据,说明MongoDB功能正常。
测试环境完成后,生产环境需开启用户认证,步骤如下:
# 1. 重新连接MongoDBmongosh# 2. 切换到admin数据库(系统库)use admin# 3. 创建管理员账户(拥有所有权限)db.createUser({user:"root", pwd:"MongoDB@123",# 自定义强密码roles:[{role:"root", db:"admin"}]})# 4. 退出客户端exit# 5. 修改配置文件开启认证vim/etc/mongod.conf# 将security下的authorization改为enabled:security: authorization: enabled# 6. 重启mongod服务使配置生效systemctl restart mongod# 7. 使用认证连接MongoDBmongosh -u root -p MongoDB@123 --authenticationDatabase adminnetstat -tulpn | grep 27017,杀死占用进程或修改mongod.conf中的port配置。chown -R mongodb:mongodb /var/lib/mongo /var/log/mongodb。bindIp为0.0.0.0,且防火墙开放27017端口:firewall-cmd --add-port=27017/tcp --permanent && firewall-cmd --reload。/var/log/mongodb/mongod.log定位原因。