以詳解Apache、PHP和Mysql的關係
##學習方法
弄清楚Apache、PHP和MySQL之間的關係,對於初學者理解程式的運行過程,還是很有幫助的,學習一個新事物,要明白最基本的三個問題: 是什麼、有什麼、為什麼。 是什麼指的是新事物的宏觀層面的功能描述Apache是什麼?就是一個能提供Http服務的Web伺服器。
Apache有什麼? Apache有虛擬主機功能,有不同的工作模式(MPM模式),有日誌功能,有壓縮功能,還有各種功能模組等等。
Apache為什麼?為什麼需要使用Apache?什麼場景下適合使用Apache?什麼場景又不適合使用?能否使用其它Web伺服器來取代它? Apache能呼叫PHP解譯器工作,那能否和其它的腳本解釋器一起運作?
Apache、PHP和Mysql的基本理解
Apache是一個Web伺服器: 基於Http/Https/Websocket等協定對外部提供數據、文件的獲取功能。 PHP是可程式化的腳本語言: 提供基本的運算和邏輯處理的功能,可以很好的應用於Web網站功能需求的開發。
MySQL是一種關聯式資料庫: 用於儲存、修改、取得和管理資料的工具,可以透過結構化查詢語言(SQL)進行資料庫的管理。Apache與PHP之間的關係Apache與PHP解譯器之間的關係,是呼叫與被呼叫之間的關係,Apache主動呼叫PHP解釋器去執行PHP腳本文件,PHP解釋器被Apache呼叫。
Apache是web伺服器軟體,它可以接受來自客戶端的Http/Https等協定的請求,當請求的檔案是PHP腳本檔案時,它會呼叫PHP解釋器去解釋和執行該腳本中的內容,並將解釋器傳回的結果,根據對應的協定規則封裝成對應格式的數據,再將資料傳回給請求的客戶端。
PHP究竟是如何被Apache調用的,可以參考第四節的《詳解PHP的運行模式Sapi》,或者下一節的《詳解Apache的MPM及採用的PHP模式》
PHP和MySql之間的關係
PHP和Mysql之間的關係,也是呼叫和被呼叫的關係,PHP透過SQL語言呼叫Mysql進行資料庫的管理功能,Mysql資料庫總是被動的接受操作指令。
MYSQL是小型關係資料庫軟體,它為可以各種軟體提供資料庫支持,透過PHP可以操作Mysql,同理使用其它語言也可以操作Mysql,同樣PHP也可以操作其他的資料庫,不一定是MYSQL。
PHP如何呼叫Mysql資料庫進行操作?
PHP與Mysql互動使用的語言規則是SQL,但是PHP和Mysql是兩個獨立的應用程序,想要交互必須得先建立連接,就如同瀏覽器訪問Web伺服器一樣,在請求數據發送前也需要先成功建立tcp連線。PHP腳本與Mysql建立連接的過程都是由PHP的Mysqld/PDO等驅動來完成的,這些驅動的本質都是PHP的模組,即PHP解釋器可以識別的相關函數集合,一般使用C語言編寫。 對PHP語言來說,屏蔽了具體連接建立和資料庫協議操作的詳細過程,對PHP語言暴露了一些基礎的接口,即PHP可以調用到的一些資料庫操作函數,如連接資料庫、執行資料庫SQL指令、斷開連線等。
總而言之,PHP呼叫Mysql資料庫的過程,通常是透過PHP的資料庫驅動模組來操作的,它的本質也是一個網路資料的請求操作(遵循MySql通訊協定來建立連接,使用SQL語法來執行具體操作指令)。以上是十年程式設計師告訴你Apache、PHP和Mysql的關係的詳細內容。更多資訊請關注PHP中文網其他相關文章!