首先介紹下在本文出現的幾個比較重要的概念:
函數計算(Function Compute): 函數計算是一個事件驅動的服務,通過函數計算,用戶無需管理服務器等運行情況,只需編寫代碼并上傳。函數計算準備計算資源,并以彈性伸縮的方式運行用戶代碼,而用戶只需根據實際代碼運行所消耗的資源進行付費。函數計算更多信息 參考。Fun: Fun 是一個用于支持 Serverless 應用部署的工具,能幫助您便捷地管理函數計算、API 網關、日志服務等資源。它通過一個資源配置文件(template.yml),協助您進行開發、構建、部署操作。Fun 的更多文檔 參考。
備注: 本文介紹的技巧需要 Fun 版本大于等于 3.6.3。
Thinkphp%20是什么?
ThinkPHP%20是一個免費開源的,快速、簡單的面向對象的輕量級%20PHP%20開發框架,是為了敏捷%20WEB%20應用開發和簡化企業應用開發而誕生的。ThinkPHP%20從誕生以來一直秉承簡潔實用的設計原則,在保持出色的性能和至簡代碼的同時,更注重易用性。遵循%20Apache2%20開源許可協議發布,意味著你可以免費使用%20ThinkPHP,甚至允許把你基于%20ThinkPHP%20開發的應用開源或商業產品發布/銷售。
效果預覽
本文涉及到的兩個應用示例部署后的鏈接,點擊預覽效果:
- ThinkPHP%20官方示例:http://13492727-1986114430573743.test.functioncompute.com
- ThinkPHP%20博客示例:http://13500180-1986114430573743.test.functioncompute.com
- ThinkPHP%20博客示例管理后臺:http://13500180-1986114430573743.test.functioncompute.com/admin
環境準備
首先按照%20Fun%20的安裝文檔里介紹的方法將%20Fun%20安裝到本機。
PS:%20本文介紹的方法,不需要安裝%20Docker,僅僅安裝%20Fun%20即可,最簡單的方式就是直接下載可執行的二進制文件。
安裝完成后,可以執行%20fun%20--version%20檢查%20Fun%20是否安裝成功。
第一個示例:快速初始化并部署一個%20ThinkPHP%20示例應用
初始化一個%20thinkphp%20示例:
composer%20create-project%20topthink/think%20tp
將該示例在本地運行測試:
php%20think%20run
可以在本地看到效果:
傳統的開發方式是,本地開發完成后,就要進行部署工作了,通常我們部署一個 PHP 應用可能需要如下幾步:
- 購買一臺物理機器,比如 ECS
- 在物理機器上綁定公網 ip、安裝 php、Nginx、php-fpm
- 配置 nginx、php-fpm 以及上傳應用到該機器上
- 運行測試
其中最復雜的就要數第 2、3 步了,因為可能不同的環境的配置方法還不一樣,會有比較多的坑。我們演示下如何將應用部署到函數計算上。
fun deploy
僅需要一個命令,Fun 會自動進入部署流程,在該流程中,用戶僅僅需要按下一系列的回車即可。流程細節如下:
- Fun 檢測到這不是一個 Fun 項目,會提示協助創建(直接回車或者輸入 y 即可)
- Fun 項目自動創建成功,提示是否進行部署?可以直接回車,或者輸入 y 進行確認
- 然后 Fun 會直接將應用部署到線上了
部署完成后,我們可以根據部署成功的日志看到,函數計算為我們生成了臨時域名 13492727-1986114430573743.test.functioncompute.com,我們可以通過這個臨時域名直接訪問我們剛剛部署的應用。
備注:臨時域名僅僅用作演示以及開發,是有時效的,如果用作生產,請綁定已經備案的域名。
第二個示例:快速遷移一個已有的 ThinkPHP 應用
這里我們拿一個開源的 ThinkPHP 博客做示例:https://github.com/wolf-leo/Wolf-Blog
首先我們需要將 blog 克隆下來:
git clone https://github.com/wolf-leo/Wolf-Blog.git
使用 composer 安裝依賴:
composer install
在要使用的 MySQL 數據庫上新建一個名為 blog_test 的 database。然后編輯 config/database.php 文件,修改其中的數據庫地址、用戶名、密碼信息。
// ... ...
return [
// ... ...
// 服務器地址
'hostname' => '192.168.17.104',
// 數據庫名 測試數據庫名稱 不用修改 否則默認安裝會出錯
'database' => 'blog_test',
// 用戶名 需要修改的地方
'username' => 'root',
// 密碼 需要修改的地方
'password' => 'root',
// ... ...
];
修改完成后,就可以本地啟動查看效果了:
$ php think run
ThinkPHP Development server is started On <http://127.0.0.1:8000/>
You can exit with `CTRL-C`
Document root is: /examples/php/Wolf-Blog/public
然后打開 http://localhost:8000 可以直接看到效果。
本地測試沒問題后,就要進行部署了。部署前,我們需要知道,由于函數計算運行時代碼目錄本身是不可以修改的,而 ThinkPHP 會在代碼目錄下的 Runtime 這個目錄寫一些緩存文件,我們需要將這個緩存文件放到 /tmp 下面。在我們的例子中就是將 thinkphp/library/think/App.php 這個文件的第 174 行做如下修改:
- $this->runtimePath = $this->rootPath . 'runtime' . DIRECTORY_SEPARATOR;
+ $this->runtimePath = DIRECTORY_SEPARATOR . 'tmp' . DIRECTORY_SEPARATOR;
修改完成后可以直接使用以下命令進行部署:
fun deploy
經歷與第一個示例一樣的步驟后,我們可以得到一個可以訪問的臨時域名進行測試:13500180-1986114430573743.test.functioncompute.com。打開該臨時域名,可以預覽到與本地運行一樣的效果。
還可以訪問 13500180-1986114430573743.test.functioncompute.com/admin 打開該應用的管理后臺:
總結
本文主要介紹了如何將 ThinkPHP 應用部署到函數計算。相比較與傳統的部署方法,不僅沒有更復雜,還省略了購買機器、安裝配置 Nginx、安裝配置 php-fpm 等步驟。可以實現,將傳統的 ThinkPHP 應用在本地開發完成后,一鍵部署到遠端直接用于生產,并擁有了彈性伸縮、按量付費、免運維等特性。