婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > MySQL使用的常見問題解決與應(yīng)用技巧匯總

MySQL使用的常見問題解決與應(yīng)用技巧匯總

熱門標(biāo)簽:銀川電銷外呼系統(tǒng)定制 甘孜電話機(jī)器人廠家 哈爾濱crm外呼系統(tǒng)價(jià)格 中科嘉智人工智能電銷機(jī)器人 上海智能外呼系統(tǒng)需要多少錢 電銷機(jī)器人好品牌門薩維l 凱立德科技館地圖標(biāo)注 做地圖標(biāo)注都需要什么工具 西安400電話在哪里辦理

前言

在MySQL日常開發(fā)或者是維護(hù)中,有一些問題或是故障往往是難以避免的,如丟失密碼、表損壞。在此總結(jié)一下常見的問題,以備今后所需。

一、 忘記 MySQL 的 root 密碼

1. 登錄到數(shù)據(jù)庫所在的服務(wù)器,手工 kill 掉 mysql 進(jìn)程。

(1) 登錄到數(shù)據(jù)庫所在的服務(wù)器,手工 kill 掉 MySQL 進(jìn)程:

root@bogon:/data/mysql# kill `cat ./mysql.pid`

其中,mysql.pid 指的是 MySQL 數(shù)據(jù)目錄下的 pid 文件,它記錄了 MySQL 服務(wù)的進(jìn)程號(hào)。

(2) 使用 --skip-grant-tables 選項(xiàng)重啟 MySQL 服務(wù):

zj@bogon:/data/mysql$ sudo /usr/local/mysql/bin/mysqld --skip-grant-tables --user=root 

--skip-grant-tables 選項(xiàng)意思是啟動(dòng) MySQL 服務(wù)時(shí)跳過權(quán)限表認(rèn)證。啟動(dòng)后,連接到 MySQL 的 root 將不需要口令。

(3) 用空密碼的 root 用戶連接到 mysql ,并且更改 root 口令:

zj@bogon:/usr/local/mysql/bin$ mysql -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.18-log Source distribution

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MySQL [(none)]> set password = password('123456');
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
MySQL [(none)]> use mysql
Database changed
MySQL [mysql]> update user set authentication_string=password('123456') where user="root" and host="localhost";
Query OK, 1 row affected, 1 warning (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 1

MySQL [mysql]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

MySQL [mysql]> exit;
Bye

****************************************************************

zj@bogon:/usr/local/mysql/bin$ mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 7
Server version: 5.7.18-log Source distribution

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MySQL [(none)]> 

由于使用了 --skip-grant-tables 選項(xiàng)啟動(dòng),使用 “set password” 命令更改密碼失敗,直接更新 user 表的 authentication_string(測(cè)試版本為5.7.18,有的版本密碼字段是 ‘password') 字段后,更改密碼成功。刷新權(quán)限表,使權(quán)限認(rèn)證重新生效。重新用 root 登錄時(shí),就可以使用剛剛修改后的口令了。

二、如何處理 myisam 存儲(chǔ)引擎的表損壞

有的時(shí)候可能會(huì)遇到 myisam 表損壞的情況。一張損壞的表的癥狀通常是查詢意外中斷,并且能看到下述錯(cuò)誤:

  • 'table_name.frm' 被鎖定不能更改
  • 不能找到文件 'tbl_name.MYYI' (errcode:nnn)
  • 文件意外結(jié)束
  • 記錄文件被毀壞
  • 從表處理器得到錯(cuò)誤 nnn。

通常有以下兩種解決方法:

1. 使用 myisamchk 工具

使用 MySQL 自帶的 myisamchk 工具進(jìn)行修復(fù):

shell> myisamchk -r tablename

其中 -r 參數(shù)的含義是 recover,上面的方法幾乎能解決所有問題,如果不行,則使用命令:

shell> mysiamchk -o tablename

其中 -o 參數(shù)的含義是 --safe-recover,可以進(jìn)行更安全的修復(fù)。

2. 使用 sql 命令

使用 MySQL 的 check table 和 repair table 命令一起進(jìn)行修復(fù),check table 用來檢查表是否有損壞;repair table 用來對(duì)壞表進(jìn)行修復(fù)。

三、 數(shù)據(jù)目錄磁盤空間不足的問題

系統(tǒng)上線后,隨著數(shù)據(jù)量的不斷增加,會(huì)發(fā)現(xiàn)數(shù)據(jù)目錄下的可用空間越來越小,從而給應(yīng)用造成了安全隱患。

1. 對(duì)于 myisam 存儲(chǔ)引擎的表

對(duì)于 myisam 存儲(chǔ)引擎的表,在建表時(shí)可以用如下選項(xiàng)分別制定數(shù)據(jù)目錄和索引目錄存儲(chǔ)到不同的磁盤空間,而默認(rèn)會(huì)同時(shí)放在數(shù)據(jù)目錄下:

data directory = 'absolute path to directory'
index directory = 'absolute path to directory'

如果表已經(jīng)創(chuàng)建,只能先停機(jī)或者將表鎖定,防止表的更改,然后將表的數(shù)據(jù)文件和索引文件 mv 到磁盤充足的分區(qū)上,然后在原文件處創(chuàng)建符號(hào)鏈接即可。

2. 對(duì)于 innodb 存儲(chǔ)引擎的表

因?yàn)閿?shù)據(jù)文件和索引文件是存放在一起的,所以無法將它們分離。當(dāng)磁盤空間出現(xiàn)不足時(shí),可以增加一個(gè)新的數(shù)據(jù)文件,這個(gè)文件放在充足空間的磁盤上。

具體實(shí)現(xiàn)方法是在參數(shù) innodb_data_file_path 中增加此文件,路徑寫為新磁盤的絕對(duì)路徑。

例如,如果 /home 下空間不足,希望在 /home1 下新增加一個(gè)可自動(dòng)擴(kuò)充數(shù)據(jù)的文件,那么參數(shù)可以這么寫:

innodb_data_file_path = /home/ibdata1:2000M;/home1/ibdata2:2000M:autoextend

參數(shù)修改后,必須重啟數(shù)據(jù)庫才可以生效。

四、DNS反向解析的問題 (5.0 以后的版本默認(rèn)跳過域名逆向解析)

在客戶端執(zhí)行 show processlist 命令,有時(shí)會(huì)出現(xiàn)很多進(jìn)程,類似于:

unauthenticated user | 192.168.10.10:55644 | null | connect | null | login | null

這些進(jìn)程會(huì)累計(jì)的越來越多,并且不會(huì)消失,應(yīng)用無法正常相應(yīng),導(dǎo)致系統(tǒng)癱瘓。

MySQL 在默認(rèn)情況下對(duì)于遠(yuǎn)程連接過來的 IP 地址會(huì)進(jìn)行域名的逆向解析,如果系統(tǒng)的 hosts 文件中沒有與之對(duì)應(yīng)的域名,MySQL 就會(huì)將此連接認(rèn)為是無效用戶,所以下進(jìn)程中出現(xiàn) unauthenticated user 并導(dǎo)致進(jìn)程阻塞。

解決的方法很簡(jiǎn)單,在啟動(dòng)時(shí)加上 --skip-name-resolve 選項(xiàng),則 MySQL 就可以跳過域名解析過程,避免上述問題。

五、mysql.sock 丟失后如何連接數(shù)據(jù)庫

在 MySQL 服務(wù)器本機(jī)上連接數(shù)據(jù)庫時(shí),經(jīng)常會(huì)出現(xiàn) mysql.sock 不存在,導(dǎo)致無法連接的問題。這是因?yàn)槿绻付?localhost 作為一個(gè)主機(jī)名,則 mysqladmin 默認(rèn)使用 Unix 套接字文件連接,而不是 tcp/ip。而這個(gè)套接字文件(一般命名為 mysql.sock)經(jīng)常會(huì)因?yàn)楦鞣N原因而被刪除。通過 --protocol=TCP|SOCKET|PIPE|MEMORY 選項(xiàng),用戶可以顯式地指定連接協(xié)議,下面演示使用了 Unix 套接字失敗后使用 tcp 協(xié)議連接成功的例子。

1. Unix 套接字連接:

zj@bogon:~$ mysql
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

2. tcp 連接

zj@bogon:~$ mysql --protocol=TCP

六、MyISAM表過大,無法訪問問題

首先我們可以通過myisamchk命令來查看MyISAM表的情況。如下圖,我查看admin表


  • datefile length代表當(dāng)前文件大小
  • keyfile length代表索引文件大小
  • max datefile length 最大文件大小
  • max keyfile length 最大索引大小

可以通過如下命令來進(jìn)行擴(kuò)展數(shù)據(jù)文件大小

alter table table_name MAX_ROWS=88888888 AVG_ROW_LE=66666

七、數(shù)據(jù)目錄磁盤空間不足的問題

針對(duì)MyISAM存儲(chǔ)引擎

可以將數(shù)據(jù)目錄和索引目錄存儲(chǔ)到不同的磁盤空間。

針對(duì)InnoDB存儲(chǔ)引擎

對(duì)于InnoDB存儲(chǔ)引擎的表,因?yàn)閿?shù)據(jù)文件和索引文件時(shí)存放在一起的。所以無法將他們分離。當(dāng)磁盤空間出現(xiàn)不足時(shí)候,可以增加一個(gè)新的數(shù)據(jù)文件,這個(gè)文件放在有充足空間的磁盤上。具體實(shí)現(xiàn)是通過InnoDB_data_file_path中增加此文件。

innodb_data_file_path=/home/mysql/data:10000M;/user/mysql/data:10000M:autoextend 

參數(shù)修改之后,需要重啟服務(wù)器,才可以生效。

八、同一臺(tái)主機(jī)上安裝多個(gè)Mysql

除了每個(gè)Mysql安裝目錄不能相同外,還需要的是port和socket不能一樣。

mysql.sock就是客戶端連接與mysql間通信用的。socket文件,只能本機(jī)使用,遠(yuǎn)程連接要通過tcp/ip了。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • mysql 5.7.20常用下載、安裝和配置方法及簡(jiǎn)單操作技巧(解壓版免安裝)
  • JavaWeb連接數(shù)據(jù)庫MySQL的操作技巧
  • 利用tcpdump對(duì)mysql進(jìn)行抓包操作技巧
  • 30個(gè)mysql千萬級(jí)大數(shù)據(jù)SQL查詢優(yōu)化技巧詳解
  • Mysql根據(jù)時(shí)間查詢?nèi)掌诘膬?yōu)化技巧
  • 提升MYSQL查詢效率的10個(gè)SQL語句優(yōu)化技巧
  • MySQL快速對(duì)比數(shù)據(jù)技巧
  • 5個(gè)保護(hù)MySQL數(shù)據(jù)倉庫的小技巧
  • 分享101個(gè)MySQL調(diào)試與優(yōu)化技巧
  • MySql Sql 優(yōu)化技巧分享
  • MySQL注入繞開過濾的技巧總結(jié)
  • MySQL數(shù)據(jù)庫常用操作技巧總結(jié)

標(biāo)簽:平頂山 濮陽 安康 那曲 浙江 四川 山南 安徽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL使用的常見問題解決與應(yīng)用技巧匯總》,本文關(guān)鍵詞  MySQL,使,用的,常見問題,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL使用的常見問題解決與應(yīng)用技巧匯總》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL使用的常見問題解決與應(yīng)用技巧匯總的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 白水县| 大荔县| 祁东县| 监利县| 麻栗坡县| 固安县| 饶阳县| 平顺县| 田林县| 桃园县| 嵩明县| 东安县| 盖州市| 花莲县| 虞城县| 页游| 修水县| 资兴市| 大田县| 沂源县| 云和县| 沛县| 洞头县| 明水县| 临邑县| 山丹县| 中西区| 十堰市| 土默特右旗| 威宁| 芜湖市| 云梦县| 顺昌县| 汉寿县| 华亭县| 湟中县| 乌兰县| 龙山县| 宁明县| 钦州市| 惠东县|