一、Mysql突然間所有數(shù)據(jù)庫的表都消失了的原因
首先我們需要打開MySQL 命令行客戶端,如圖所示,點擊【MySQL 8.0 command line client】;然后輸入自己安裝MySQL時設(shè)置的密碼,登錄客戶端;接下來,我們先查看一下加密的方式,輸入:show variables like ‘default_authentication_plugin’。
接下來,查看本地mysql用戶的信息,
輸入:select host,user,plugin from mysql.user;
回車,可以看到root賬戶的加密方式是caching_sha2_password;
但是Navicat不支持MySQL新版本的這種用戶登錄賬戶加密方式,所以下面我們要修改root賬戶的加密方式為【mysql_native_password】,如圖所示,輸入:ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘root’;
回車,即可修改成功,注意這里最后的root是你設(shè)置的root賬戶的密碼,我設(shè)置的是“root”。
最后,我們再重新打開Navicat連接MySQL,就可以成功用root賬戶連接了。
總計:
1、打開MySQL 命令行客戶端;
2、輸入自己安裝MySQL時設(shè)置的密碼,登錄客戶端;
3、查看一下加密的方式;
4、查看本地mysql用戶的信息;
5、修改root賬戶的加密方式為【mysql_native_password】;
6、重新打開Navicat連接MySQL即可。
延伸閱讀:
二、為什么要持久化連接
這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過三種方法來利用 PHP 生成 web 頁面。
名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個單獨運(yùn)行的語言解釋器(CGI Wapper)。當(dāng)以這種方法運(yùn)行時,PHP 會為向 web 服務(wù)器的每個 PHP 頁面請求創(chuàng)建并銷毀 PHP 解釋器的時候?qū)嵗S捎谄鋾S每個請求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫服務(wù)器的鏈接)都會在銷毀時關(guān)閉。在這種情況下,不會從使用持久連接中獲得任何好處——因為根本不會持久。
第二,也是最流行的方法是把 PHP 用作多進(jìn)程 web 服務(wù)器的一個模塊,這種方法目前只適用于 Apache。多進(jìn)程的服務(wù)器通常有一個父進(jìn)程和一組子進(jìn)程協(xié)調(diào)運(yùn)行,子進(jìn)程負(fù)責(zé)提供網(wǎng)頁的工作。每當(dāng)接收達(dá)到客戶端提出請求時,該請求會傳遞給尚未給其它客戶端提供服務(wù)的某個子進(jìn)程。這也就是說當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請求時,它將有可能由與名列前茅次不同的某個子進(jìn)程提供服務(wù)。在開啟了一個持久連接后,所有請求 SQL 服務(wù)的后繼頁面都能夠重用與 SQL 服務(wù)器建立的相同連接。
最后一種方法是將 PHP 用作多線程 web 服務(wù)器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務(wù)器的插件使用。該行為與前面描述的多過程模型相同。