亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL數據庫監控軟件lepus使用問題以及解決辦法

2024-07-25 19:09:03
字體:
來源:轉載
供稿:網友

在使用lepus3.7監控MySQL數據庫的時候,碰到了以下幾個問題,本博客給出了這些問題產生的原因,以及相應的解決辦法。

1. 問題1:php頁面無法連接數據庫

直接使用php程序執行php文件,可以連接mysql,但是在httpd中同樣的php頁面無法連接mysql。

lepus的web程序(PHP代碼)無法連接數據庫時,web界面上什么操作也無法繼續。

為此編寫了最簡單的PDO連接測試代碼:

php代碼如下:

[x@coe2coe lepus]$ cat mysql.php<?php try{ #$dsn="mysql:host=127.0.0.1;dbname=lepus;"; $dsn="mysql:host=11.1.1.11;dbname=lepus;"; $user="coe2coe"; $pwd="XXXXXXXXXX"; $sql="select now() as a"; $dbh=new PDO($dsn,$user,$pwd); $stmt=$dbh->prepare($sql); $stmt->execute(); $row=$stmt->fetch(PDO::FETCH_ASSOC); echo "result:".$row['a']; } catch(PDOException $e) { echo "FAILED:".$e->getMessage(); }?>

php程序直接執行php文件:

[x@coe2coe lepus]$ php mysql.phpresult:2018-09-27 00:03:44

通過瀏覽器訪問這個頁面:

FAILED:SQLSTATE[HY000] [2003] Can't connect to MySQL server on '11.1.1.11' (13)

lepus的web程序給出的錯誤提示信息更加模糊。

原因:

通過一番baidu之后,終于看到了一個比較靠譜的分析。

Linux(CentOS7)的selinux安全機制禁止了httpd中的模塊訪問網絡。

[x@coe2coe lepus]$ sudo getsebool -a |grep httpdhttpd_anon_write --> offhttpd_builtin_scripting --> onhttpd_can_check_spam --> offhttpd_can_connect_ftp --> offhttpd_can_connect_ldap --> offhttpd_can_connect_mythtv --> offhttpd_can_connect_zabbix --> offhttpd_can_network_connect --> offhttpd_can_network_connect_cobbler --> offhttpd_can_network_connect_db --> offhttpd_can_network_memcache --> offhttpd_can_network_relay --> offhttpd_can_sendmail --> offhttpd_dbus_avahi --> offhttpd_dbus_sssd --> offhttpd_dontaudit_search_dirs --> offhttpd_enable_cgi --> onhttpd_enable_ftp_server --> offhttpd_enable_homedirs --> offhttpd_execmem --> offhttpd_graceful_shutdown --> onhttpd_manage_ipa --> offhttpd_mod_auth_ntlm_winbind --> offhttpd_mod_auth_pam --> offhttpd_read_user_content --> offhttpd_run_ipa --> offhttpd_run_preupgrade --> offhttpd_run_stickshift --> offhttpd_serve_cobbler_files --> offhttpd_setrlimit --> offhttpd_ssi_exec --> offhttpd_sys_script_anon_write --> offhttpd_tmp_exec --> offhttpd_tty_comm --> offhttpd_unified --> offhttpd_use_cifs --> offhttpd_use_fusefs --> offhttpd_use_gpg --> offhttpd_use_nfs --> offhttpd_use_openstack --> offhttpd_use_sasl --> offhttpd_verify_dns --> off

解決辦法:

臨時辦法:臨時禁用SELINUX。

[x@coe2coe lepus]$ sudo setenforce 0

永久辦法:修改selinux配置文件,禁用SELINUX。

[x@coe2coe lepus]$ cat /etc/selinux/config# This file controls the state of SELinux on the system.# SELINUX= can take one of these three values:#  enforcing - SELinux security policy is enforced.#  permissive - SELinux prints warnings instead of enforcing.#  disabled - No SELinux policy is loaded.#SELINUX=enforcingSELINUX=disabled# SELINUXTYPE= can take one of three two values:#  targeted - Targeted processes are protected,#  minimum - Modification of targeted policy. Only selected processes are protected. #  mls - Multi Level Security protection.SELINUXTYPE=targeted

驗證:

再次在瀏覽器中訪問這個php頁面:

result:2018-09-27 00:09:26

2. 問題2:lepus日志中出現group by警告。

2018-09-27 01:12:41 [WARNING] check mysql 11.1.1.11:3408 failure: 1055 Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'information_schema.processlist.USER' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

原因:

這是lepus后端監控程序寫的log。

默認情況下sql_mode包含ONLY_FULL_GROUP_BY。

mysql> select @@sql_mode;+-------------------------------------------------------------------------------------------------------------------------------------------+| @@sql_mode                                |+-------------------------------------------------------------------------------------------------------------------------------------------+| ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |+-------------------------------------------------------------------------------------------------------------------------------------------+1 row in set (0.01 sec)

解決辦法:

去掉ONLY_FULL_GROUP_BY。

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

3. 問題3:復制監控查詢不到數據。

沒有查詢到數據.

解決辦法:

show_compatibility_56=1

4. 問題4:表空間分析沒有數據。

5. 問題5:慢查詢沒有數據。

前提:

MySQL的my.cnf配置文件中已經配置了慢查詢日志。

slow_query_log=1long_query_time=10log_slow_admin_statements=1log_slow_slave_statements=1

原因:

1.lepus慢查詢分析基于pecona-toolkit工具包中的pt-query-digest程序。需要先安裝這個工具包。

2. pt-query-digest程序與lepus3.7建的表有點沖突。

Pipeline process 5 (iteration) caused an error: DBD::mysql::st execute failed: Data truncated for column 'checksum' at row 1 [for Statement "REPLACE INTO `lepus`.`mysql_slow_query_review_history`(`checksum`, `sample`, `serverid_max`, `db_max`, `user_max`, `ts_min`, 
.....
Terminating pipeline because process 4 (iteration) caused too many errors.

修改mysql_slow_query_review:

mysql> alter table mysql_slow_query_review modify checksum varchar(100) not null ;Query OK, 0 rows affected (0.03 sec)Records: 0 Duplicates: 0 Warnings: 0修改mysql_slow_query_review_history:mysql> alter table mysql_slow_query_review_history modify checksum varchar(100) not null;Query OK, 0 rows affected (0.02 sec)Records: 0 Duplicates: 0 Warnings: 0mysql> alter table mysql_slow_query_review_history modify serverid_max smallint(4) null;Query OK, 0 rows affected (0.02 sec)Records: 0 Duplicates: 0 Warnings: 0

修改腳本

原始的lepus_slowquery.sh文件存在一些問題。

(1) 需要人工指定lepus_server_id。這個腳本需要在每個MySQL服務器上部署,因此如果要監控的MySQL很多,會比較容易出錯。

lepus_server_id這個參數很重要。下面的代碼可以自動取得這個id。

id=$( $mysql_client -h$lepus_db_host -P$lepus_db_port -u$lepus_db_user -p$lepus_db_password -e "select id,host,port from $lepus_db_database.db_servers_mysql where host='$mysql_host' and port=$mysql_port/G" 2>/dev/null |grep "id:" |awk -F": " '{print $2}')

(2)同一臺機器上如果部署有多個MySQL服務實例時,應該只需要一個定時任務即可,在另一腳本中同時對本機的多個MySQL服務實例進行檢查。

這個總的定時腳本如下,測試時開啟了6個MySQL實例,端口依次為:3306 3307 3308 3406 3407 3408.其中3306和3406為MASTER,其它為SLAVE。在這個總的腳本中對每個實例調用lepus_slowquery.sh。

[x@coe2coe mysql]$ cat slowquery.sh################################################################### FileName :slowquery.sh# Author  : coe2coe@qq.com# Created  :2018-09-27# Description :http://www.cnblogs.com/coe2coe/##################################################################!/bin/bashports=(3306 3307 3308 3406 3407 3408)i=0while [ $i -lt ${#ports[*]} ]do port=${ports[$i]} echo -e "/lepus_slowquery.sh $port" ./lepus_slowquery.sh $port  let i=i+1done

(3)原始的lepus_slowquery.sh會去修改MySQL的全局配置參數,個人認為不需要修改,這兩個配置還是應該按照MySQL服務器的my.cnf文件中配置的為準,不應該因為部署了一個lepus監控系統就隨意的修改這個參數。因此直接注釋掉了最后面的幾行代碼。

long_query_timeslow_query_log_file

修改后的完整的lepus_slowquery.sh文件如下:

[x@coe2coe mysql]$ cat lepus_slowquery.sh#!/bin/bash#****************************************************************## ScriptName: /usr/local/sbin/lepus_slowquery.sh# Create Date: 2014-03-25 10:01# Modify Date: 2014-03-25 10:01#***************************************************************#port=$1id=$2if [ "$port" == "" ] || [ $port -lt 1 ] then echo -e "invalid argument port" exit 1fiecho -e "mysql port is :{$port} "#config lepus database serverlepus_db_host="11.1.1.11"lepus_db_port=3306lepus_db_user="lepus_monitor"lepus_db_password="XXXXXXXXXX"lepus_db_database="lepus"#config mysql servermysql_client="/usr/bin/mysql"mysql_host="11.1.1.11"mysql_port=$portmysql_user="lepus_monitor"mysql_password="XXXXXXXXXX"id=$( $mysql_client -h$lepus_db_host -P$lepus_db_port -u$lepus_db_user -p$lepus_db_password -e "select id,host,port from $lepus_db_database.db_servers_mysql where host='$mysql_host' and port=$mysql_port/G" 2>/dev/null |grep "id:" |awk -F": " '{print $2}')if [ "$id" == "" ] || [ $id -lt 1 ]then echo -e "invalid argument id" exit 2fiecho -e "mysql lepus id is :{$id}"#config slowquryslowquery_dir="/tmp/"slowquery_long_time=1slowquery_file=`$mysql_client -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -e "show variables like 'slow_query_log_file'" 2>/dev/null |grep log|awk '{print $2}'`pt_query_digest="/usr/bin/pt-query-digest"#config server_idlepus_server_id=$id#collect mysql slowquery log into lepus database$pt_query_digest --user=$lepus_db_user --password=$lepus_db_password --port=$lepus_db_port --review h=$lepus_db_host,D=$lepus_db_database,t=mysql_slow_query_review --history h=$lepus_db_host,D=$lepus_db_database,t=mysql_slow_query_review_history --no-report --limit=100% --filter=" /$event->{add_column} = length(/$event->{arg}) and /$event->{serverid}=$lepus_server_id " $slowquery_file > /tmp/lepus_slowquery.log##### set a new slow query log ############tmp_log=`$mysql_client -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -e "select concat('$slowquery_dir','slowquery_', '$port','_', date_format(now(),'%Y%m%d%H'),'.log');" 2>/dev/null |grep log|sed -n -e '2p'`#config mysql slowquery#$mysql_client -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -e "set global slow_query_log=1;set global long_query_time=$slowquery_long_time;" 2>/dev/null#$mysql_client -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -e "set global slow_query_log_file = '$tmp_log'; "#delete log before 7 days#cd $slowquery_dir#/usr/bin/find ./ -name 'slowquery_*' -mtime +7|xargs rm -rf ;####END####

6. 問題6:web慢查詢查詢不到lepus中的數據

在mysql_slow_query_review表中記錄了慢查詢,但是在lepus web界面上沒有數據。

執行:select sleep(14)有時候無法在web界面查詢到。

原因:有時候pt-query-digest產生的結果中db_max為NULL,導致查詢不出來。

這個字段安裝的原始數據庫是NOT NULL,但是在NOT NULL的情況下pt-query-digest有時會插入NULL數據,導致報錯。所以修改為了NULL。

修改為NULL后,web界面中查詢時使用的PHP程序的SQL語句有問題,沒有考慮NULL的情況,導致查詢不出來這部分數據。

解決辦法:

臨時打開general_log這個全局參數,再做web查詢慢日志,就可以很快找到這個SQL語句,再根據這個SQL語句就可以找到有問題的PHP代碼。

將 application/controllers/lp_mysql.php中的以下語句注釋掉即可。

修改前:

$this->db->where( "b.db_max !=", 'information_schema'");

修改后:

//$this->db->where( "b.db_max !=", 'information_schema'");

7. 問題7:主機監控中的三項都沒有數據。

原因:監控主機以及被監控主機上沒有安裝snmpd,snmptrapd。

解決辦法:

在所有主機上安裝snmpd和snmptrapd。

軟件包:

x@coe2coe snmp]$ ls net-snmp*net-snmp-5.7.2-32.el7.x86_64.rpmnet-snmp-agent-libs-5.7.2-32.el7.x86_64.rpmnet-snmp-devel-5.7.2-32.el7.x86_64.rpmnet-snmp-libs-5.7.2-32.el7.x86_64.rpmnet-snmp-perl-5.7.2-32.el7.x86_64.rpmnet-snmp-python-5.7.2-32.el7.x86_64.rpmnet-snmp-sysvinit-5.7.2-32.el7.x86_64.rpmnet-snmp-utils-5.7.2-32.el7.x86_64.rpm

CentOS7-everything-xxx.iso上有這些軟件包。

安裝完畢后啟動snmpd和snmptrapd服務。

總結

以上所述是小編給大家介紹的MySQL數據庫監控軟件lepus使用問題以及解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩激情av在线免费观看| 国产精品久久久久久久久久久久久| 久久影院在线观看| 7777精品久久久久久| 欧美日韩免费观看中文| 亚洲精品国产精品国产自| 亚洲欧美精品伊人久久| 国产97在线视频| 国产欧美日韩精品在线观看| 米奇精品一区二区三区在线观看| 欧美成人h版在线观看| 国产精品视频精品视频| 国语自产精品视频在线看抢先版图片| 插插插亚洲综合网| 国产91免费看片| 欧美另类在线观看| 国产精品久久久久久久久久久新郎| 色吧影院999| 久99九色视频在线观看| 日韩国产精品亚洲а∨天堂免| 久久香蕉频线观| 国产精品视频永久免费播放| 亚洲欧美日韩一区二区在线| wwwwwwww亚洲| 久热爱精品视频线路一| 欧美视频中文在线看| 欧美成人剧情片在线观看| 欧美美女操人视频| 国产精品专区h在线观看| 亚洲精品美女在线观看播放| 理论片在线不卡免费观看| 久久国产精品久久精品| 亚洲国产精品悠悠久久琪琪| 日韩中文第一页| 国产精品国模在线| 国产精品69久久久久| 欧美亚洲视频一区二区| 国产美女精品视频免费观看| 777午夜精品福利在线观看| www国产精品com| 色综合久久悠悠| 欧美日韩免费在线| www.欧美三级电影.com| 91精品国产电影| 91国内在线视频| 欧美激情乱人伦| 欧美极度另类性三渗透| 1769国内精品视频在线播放| 欧美在线视频免费| 精品无人区太爽高潮在线播放| 欧美做受高潮电影o| 亚洲欧美制服综合另类| 欧美在线一区二区视频| 欧美成人亚洲成人| 亚洲尤物视频网| 欧美成人在线免费| 亚洲变态欧美另类捆绑| 国产精品美女网站| 国产精品美女久久| 久久中文字幕在线视频| 欧美精品在线观看| 亚洲精品视频在线播放| 日韩视频在线免费观看| 日韩国产精品一区| 亚洲影视中文字幕| 日本成人免费在线| 538国产精品一区二区在线| 色播久久人人爽人人爽人人片视av| 久久99青青精品免费观看| 国产精品自产拍在线观看中文| 韩国美女主播一区| 国产精品久久久久久久天堂| 国产欧美精品xxxx另类| 久久久久国产精品一区| 亚洲精品小视频| 伊人久久久久久久久久久| 亚洲aa在线观看| 国精产品一区一区三区有限在线| 亚洲精品小视频在线观看| 亚洲国产精品字幕| 国产一区二区三区在线观看网站| 欧美色另类天堂2015| 亚洲直播在线一区| 日韩专区在线观看| 精品久久久久久国产91| 亚洲bt欧美bt日本bt| 国内精品一区二区三区| 91中文字幕一区| 亚洲美女精品久久| 神马久久久久久| 亚洲欧洲国产一区| 国产91色在线|| 91精品国产91久久久久久吃药| 日韩av综合中文字幕| 在线播放日韩欧美| 国产精品一区二区三区久久| 中文字幕国产精品| 国产精品第七十二页| 亚洲一级黄色av| 日韩中文字幕在线观看| 欧美第一页在线| 国产精品亚洲综合天堂夜夜| 成人在线小视频| 亚洲成人中文字幕| 亚洲一区二区久久久久久| 久久久国产精品x99av| 在线a欧美视频| 日韩有码在线观看| 97精品免费视频| 亚洲性视频网站| 亚洲欧洲在线看| 欧美高清第一页| 日韩中文字幕网| 国产精品盗摄久久久| 97**国产露脸精品国产| 高清一区二区三区日本久| 亚洲精品www久久久| 久久99视频精品| 91探花福利精品国产自产在线| 亚洲欧美在线免费观看| 国产在线拍偷自揄拍精品| 国产成人激情小视频| 日韩欧美精品在线观看| 91精品国产综合久久香蕉| 久久精品国产成人| 91高潮在线观看| 韩剧1988在线观看免费完整版| 久久最新资源网| 国产精品99久久久久久人| 久久国产精品久久久久久久久久| 色综合久久悠悠| 欧美日韩亚洲视频一区| 国产精品视频午夜| 国产精品91视频| 国产一区二区丝袜高跟鞋图片| 亚洲精选在线观看| 亚洲欧美三级伦理| 欧美理论片在线观看| 久久视频在线观看免费| 91精品国产高清自在线| 国产精品美女主播在线观看纯欲| 国产亚洲精品久久久久动| 亚洲国产欧美一区| 久久久久久国产| 欧美极品欧美精品欧美视频| 亚洲图片欧美午夜| 成人午夜在线观看| 成人两性免费视频| 久久久久久久久久久久久久久久久久av| 日韩在线中文字幕| 亚洲人成绝费网站色www| 日韩精品在线观看视频| 亚洲缚视频在线观看| 日产精品99久久久久久| 欧美放荡办公室videos4k| 国产精品免费福利| 色中色综合影院手机版在线观看| 中文字幕成人精品久久不卡| 欧美劲爆第一页| 亚洲永久在线观看| 成人97在线观看视频| 2019av中文字幕| 亚洲一级黄色av| 中文字幕一区日韩电影|