MYSQL故障排查和環境優化

一、MySQL故障排查

1.?單實例常見故障

(1)連接失敗類問題
  • ERROR 2002 (HY000): Can't connect to MySQL server
    原因:MySQL未啟動或端口被防火墻攔截。
    解決:啟動MySQL服務(systemctl start mysqld)或開放端口(如3306)367。

  • ERROR 1045 (28000): Access denied
    原因:密碼錯誤或權限不足。
    解決:修改配置文件添加skip-grant-tables,重啟后重置密碼并授權367。

(2)性能與資源類問題
  • Too many connections
    原因:連接數超出max_connections限制。
    解決:臨時調整(SET GLOBAL max_connections=10000;)或永久修改配置文件36。

  • Host blocked due to connection errors
    原因:同一IP頻繁連接失敗超過max_connect_errors閾值。
    解決:執行mysqladmin flush-hosts或增大max_connect_errors值36。

(3)數據損壞與表修復
  • 表文件損壞(如MYI文件錯誤)
    原因:非正常關機或磁盤空間不足。
    解決:使用myisamchk -r修復或通過phpMyAdmin修復表36。

  • InnoDB數據文件損壞
    解決:設置innodb_force_recovery=4啟動數據庫,備份后重建表37。

2.?主從復制故障

  • Slave_IO_Running為NO
    原因:主從server-id重復或網絡中斷。
    解決:修改從庫server-id并重啟同步367。

  • Slave_SQL_Running為NO(主鍵沖突)
    解決:跳過錯誤(SET GLOBAL SQL_SLAVE_SKIP_COUNTER=1;)或設置從庫只讀36。

  • 中繼日志損壞
    解決:重新指定同步點(CHANGE MASTER TO MASTER_LOG_FILE='...', MASTER_LOG_POS=...;)36。


二、生產環境優化策略

1.?硬件與存儲優化

  • CPU:選擇多核高主頻處理器(如Intel Xeon),支持高并發處理17。

  • 內存:建議至少4GB,優先分配大內存給innodb_buffer_pool_size(占物理內存70%~80%)157。

  • 磁盤:使用SSD或RAID 10陣列,避免RAID 5(寫性能差)157。

2.?查詢與索引優化

  • 索引設計

    • 選擇性高列優先:如用戶ID而非性別字段25。

    • 覆蓋索引:避免回表查詢(如SELECT name FROM users WHERE name='Alice')25。

    • 復合索引:遵循最左前綴原則(如索引(col1,col2)需條件包含col1)25。

  • SQL語句優化

    • 避免全表掃描:使用EXPLAIN檢查執行計劃29。

    • 分頁優化:用WHERE id > 1000 LIMIT 10替代LIMIT 1000,1025。

    • 批量操作:合并INSERT語句減少事務開銷25。

3.?配置參數調優

  • 緩沖池innodb_buffer_pool_size設置為物理內存的70%~80%57。

  • 連接管理:調整max_connections(默認151)和wait_timeout(建議120秒)57。

  • 日志配置:開啟慢查詢日志(slow_query_log=ON)并設置合理閾值(long_query_time=1)25。

4.?架構與維護優化

  • 讀寫分離:通過主從復制分離讀/寫流量,使用中間件(如ProxySQL)1410。

  • 分庫分表:按業務拆分大表,減少單表壓力14。

  • 定期維護

    • 使用OPTIMIZE TABLE減少碎片57。

    • 監控工具:Percona Monitoring或Prometheus+Grafana10。


三、高級技巧與注意事項

  • 關閉DNS解析:在配置中添加skip-name-resolve提升連接速度(需改用IP授權)8。

  • 磁盤調度策略:設置為deadlinenoop(SSD適用)以提高I/O效率8。

  • 網絡優化:調整TCP緩沖隊列(net.ipv4.tcp_max_syn_backlog)和隨機端口范圍8。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/81542.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/81542.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/81542.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

7GB顯存如何部署bf16精度的DeepSeek-R1 70B大模型?

構建RAG混合開發---PythonAIJavaEEVue.js前端的實踐-CSDN博客 服務容錯治理框架resilience4j&sentinel基礎應用---微服務的限流/熔斷/降級解決方案-CSDN博客 conda管理python環境-CSDN博客 快速搭建對象存儲服務 - Minio,并解決臨時地址暴露ip、短鏈接請求改…

數字圖像處理——圖像壓縮

背景 圖像壓縮是一種減少圖像文件大小的技術,旨在在保持視覺質量的同時降低存儲和傳輸成本。隨著數字圖像的廣泛應用,圖像壓縮在多個領域如互聯網、移動通信、醫學影像和衛星圖像處理中變得至關重要。 技術總覽 當下圖像壓縮JPEG幾乎一統天下&#xff…

抖音視頻怎么去掉抖音號水印

你是不是經常遇到這樣的煩惱?看到喜歡的抖音視頻,想保存下來分享給朋友或二次創作,卻被抖音號水印擋住了畫面?別著急,今天教你幾種超簡單的方法,輕松去除水印,高清無水印視頻一鍵保存&#xff0…

RISC-V 開發板 MUSE Pi Pro PCIE 測試以及 fio 崩潰問題解決

視頻講解: RISC-V 開發板 MUSE Pi Pro PCIE 測試以及 fio 崩潰問題解決 板子上有一個m.2的pcie插槽,k1有三個pcie控制器,pcie0和usb3復用一個phy,所以實際開發板就兩個,測試的話,上一個nvme硬盤&#xff0c…

超級管理員租戶資源初始化與授權管理設計方案

背景說明 在多租戶系統中,資源(如功能模塊、系統菜單、服務能力等)需按租戶維度進行授權管理。超級管理員在創建新租戶時,需要初始化該租戶的資源授權信息。 兩種可選方案 方案描述方案 A:前端傳入選中的資源列表創…

stm32week16

stm32學習 十一.中斷 4.使用中斷 EXTI的配置步驟: 使能GPIO時鐘設置GPIO輸入模式使能AFIO/SYSCFG時鐘設置EXTI和IO對應關系設置EXTI屏蔽,上/下沿設置NVIC設計中斷服務函數 HAL庫的使用: 使能GPIO時鐘:__HAL_RCC_GPIOx_CLK_EN…

什么是RDMA?

什么是RDMA? RDMA(RemoteDirect Memory Access)技術全稱遠程直接內存訪問,就是為了解決網絡傳輸中服務器端數據處理的延遲而產生的。它將數據直接從一臺計算機的內存傳輸到另一臺計算機,無需雙方操作系統的介入。這允許高吞吐、低延遲的網絡…

golang 安裝gin包、創建路由基本總結

文章目錄 一、安裝gin包和熱加載包二、路由簡單場景總結 一、安裝gin包和熱加載包 首先終端新建一個main.go然后go mod init ‘項目名稱’執行以下命令 安裝gin包 go get -u github.com/gin-gonic/gin終端安裝熱加載包 go get github.com/pilu/fresh終端輸入fresh 運行 &…

【數據結構篇】鏈式結構二叉樹

目錄: 一 二叉鏈的概念與結構: 1.1 概念: 1.2 結構: 二 二叉鏈的實現: 2.1 二叉樹的構建: 2.2 二叉樹的遍歷: 2.2.1 前序遍歷: 2.2.2 中序遍歷: 2.2.3 后序遍歷…

【MySQL】02.數據庫基礎

1. 數據庫的引入 之前存儲數據用文件就可以了,為什么還要弄個數據庫? 文件存儲存在安全性問題,文件不利于數據查詢和管理,文件不利于存儲海量數據,文件在程序中控制不方便。而為了解決上述問題,專家們設計出更加利于…

什么是 Langchain 以及其核心組件

LangChain 官方文檔:LangChain 一、什么是Langchain LangChain 是一個用于構建基于LLM的應用框架,它提供了對 LLM API 的封裝和擴展,使開發者能夠更方便地構建復雜的應用。 個人理解:用類比的方法來說,LangChain類似…

博客系統功能測試

博客系統網址:http://8.137.19.140:9090/blog_list.html 主要測試內容 功能測試、界面測試、性能測試、易用性測試、安全測試、兼容性測試、弱網測試、安裝卸載測試、壓力測試… 測試方法及目的 利用selenium和python編寫測試腳本,對博客系統進行的相關…

項目制作流程

一、使用 CRA 創建項目 npx create-react-app name 二、按照業務規范整理項目目錄 (重點src目錄) 三、安裝插件 npm install sass -Dnpm install antd --savenpm install react-router-dom 四、配置基礎路由 Router 1. 安裝路由包 react-router-dom …

ngx_http_random_index_module 模塊概述

一、使用場景 隨機內容分發 當同一目錄下存放多份等價內容(如多張輪播圖、不同版本靜態頁面等)時,可通過隨機索引實現負載均衡或流量分散。A/B 測試 通過目錄請求自動隨機分配用戶到不同測試組,無需后端邏輯參與。動態“首頁”選…

智能權限守護者:基于Python描述符的動態角色控制實現

智能權限守護者:基于Python描述符的動態角色控制實現 引言:當描述符遇見權限管理 在Python的魔法方法體系中,描述符(Descriptor)以其優雅的屬性訪問控制機制著稱。當我們將描述符與RBAC(基于角色的訪問控制)模型結合,就能創造出既靈活又安全的動態權限管理系統。本文…

Linux 的 UDP 網絡編程 -- 回顯服務器,翻譯服務器

目錄 1. 回顯服務器 -- echo server 1.1 相關函數介紹 1.1.1 socket() 1.1.2 bind() 1.1.3 recvfrom() 1.1.4 sendto() 1.1.5 inet_ntoa() 1.1.6 inet_addr() 1.2 Udp 服務端的封裝 -- UdpServer.hpp 1.3 服務端代碼 -- UdpServer.cc 1.4 客戶端代碼 -- UdpClient.…

Linux 內核等待機制詳解:prepare_to_wait_exclusive 與 TASK_INTERRUPTIBLE

1. prepare_to_wait_exclusive 函數解析 1.1 核心作用 prepare_to_wait_exclusive 是 Linux 內核中用于將進程以獨占方式加入等待隊列的關鍵函數,其主要功能包括: 標記獨占等待:通過設置 WQ_FLAG_EXCLUSIVE 標志,表明此等待條目是獨占的。 安全入隊:在自旋鎖保護下,將條…

【Android構建系統】了解Soong構建系統

背景介紹 在Android7.0之前,Android使用GNU Make描述和執行build規則。Android7.0引入了Soong構建系統,彌補Make構建系統在Android層面變慢、容易出錯、無法擴展且難以測試等缺點。 Soong利用Kati GNU Make克隆工具和Ninja構建系統組件來加速Android的…

信息學奧賽一本通 1539:簡單題 | 洛谷 P5057 [CQOI2006] 簡單題

【題目鏈接】 ybt 1539:簡單題 洛谷 P5057 [CQOI2006] 簡單題 【題目考點】 1. 樹狀數組 模板題及講解:洛谷 P3374 【模板】樹狀數組 【解題思路】 解法1:樹狀數組 該有01構成數組初值都為0。 某位置的元素被修改奇數次后值為1&#x…

倉頡開發語言入門教程:搭建開發環境

倉頡開發語言作為華為為鴻蒙系統自研的開發語言,雖然才發布不久,但是它承擔著極其重要的歷史使命。作為鴻蒙開發者,掌握倉頡開發語言將成為不可或缺的技能,今天我們從零開始,為大家分享倉頡語言的開發教程,…