亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁(yè) > 知識(shí)庫(kù) > 淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則

淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則

熱門(mén)標(biāo)簽:常州電銷(xiāo)外呼系統(tǒng)一般多少錢(qián) 云南語(yǔ)音外呼系統(tǒng)平臺(tái) 沃克斯電梯外呼線路圖 天智外呼系統(tǒng) 400電話鄭州申請(qǐng) 地圖標(biāo)注被騙三百怎么辦 北京人工外呼系統(tǒng)價(jià)錢(qián) 房產(chǎn)智能外呼系統(tǒng)品牌 福州呼叫中心外呼系統(tǒng)哪家好

--連接數(shù)據(jù)庫(kù)時(shí),host和user的匹配規(guī)則

官方文檔:https://dev.mysql.com/doc/refman/5.7/en/connection-access.html

--host和user的匹配規(guī)則如下:

--是host為明確的最先匹配,host帶%模糊的時(shí)候最后匹配,但host為''(空)位于%之后才匹配

--相同的host時(shí)候,比較user為明確的最先匹配,user為''(空)最后匹配

--相同的host和user時(shí),排序是不確定的

When multiple matches are possible, the server must determine which of them to use. It resolves this issue as follows: 
Whenever the server reads the user table into memory, it sorts the rows. 
When a client attempts to connect, the server looks through the rows in sorted order. 
The server uses the first row that matches the client host name and user name. 
The server uses sorting rules that order rows with the most-specific Host values first. Literal host names and IP addresses are the most specific. (The specificity of a literal IP address is not affected by whether it has a netmask, so 198.51.100.13 and 198.51.100.0/255.255.255.0 are considered equally specific.) The pattern '%' means “any host” and is least specific. The empty string '' also means “any host” but sorts after '%'. Rows with the same Host value are ordered with the most-specific User values first (a blank User value means “any user” and is least specific). For rows with equally-specific Host and User values, the order is nondeterministic.

--查看當(dāng)前的host及用戶信息匹配順序,先host順序匹配、后user順序匹配

mysql> SELECT authentication_string, host, user,account_locked FROM mysql.USER ORDER BY host desc ,user desc;
+-------------------------------------------+--------------+---------------+----------------+
| authentication_string      | host   | user   | account_locked |
+-------------------------------------------+--------------+---------------+----------------+
| *511C0A408C5065XXEC90D60YYA1AB9437281AF28 | localhost | root   | N    |
| *THISISNOTAVALIXXASSWORDYYATCANBEUSEDHERE | localhost | mysql.sys  | Y    |
| *THISISNOTAVALIXXASSWORDYYATCANBEUSEDHERE | localhost | mysql.session | Y    |
| *485CE31BA547A4XXC047659YY10DF200F361CD4E | localhost | bkpuser  | N    |
| *7B502777D8FF69XX4B56BC2YY2867F4B47321BA8 | 192.168.56.% | repl   | N    |
| *AECCE73463829AXX3968838YYF6F85E43C3F169C | %   | flyremote  | N    |
| *566AC8467DAAAEXXE247AE7YY0A770E9B97D9FB0 |    | flylocal  | N    |
+-------------------------------------------+--------------+---------------+----------------+
8 rows in set (0.00 sec)
 

--舉個(gè)特殊例子

--建立兩個(gè)特殊用戶如下,一個(gè)用戶名為''(空)、一個(gè)用戶名和host都為''(空)

mysql> create user ''@'localhost' identified by "Kong123$";
Query OK, 0 rows affected (0.00 sec) 
mysql> create user ''@'' identified by "doubleKong123$";   
Query OK, 0 rows affected (0.00 sec)

--查看當(dāng)前的host及用戶信息匹配順序,先host順序匹配、后user順序匹配

mysql> SELECT authentication_string, host, user,account_locked FROM mysql.USER ORDER BY host desc ,user desc;
+-------------------------------------------+--------------+---------------+----------------+
| authentication_string      | host   | user   | account_locked |
+-------------------------------------------+--------------+---------------+----------------+
| *511C0VVV8C5065CBEC90D6TTTT1AB9437281AF28 | localhost | root   | N    |
| *THISIVVVTAVALIDPASSWORTTTTTCANBEUSEDHERE | localhost | mysql.sys  | Y    |
| *THISIVVVTAVALIDPASSWORTTTTTCANBEUSEDHERE | localhost | mysql.session | Y    |
| *485CEVVVA547A48CC04765TTTT0DF200F361CD4E | localhost | bkpuser  | N    |
| *256D7VVV91F7363EBDADEFTTTTB74B2B318746FC | localhost |    | N    |
| *7B502VVVD8FF69164B56BCTTTT867F4B47321BA8 | 192.168.56.% | repl   | N    |
| *AECCEVVV63829A5F396883TTTT6F85E43C3F169C | %   | flyremote  | N    |
| *566ACVVV7DAAAE79E247AETTTTA770E9B97D9FB0 |    | flylocal  | N    |
| *AE162VVV68403D1D98A4C9TTTT50A508B8C56F3F |    |    | N    |
+-------------------------------------------+--------------+---------------+----------------+
9 rows in set (0.00 sec)

--這樣本地登錄flyremote用戶時(shí) 會(huì)報(bào)錯(cuò),因?yàn)榘匆陨系捻樞?優(yōu)先匹配到了host為localhost、user為''(空)的用戶,而不是flyremote用戶 (因?yàn)閡ser為''(空)的用戶可以匹配任意用戶名)

[root@hostmysql-m mysql]# mysql -uflyremote -pFlyremote123$
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'flyremote'@'localhost' (using password: YES)

--那就是說(shuō)本地登錄flyremote用戶時(shí), 用匹配到的host為localhost、user為''(空)的密碼 Kong123$ ,就可以正常登陸了

[root@hostmysql-m mysql]# mysql -uflyremote -pKong123$
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 15
Server version: 5.7.23-log MySQL Community Server (GPL) 
Copyright (c) 2000, 2018, 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.

--查看當(dāng)前用戶連接方式 和 當(dāng)前用戶認(rèn)證方式

mysql> select user(),CURRENT_USER();
+---------------------+----------------+
| user()    | CURRENT_USER() |
+---------------------+----------------+
| flyremote@localhost | @localhost  |
+---------------------+----------------+
1 row in set (0.06 sec)

--用帶入ip的方式登錄flyremote用戶時(shí) 無(wú)問(wèn)題, ip匹配到了% ,user匹配到了flyremote

[root@hostmysql-m mysql]# mysql -uflyremote -pFlyremote123$ -h127.11.22.33 
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 12
Server version: 5.7.23-log MySQL Community Server (GPL) 
Copyright (c) 2000, 2018, 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>

--查看當(dāng)前用戶連接方式 和 當(dāng)前用戶認(rèn)證方式

mysql> select user(),CURRENT_USER();
+------------------------+----------------+
| user()     | CURRENT_USER() |
+------------------------+----------------+
| flyremote@127.11.22.33 | flyremote@% |
+------------------------+----------------+
1 row in set (0.00 sec)

--任意用戶、任意host,只要密碼和建立的第二個(gè)空用戶空host的密碼"doubleKong123$"匹配了, 就可以進(jìn)入mysql

--測(cè)試一個(gè)不存在的用戶hahaha

[root@hostmysql-m ~]# mysql -uhahaha -pdoubleKong123$ -h127.11.22.33
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 6
Server version: 5.7.23-log MySQL Community Server (GPL) 
Copyright (c) 2000, 2018, 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>

--查看當(dāng)前用戶連接方式 和 當(dāng)前用戶認(rèn)證方式

mysql> select user(),CURRENT_USER();
+---------------------+----------------+
| user()    | CURRENT_USER() |
+---------------------+----------------+
| hahaha@127.11.22.33 | @    |
+---------------------+----------------+
1 row in set (0.01 sec)

--解決方案:

1、手工刪除空用戶和空host用戶確保安全

或者

2、使用 mysql_secure_installation 來(lái)進(jìn)行安全配置

--安全配置如下,其中有刪除匿名用戶的操作

This program enables you to improve the security of your MySQL installation in the following ways:
 You can set a password for root accounts.
 You can remove root accounts that are accessible from outside the local host.
 You can remove anonymous-user accounts.
 You can remove the test database (which by default can be accessed by all users, even anonymous users), and privileges that permit anyone to access databases with names that start with test_.

--刪除匿名用戶的源碼 mysql_secure_installation.cc 如下:

 //Remove anonymous users
 remove_anonymous_users(); 
/**
 Removes all the anonymous users for better security.
*/
void remove_anonymous_users()
{
 int reply;
 reply= get_response((const char *) "By default, a MySQL installation has an "
      "anonymous user,\nallowing anyone to log "
      "into MySQL without having to have\na user "
      "account created for them. This is intended "
      "only for\ntesting, and to make the "
      "installation go a bit smoother.\nYou should "
      "remove them before moving into a production\n"
      "environment.\n\nRemove anonymous users? "
      "(Press y|Y for Yes, any other key for No) : ", 'y');
 
 if (reply == (int) 'y' || reply == (int) 'Y')
 {
 const char *query;
 query= "SELECT USER, HOST FROM mysql.user WHERE USER=''";
 if (!execute_query(query, strlen(query)))
  DBUG_PRINT("info", ("query success!"));
 MYSQL_RES *result= mysql_store_result(mysql);
 if (result)
  drop_users(result);
 mysql_free_result(result);
 fprintf(stdout, "Success.\n\n");
 }
 else
 fprintf(stdout, "\n ... skipping.\n\n");
}

補(bǔ)充:mysql 用戶表中多個(gè)host時(shí)的匹配規(guī)則

mysql數(shù)據(jù)庫(kù)中user表的host字段,是用來(lái)控制用戶訪問(wèn)數(shù)據(jù)庫(kù)“權(quán)限”的。

可以使用“%”,表示所有的網(wǎng)段;

也可以使用具體的ip地址,表示只有該ip的客戶端才可以登錄到mysql服務(wù)器;

也可以使用“_”進(jìn)行模糊匹配,表示某個(gè)網(wǎng)段的客戶端可以登錄到mysql服務(wù)器。

如果在user表中存在一個(gè)用戶兩條不同host值的記錄,那么mysql服務(wù)器該如何匹配該用戶的權(quán)限呢?

mysql采用的策略是:當(dāng)服務(wù)器讀取user表時(shí),它首先以最具體的Host值排序(主機(jī)名和IP號(hào)是最具體的) 。有相同Host值的條目首先以最具體的User匹配。

舉例:

如下,有兩條root用戶,那么只有l(wèi)ocalhost的root客戶端可以登錄到mysql服務(wù)器。

| root | localhost | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
| root | %   | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Mysql連接數(shù)設(shè)置和獲取的方法
  • PHP連接MySQL數(shù)據(jù)庫(kù)三種實(shí)現(xiàn)方法
  • Navicat Premium遠(yuǎn)程連接MySQL數(shù)據(jù)庫(kù)的方法
  • 使用IDEA配置Tomcat和連接MySQL數(shù)據(jù)庫(kù)(JDBC)詳細(xì)步驟
  • 詳解DBeaver連接MySQL8以上版本以及解決可能遇到的問(wèn)題
  • 連接docker里面的mysql失敗解決方法
  • 解決navicat遠(yuǎn)程連接mysql報(bào)錯(cuò)10038的問(wèn)題
  • Php連接及讀取和寫(xiě)入mysql數(shù)據(jù)庫(kù)的常用代碼
  • 遠(yuǎn)程連接mysql 授權(quán)方法詳解
  • C#連接MySql數(shù)據(jù)庫(kù)的方法
  • MySQL的MaxIdleConns不合理,會(huì)變成短連接的原因

標(biāo)簽:沈陽(yáng) 鹽城 拉薩 移動(dòng) 珠海 黔東 沈陽(yáng) 徐州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則》,本文關(guān)鍵詞  淺談,Mysql,連接,數(shù)據(jù)庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于淺談Mysql連接數(shù)據(jù)庫(kù)時(shí)host和user的匹配規(guī)則的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    久久久久久久久综合影视网| 成人a大片在线观看| 九九久久99综合一区二区| 精品国产一级毛片| 尤物视频网站在线| 九九精品影院| 精品视频在线观看免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产成a人片在线观看视频| 亚欧视频在线| 国产视频在线免费观看| 九九九国产| 国产美女在线观看| 国产高清在线精品一区二区| 国产成a人片在线观看视频| 欧美激情伊人| a级毛片免费观看网站| 欧美激情在线精品video| 久草免费资源| 99久久网站| 精品国产一区二区三区久久久狼| 日本在线不卡视频| 国产高清在线精品一区a| 日韩av成人| 国产精品1024永久免费视频| 九九干| 日韩中文字幕一区| 精品视频免费在线| 欧美另类videosbestsex高清| 国产不卡在线观看| 麻豆污视频| 高清一级片| 黄色福利| 黄视频网站免费| 国产精品1024在线永久免费| 九九久久国产精品大片| 中文字幕一区二区三区 精品| 欧美激情一区二区三区在线播放 | 国产麻豆精品视频| 国产91素人搭讪系列天堂| 日韩中文字幕在线播放| 中文字幕一区二区三区精彩视频| 四虎影视久久久| 午夜在线影院| 亚洲精品中文一区不卡| 可以在线看黄的网站| 久久成人综合网| 人人干人人插| 九九久久99| 亚欧成人乱码一区二区| 午夜在线观看视频免费 成人| 久草免费在线观看| 久久精品道一区二区三区| 天天做人人爱夜夜爽2020毛片| 国产麻豆精品视频| 国产一区二区精品| 二级片在线观看| 欧美爱爱网| 韩国三级香港三级日本三级la | 国产成+人+综合+亚洲不卡| 欧美激情一区二区三区在线播放 | 久久国产精品自由自在| 精品国产香蕉伊思人在线又爽又黄| 青青久久精品| 青青久久国产成人免费网站| a级黄色毛片免费播放视频| 99热视热频这里只有精品| 亚洲女初尝黑人巨高清在线观看| 亚洲第一色在线| 日本伦理网站| 人人干人人插| 九九久久国产精品大片| 欧美日本免费| 国产麻豆精品免费视频| 国产精品1024永久免费视频| 四虎久久精品国产| 九九精品在线| 黄视频网站免费| 欧美大片aaaa一级毛片| 日本在线不卡视频| 一本高清在线| 国产精品自拍在线| 国产精品1024永久免费视频| 欧美激情一区二区三区在线播放 | 日韩av成人| 欧美激情伊人| 精品国产亚洲人成在线| 国产精品123| 一级女性大黄生活片免费| 日韩一级黄色| 日本在线不卡视频| 欧美另类videosbestsex久久 | 国产不卡精品一区二区三区| 国产不卡精品一区二区三区| 91麻豆高清国产在线播放| 欧美大片aaaa一级毛片| 高清一级做a爱过程不卡视频| 久久国产影院| 日本伦理网站| 亚洲精品永久一区| 99色视频在线观看| 国产麻豆精品| a级毛片免费观看网站| 欧美激情一区二区三区视频 | 亚洲精品久久久中文字| 韩国三级一区| 青青久久网| 欧美激情影院| 免费国产在线视频| 国产欧美精品午夜在线播放| 国产精品123| 国产视频久久久| 精品国产三级a∨在线观看| 精品视频在线看 | 欧美a级片免费看| 欧美国产日韩久久久| 九九久久国产精品| 中文字幕97| 99色视频| 成人免费观看男女羞羞视频| 91麻豆精品国产综合久久久| 四虎久久影院| 日韩免费在线| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产伦精品一区二区三区在线观看 | 99久久网站| 久久国产一区二区| 国产成+人+综合+亚洲不卡| 精品在线免费播放| 麻豆网站在线看| 亚洲 欧美 成人日韩| 成人在免费观看视频国产| 午夜欧美成人香蕉剧场| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 91麻豆精品国产自产在线观看一区| 99色播| 天天做日日干| 日韩专区第一页| 欧美爱爱网| 日韩在线观看视频免费| 日韩中文字幕在线播放| 欧美国产日韩久久久| 国产网站免费视频| 天天做人人爱夜夜爽2020毛片| 免费毛片基地| 国产不卡在线观看视频| 国产伦精品一区二区三区无广告| 国产高清在线精品一区二区| 日韩在线观看视频黄| 国产一区二区精品久久| 一级女人毛片人一女人| 毛片的网站| 亚洲 欧美 成人日韩| 亚洲女初尝黑人巨高清在线观看| 国产网站在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 你懂的国产精品| 可以免费在线看黄的网站| 美女免费精品高清毛片在线视| 久久国产精品永久免费网站| 亚洲精品久久玖玖玖玖| 成人a级高清视频在线观看| 尤物视频网站在线| 九九九网站| 日韩字幕在线| 国产一级强片在线观看| 香蕉视频久久| 国产网站免费观看| 欧美一区二区三区性| 国产一区精品| 日本特黄特黄aaaaa大片| 尤物视频网站在线观看| 国产亚洲免费观看| 国产成a人片在线观看视频| 亚欧成人乱码一区二区| 久久99爰这里有精品国产| 99色视频在线观看| 日韩中文字幕一区| 91麻豆精品国产高清在线| 999久久狠狠免费精品| 成人高清免费| 一级片片| 一级女性大黄生活片免费| 国产一区免费在线观看| 日本伦理黄色大片在线观看网站| 精品国产三级a| 欧美激情伊人| 久久精品人人做人人爽97| 精品国产一区二区三区久久久蜜臀 | 亚洲精品久久玖玖玖玖| 精品国产一级毛片| 国产一区精品| 青青久久精品| 久久久成人网| 欧美日本国产| 韩国三级香港三级日本三级| 精品视频在线看| 国产福利免费观看| 午夜家庭影院| 国产成人女人在线视频观看|