最近公司在用一个类似于BLOG的一个系统来管理项目, PHP+MYSQL架构,同事反应这个系统打开项目的时候非常慢,由于这个系统的服务器在美国,为了查找问题,首先从ftp站点把源文件下载下来,然后用phpmyadmin把mysql数据库的文件备份下来,这样就可以在本地虚拟机搭建起了一个测试环境,
ubuntu10.4+apache2+mysql+php
开始做一些简单配置系统就开始运行,可能跟源系统的具体配置不一样,php运行起来还是有点错误,结果导致apache2的错误日志文件急速增长,最后通过在php语句中添加错误屏蔽语句才解决这个,这样系统总算能运行起来了,
接下来开始优化一些mysql的参数变量,做了些修改以后还是觉得没有明显的改善。
设置慢查询,查询结果如下:
mysqldumpslow mysql-slow.log,发现下面这条语句耗时最多,而且需要重复运行很多遍
sbvgroup@ubuntu104:/var/log/mysql$ mysqldumpslow mysql-slow.log
Reading mysql slow query log from mysql-slow.log
Count: 29 Time=3.68s (106s) Lock=0.00s (0s) Rows=646.8 (18757), root[root]@localhost
SELECT
prj_id, dep_id
FROM
sys_projeto,
sys_grupo,
sys_grupo_projeto,
sys_usuario_grupo,
sys_usuario,
sys_departamento,
sys_departamento_projeto,
sys_usuario_projeto_departamento
WHERE
prj_remove 'S'
AND grp_remove 'S'
AND grpr_remove 'S'
AND usu_id = '100048' AND usu_remove 'S'
AND usug_remove 'S'
AND dep_remove 'S'
AND depp_remove 'S'
AND usupd_remove 'S'
AND usu_id = usug_idusuario
AND usug_idgrupo = grp_id
AND grp_id = grpr_idgrupo
AND grpr_idprojeto = prj_id
AND usu_id = usupd_idusuario
AND prj_id = usupd_idprojeto
AND prj_id = depp_idprojeto
AND dep_id = usupd_iddepartamento
AND dep_id = depp_idderpatamento
AND usupd_iddepartamento '100048'
UNION
SELECT
prj_id, dep_id
FROM sys_projeto,
sys_usuario,
sys_departamento,
sys_departamento_projeto
WHERE prj_remove 'S'
AND usu_remove 'S'
AND dep_remove 'S'
AND depp_remove 'S'
AND dep_id = depp_idderpatamento
AND depp_idprojeto = prj_id
AND usu_id = '100048'
AND prj_idgerente = usu_id
然后针对语句条用的表字段做了些索引,结果得到改善,本人对sql语句不是很精通,可能是这条语句本身的执行效率就不高,再加上没有适当索引,所以导致系统运行很慢。

MySQL通過異步、半同步和組複製三種模式處理數據複製。 1)異步複製性能高但可能丟失數據。 2)半同步複製提高數據安全性但增加延遲。 3)組複製支持多主複製和故障轉移,適用於高可用性需求。

EXPLAIN語句可用於分析和提升SQL查詢性能。 1.執行EXPLAIN語句查看查詢計劃。 2.分析輸出結果,關注訪問類型、索引使用情況和JOIN順序。 3.根據分析結果,創建或調整索引,優化JOIN操作,避免全表掃描,以提升查詢效率。

使用mysqldump進行邏輯備份和MySQLEnterpriseBackup進行熱備份是備份MySQL數據庫的有效方法。 1.使用mysqldump備份數據庫:mysqldump-uroot-pmydatabase>mydatabase_backup.sql。 2.使用MySQLEnterpriseBackup進行熱備份:mysqlbackup--user=root--password=password--backup-dir=/path/to/backupbackup。恢復時,使用相應的命

MySQL慢查詢的主要原因包括索引缺失或不當使用、查詢複雜度、數據量過大和硬件資源不足。優化建議包括:1.創建合適的索引;2.優化查詢語句;3.使用分錶分區技術;4.適當升級硬件。

MySQL視圖是基於SQL查詢結果的虛擬表,不存儲數據。 1)視圖簡化複雜查詢,2)增強數據安全性,3)維護數據一致性。視圖是數據庫中的存儲查詢,可像表一樣使用,但數據動態生成。

mysqldiffersfromothersqldialectsinsyntaxforlimit,自動啟動,弦樂範圍,子征服和表面上分析。 1)MySqluessLipslimit,whilesqlserverusestopopandoraclesrontersrontsrontsrontsronnum.2)

MySQL分區能提升性能和簡化維護。 1)通過按特定標準(如日期範圍)將大表分成小塊,2)物理上將數據分成獨立文件,3)查詢時MySQL可專注於相關分區,4)查詢優化器可跳過不相關分區,5)選擇合適的分區策略並定期維護是關鍵。

在MySQL中,如何授予和撤銷權限? 1.使用GRANT語句授予權限,如GRANTALLPRIVILEGESONdatabase_name.TO'username'@'host';2.使用REVOKE語句撤銷權限,如REVOKEALLPRIVILEGESONdatabase_name.FROM'username'@'host',確保及時溝通權限變更。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

WebStorm Mac版
好用的JavaScript開發工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1
好用且免費的程式碼編輯器

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器