MongoDB 常见问题处理(一)(mongodb unauthorized)
itomcoil 2025-06-08 21:51 9 浏览
MongoDB维护过程中常用问题处理
MongoDB实例监控中,CPU使用率过高问题排查?
- 使用top命令查看当前CPU资源利用情况,若都在正常范围,则考虑是否频繁操作数据库。
- 确定业务是否有很高的操作数据库频率 若通过监控指标或command line发现,业务QPS过高,则需要考虑升级实例配置,否则排查是否有慢查询堆积。
- 确定是否有慢查询堆积 在主节点用慢查询日志(system.profile)找到超过200ms的语句,然后再通过.explain()解析影响行数,分析为什么超过200ms。
container网络入/出流量告警问题?
当出现网络流量过高的情况,通常是因为服务器与服务器之间拷贝数据导致的,拷贝结束,流量即可恢复正常,如果不是数据拷贝,通常是服务器中毒或者受到攻击,在对内或对外大量发包导致,此时,可按照以下方法进行排查
- 如果您使用的是Linux系统的服务器,可以在系统中安装nethogs查看具体的进程占用流量的情况(如nether eth0->查看网卡具体流量)并杀死该进程;对于一些常见的网络问题,如容器之间网络通信问题,您可以使用Tcpdump工具捕获网络流量,来解决这些网络问题.
- 如果您使用的是windows系统,可通过资源监视器(启动任务管理器>资源监视器>网络)看到哪些进程占用网络流量并结束相关进程.
容器down 后排查处理?
当prometheus监控到容器down指标Container Killed告警,说明容器可能失效或终止运行,以异常状态退出或健康检查失败,k8s的核心组件 kubelet会根据设置的pod重启策略自动重启该容器,例如容器运行时内存超出限制,容器以Failed状态终止,kubelet则自动重启该容器。而pod中的守护进程supervisor会保证mongod服务自动重启。
MongoDB监控里Memory使用率过高?
mongo为了优化读写效率,将内存当做缓存,读写次数越多、数据量越大,缓存就越大。
解决办法:
- 控制并发连接数: MongoDB driver在连接mongod时,会维护一个连接池(默认100),当有大量的客户端同时访问同一个mongod时,就要减少每个客户端连接池的大小,可以在配置文件中通过配置net.maxIncomingConnections来限制最大的并发连接数,防止数据库压力过载。或者增大memory资源。
- 是否配置journal mongodb4.0默认开启journal,这样会持久化存储,不过会耗费内存资源,除非正常关闭数据库。可以在配置文件中关闭journal,不会做持久化存储,而是每分钟做一次全量的checkpoint,所以在异常出现的情况下,会丢掉大概一分钟的数据。
存储使用率达到预警值问题?
mongodb删除数据时,不会直接释放磁盘,而是产生很多碎片。这些碎片会被mongodb继续使用,当有新数据插入时,会重复利用这些碎片,不需要新申请磁盘,导致磁盘会处于高水位的使用水平,由于碎片只会被所属的库使用,在新建很多库的情况下,会使磁盘资源越来越紧张。解决方法:
- 使用命令:df -TH,查看系统的空间使用情况,查看是哪个数据盘资源负载过高,理想情况下,考虑提升系统资源,否则按以下方法排查处理。
- 将准备节点清空,重新同步同步 备节点同步的过程中,碎片空间会被清理。备节点同步的是完全的数据和索引。然后再进行一次主备切换,再将主节点数据清空,同步一次,最终让主备节点都达到释放碎片的目的。
- 使用compact命令 compact是mongodb中的压缩命令,可以删除数据产生的碎片。在WiredTiger引擎下,该命令会将整理出的空间释放给操作系统: 进入要执行的数据库:db.runCommand({compact:"库名/集合名",force:true}),在每一个节点上都需要执行,且带force:true参数,否则出错。
- 做repairDatabase 在mongodb数据库中运行db.repairDatabase() , 或者 db.runCommand({ repairDatabase: 1 })、或带几个参数: db.runCommand({ repairDatabase: 1, preserveClonedFilesOnFailure: <boolean>, backupOriginalFiles: <boolean> } ),这是官方认为唯一可以回收磁盘空间的方法,不过,能不用的情况下,尽量不用,会花费很多时间与性能的。
相关推荐
- pip 设置镜像源
-
pip是python必不可少的的包管理工具,但是要在国内用得爽,必须要配置镜像源。我常用的是清华镜像站。pipconfigsetglobal.index-urlhttps://pypi...
- 定制构建OpenWrt发行版镜像及插件安装包,升级插件到最新版本
-
最近Tailscale提示OpenWrt路由器上的版本太低,建议升级到最新版本。OpenWrt用的23.05的,因为23.05中带的tailscale版本比较老,之前升级都是从主线版本中下载最新的ta...
- 第十节 Dockerfile 核心指南:从基础概念到镜像构建实践
-
一、Dockerfile基础概念(一)本质与作用Dockerfile是用于定义Docker镜像构建流程的文本文件,包含一系列指令和说明,指导Docker引擎生成定制化镜像。其核心价值在于:...
- Python 模型部署不用愁!容器化实战,5 分钟搞定环境配置
-
你是不是也遇到过这种糟心事:花了好几天训练出的Python模型,在自己电脑上跑得顺顺当当,一放到服务器就各种报错。要么是Python版本不对,要么是依赖库冲突,折腾半天还是用不了。别再喊“我...
- Docker-镜像
-
1、获取镜像在Docker中,获取(下载)镜像通常使用dockerpull命令:基本用法:dockerpull镜像名称[:标签]例如:dockerpullnginx...
- 第十二节 Ubuntu 系统 Docker 镜像安装与容器运行指南
-
一、Ubuntu镜像版本选择(一)DockerHub镜像库浏览Ubuntu官方镜像在DockerHub上提供多版本支持,访问地址:https://hub.docker.com/_/ubu...
- Docker-使用Dockerfile 定制镜像
-
一、什么是Dockerfile?Dockerfile是一个文本文件,其中包含一条条构建镜像所需的指令。Docker引擎会按顺序执行这些指令,逐步构建出最终的自定义镜像。二、Dockerfil...
- 在Windows的WSL环境中本地安装watercrawl和Python3.13
-
这段时间在折腾Dify环境调用网络爬虫工具去自动化抓取网页信息的功能,就希望在本地Windows11的WSL环境中docker方式部署watercrawl,但每次都报错如下:用命令pip--ver...
- 1分钟搞定!Python超速工具uv换国内镜像,下载速度飙升10倍
-
1分钟搞定!Python超速工具uv换国内镜像,下载速度飙升10倍作为搞运维的老手,我太清楚Python包下载速度慢是啥滋味了。今天我来教你用3行代码给uv换上清华或者阿里云的镜像,这样就...
- Dockerfile 教程:构建你的第一个自定义镜像!
-
Dockerfile就是你自定义镜像的“说明书”,学会它,你就能打造属于自己的开发环境、部署环境,甚至可以把你的应用一键打包。一、什么是Dockerfile?Dockerfile是一个文本文件...
- 提升Python编程效率的10点建议
-
程序员的时间很宝贵,Python这门语言虽然足够简单、优雅,但并不是说你使用Python编程,效率就一定会高。要想节省时间、提高效率,还是需要注意很多地方的。今天就与大家分享资深Python程序员总结...
- 掌握线性代数: 奇异值分解 (SVD)
-
奇异值分解(SVD)什么是SVD?奇异值分解是一种矩阵分解方法,它将矩阵A分解为三个分量:哪里:U是正交矩阵(mxm)Σ是包含奇异值(mxn)的对角矩阵V^T是另一个正交矩...
- 用 Docker+K8s 部署模型,再也不怕流量暴增和服务器崩溃了
-
上周朋友公司的AI模型又出问题了——电商大促期间,预测接口突然崩溃,眼睁睁看着订单流失。老板气得拍桌子:“花了几十万训练的模型,连个大促都扛不住?”这其实是很多企业的通病:模型在实验室跑得好好...
- Python 图像处理
-
以前照相从来没有那么容易。现在你只需要一部手机。拍照是免费的,如果我们不考虑手机的费用的话。就在上一代人之前,业余艺术家和真正的艺术家如果拍照非常昂贵,并且每张照片的成本也不是免费的。我们拍照是为了及...
- 一文让你掌握22个神经网络训练技巧
-
作者丨匡吉来源丨深蓝学院神经网络训练是一个非常复杂的过程,在这过程中,许多变量之间相互影响,因此我们研究者在这过程中,很难搞清楚这些变量是如何影响神经网络的。而本文给出的众多tips就是让大家,在神经...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)