mysql連接可分為socket連接和TCP|IP連接兩種。
建網(wǎng)站原本是網(wǎng)站策劃師、網(wǎng)絡(luò)程序員、網(wǎng)頁設(shè)計師等,應(yīng)用各種網(wǎng)絡(luò)程序開發(fā)技術(shù)和網(wǎng)頁設(shè)計技術(shù)配合操作的協(xié)同工作。成都創(chuàng)新互聯(lián)公司專業(yè)提供做網(wǎng)站、成都網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站制作(企業(yè)站、響應(yīng)式網(wǎng)站開發(fā)、電商門戶網(wǎng)站)等服務(wù),從網(wǎng)站深度策劃、搜索引擎友好度優(yōu)化到用戶體驗的提升,我們力求做到極致!
[root@localhost bin]# mysql -uroot -p123456 -S/tmp/mysql.sock
-S/tmp/mysql.sock可以省略,因為默認(rèn)參數(shù)如下:
假如sock文件另有其它,那么就后面不能省略,需要指定下。
mysql -h127.0.0.1 -P3306 -uroot -p123456
那么問題來了,如何知道當(dāng)前連接的連接方式?
查看當(dāng)前連接方式,使用\s 或者status命令
Connection: Localhost via UNIX socket 表示使用 socket 進(jìn)行本地的連接
SSL: Not in use 沒有使用SSL
Connection: 127.0.0.1 via TCP/IP 使用TCP/IP 協(xié)議進(jìn)行遠(yuǎn)程連接
SSL: Cipher in use is ECDHE-RSA-AES128-GCM-SHA256 使用了SSL加密
mysql5.7默認(rèn)是使用SSL的方式來進(jìn)行通訊的。
/s輸出SSL: Not in use,說明當(dāng)前沒有使用SSL連接。
再看下error.log有一個waning:failed to set up SSL because of the following SSL liberary error:SSL context is not usable withut certificate and private key。公密鑰文件不存在,所以無法啟用SSL的連接方式。
1、進(jìn)入bin目錄執(zhí)行命令: mysql_ssl_rsa_setup 在/data 根目錄 生成相關(guān)的*.pem 密鑰文件。
2、對新生成到pem文件授權(quán)chown mysql:mysql *.pem
3、 /etc/init.d/mysqld restart 重啟mysql
4、進(jìn)入命令客戶端執(zhí)行\(zhòng)s
使用IP/TCP遠(yuǎn)程連接時,\s輸出 SSL: Cipher in use is ECDHE-RSA-AES128-GCM-SHA256。說明已經(jīng)用上SSL加密。
使用socket進(jìn)行本地連接,就不會使用SSL加密。\s輸出SSL: Not in use;
因為SSL開啟可能有性能影響。如果不希望使用ssl加密登錄連接,那么可以使用下面命令進(jìn)行禁用:mysql -h127.0.0.1 -uroot -p123456 --ssl-mode=DISABLED
強(qiáng)制一個用戶使用ssl
之后david用戶就必須使用ssl登錄了,否則報錯如下:
取消一個用戶強(qiáng)制使用ssl
x509認(rèn)證在開啟SSL的基礎(chǔ)下,還強(qiáng)制指定用戶必須使用client-cert.pem和client-key.pem證書、密鑰文件來登錄,否則登錄不了。x509是mysql最高等級的認(rèn)證機(jī)制。
之前已經(jīng)在data根目錄生成了8個 *.pem文件
把其中client-cert.pem和client-key.pem導(dǎo)出
如下,再使用之前的命令登錄。發(fā)現(xiàn)登錄不了了。
此時想要登錄必須在客戶端指定SSL CERT File和SSL Key File 如下在navicat中
在mysql workbench中
第一步 打開Database
打開myeclipse然后點擊window窗口 點擊Open Perspective菜單中的MyEclipse Database Explorer 進(jìn)入
第二步 創(chuàng)建連接
在空白處右擊鼠標(biāo)新建(即new)或者點擊菜單欄中的快捷鍵(圖二中向下的三角符號)新建。彈出Database Driver 菜單見
第三步 選擇連接方式
在Driver template選項框中 選擇MySql Connector/j
第四步 填寫配置信息
在Driver name填寫鏈接數(shù)據(jù)庫的名稱(這個可由自己喜好填寫,建議最好和所做項目名稱相關(guān)便于使用時查找)
Connection URL用于填寫連接要使用mysql數(shù)據(jù)庫的地址(jdbc:mysql://hostname[:3306]/dbname)可改為(jdbc:mysql://localhost:3306/test),其中l(wèi)ocalhost表示的是連接本地數(shù)據(jù)庫的意思,3306是表示連接mysql數(shù)據(jù)庫的端口號(不同的數(shù)據(jù)庫端口號也不相同),
User name 填寫數(shù)據(jù)庫用戶名mysql默認(rèn)的是root
Password填寫訪問mysql數(shù)據(jù)庫時的你所設(shè)置的訪問密碼。
第五步 添加驅(qū)動
點擊Add JARs添加myeclipse連接mysql數(shù)據(jù)庫的驅(qū)動文件(存放驅(qū)動的文件最好是英文目錄,在測試時確定mysql數(shù)據(jù)庫已經(jīng)打開,否則測試不會成功),在這里添加的是mysql-connector-java-5.1.7-bin版本(可以在網(wǎng)上搜索下載、)
第六步 測試數(shù)據(jù)配置是否正確
點擊Test Driver測試是否配置成功,輸入訪問數(shù)據(jù)庫密碼。
第七步 測試成功
測試連接mysql數(shù)據(jù)庫成功,點擊Finish完成創(chuàng)建連接。
第八歩 連接數(shù)據(jù)庫
右擊你創(chuàng)建的連接點擊Open another connection 輸入mysql數(shù)據(jù)庫密碼就能看到所創(chuàng)建的數(shù)據(jù)庫表。
使用“Ctrl + R”組合鍵快速打開cmd窗口,并輸入“cmd”命令,打開cmd窗口。
使用“mysql -uroot -proot”命令可以連接到本地的mysql服務(wù)。
使用“use mysql”命令,選擇要使用的數(shù)據(jù)庫,修改遠(yuǎn)程連接的基本信息,保存在mysql數(shù)據(jù)庫中,因此使用mysql數(shù)據(jù)庫。
使用“GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;”命令可以更改遠(yuǎn)程連接的設(shè)置。
使用“flush privileges;”命令刷新剛才修改的權(quán)限,使其生效。
使用“select host,user from user;”查看修改是否成功。
本文介紹 MySQL 8.0 shell 子模塊 Util 的兩個導(dǎo)入特性 importTable/import_table(JS和python 版本的命名差異)、importJson/import_json的使用方法。
其中 import_table 是通過傳統(tǒng) MySQL 協(xié)議來通信,Import_json 是通過 X 插件協(xié)議來通信。MySQL 一直以來提供導(dǎo)入文件 SQL 命令 load data infile(單線程)以及對應(yīng)的可執(zhí)行文件 mysqlimport(多線程)。
比如我導(dǎo)入 100W 行示例數(shù)據(jù)到表 ytt.tl1,花了 24 秒。這個已經(jīng)是 MySQL 默認(rèn)導(dǎo)入來的最快的。分析那我們現(xiàn)在看下 mysqlimport 工具的升級版,mysqlshell 的 util 工具集。
使用這兩個工具之前,必須得臨時開啟 local_infile 選項。1. import_table建立 3306 端口的新連接我這里切換為 python 模式清空掉示例表 Ytt.tl1import_table 有兩個參數(shù),第一個參數(shù)定義導(dǎo)入文件的路徑,第二個定義相關(guān)選項,比如導(dǎo)入的格式,并發(fā)的數(shù)量等。定義文件路徑(參數(shù)1)定義選項(參數(shù)2)執(zhí)行導(dǎo)入:只花了不到 17 秒,比傳統(tǒng) mysqlimport 快了不少。
我們上面指定了顯式指定了字段分隔符,那有沒有已經(jīng)定義好的組合格式呢? 答案是有的,選項 dialect 可以指定以下格式:csv,tsv,json,csv-unix那么上面的導(dǎo)入,我們可以更簡單,改下變量 y_options1 的定義導(dǎo)入時間差不多。這里要說明下,dialect 選項的優(yōu)先級比較低,比如添加了'linesTerminatedBy':'\r\n', 則覆蓋他自己的'\n'。
選項 diaelect 還有一個可選值為 json,可以直接把 json 結(jié)果導(dǎo)入到文檔表里。比如我新建一張表 tl1_json重新定義文件以及導(dǎo)入選項。導(dǎo)入 JSON 數(shù)據(jù)速度也還可以,不到 24 秒。那導(dǎo)入 json 數(shù)據(jù),就必須得提到以 X 插件協(xié)議通信的工具 import_json了。2. imort_json我們切換到 mysqlx 端口import_json 參數(shù)和 Import_table 參數(shù)類似,這里我改下選項我在手冊上沒有看到多線程的選項,所以單線程跑 35 秒慢了些。查看剛剛導(dǎo)入的數(shù)據(jù)import_json 不僅僅可以導(dǎo)入 Json 數(shù)據(jù),更重要的是可以在 BSON 和 JSON 之間平滑的轉(zhuǎn)換,有興趣的同學(xué)可以去 TRY 下。
在python官網(wǎng)中去下載ez_setup.py文件。
此工具是python管理包工具,通過它可以下載很多服務(wù)。
請根據(jù)系統(tǒng)下載相關(guān)文件。
在python中執(zhí)行python ez_setup.py文件,如果沒有配置環(huán)境變量,可以在python安裝路徑中找到python.exe,在此目錄中執(zhí)行上面命令。
命令執(zhí)行成功后,會在python安裝目錄下easy_install.exe工具包。
在CMD命令行執(zhí)行:easy_install.exe pymysql3
如果找不到該命令,切換服務(wù)到python安裝目錄/Scripts/下執(zhí)行。如果此目錄下沒有easy_install.exe,證明上一步?jīng)]有安裝成功。
安裝pymysql3服務(wù)如下。
pymysql3服務(wù)安裝成功后,開始寫python程序連接mysql服務(wù)。
mysql數(shù)據(jù)庫安裝在此省略,到mysql官方網(wǎng)站下載,下一步安裝就可以了。
python程序內(nèi)容如下:import pymysql
conn = pymysql.connect(user='root', passwd='root',
host='localhost', db='zjctest')
cur = conn.cursor()
cur.execute("SELECT * FROM zjc")
for r in cur:
print("row_number:" , (cur.rownumber) )
print("id:"+str(r[0])+"name:"+str(r[1])+"age:"+str(r[2]))
cur.close()
conn.close()
執(zhí)行結(jié)果如下,證明連接mysql數(shù)據(jù)庫成功,且數(shù)據(jù)正確返回。
一、mysqld 進(jìn)程沒有正常運行遇到這種情況首先到服務(wù)器上看看 mysqld 進(jìn)程是否活著,采用的命令:
二、客戶端不能和進(jìn)程 mysqld 通信如果 MySQL 服務(wù)器上的 mysqld 進(jìn)程運行正常,我們再看看客戶端能不能和 mysqld 進(jìn)行通信,使用下面的命令進(jìn)行網(wǎng)絡(luò)連通的測試:telnet localhost 3306
如果本地能通,再到客戶端的機(jī)器上把 localhost 換成 MySQL 服務(wù)器的 ip 地址進(jìn)行測試。如果不能通,通常有兩種原因,一種原因是 OS 或網(wǎng)絡(luò)的問題,或者是防火墻;另一種原因是 mysqld 自身根本沒有偵聽客戶端的連接請求, mysqld 啟動后對于客戶端的偵聽是分三種情況。
第一種情況
是使用參數(shù) --skip-networking 跳過偵聽客戶端的網(wǎng)絡(luò)連接,用下面的命令我們可以看到 MySQL 根本沒有偵聽 3306 端口。
第二種情況
使用參數(shù) --bind-address 后面增加對客戶端訪問 IP 地址的限制,例如只偵聽本地的連接
三、賬戶密碼的問題最后一種情況是賬戶密碼的問題,應(yīng)付這種情況我們有個有力的工具就是查看 MySQL 的 error log, error log 記載信息的詳細(xì)程度上由參數(shù) --log-error-verbosity 進(jìn)行控制的