PHP之微服務協程框架Swoft

2020-07-16 10:06:00

簡介

  有了swoole這樣強大的擴充套件之後,越來越多的框架都是基於swoole被開發出來,Swoft就是其中一款不錯的PHP框架。Swoft 是一款基於 Swoole 原生協程的註解式框架,自帶常駐記憶體以及 Swoole 其它功能的封裝。swoft中內建了協程用戶端。同時swoft裡面有了很多新的概念,比如Aop等。

  官網地址:https://www.swoft.org/

使用Swoft框架注意事項

  因為Swoft是基於Swoole,所以和普通的PHP框架還是很不一樣的,有些是需要注意的。

  1.不要再程式碼中執行sleep()以及其他睡眠函數,這樣會導致整個進程阻塞。

  2.不要使用exit/die函數,這樣會導致worker進程直接退出。

  3.進程隔離需要注意的,當修改了全域性變數的值,會不生效,因為全域性變數在不同的進程中,記憶體空間是隔離的。使用Swoft框架需要了解進程隔離問題。不同的進程中PHP變數不是共用,即便是全域性變數。如果不同的進程需要共用資料,可以使用Redis,Mysql,訊息佇列,檔案,Swoole/Table,APCu(php自帶的快取擴充套件),shmget(進程通訊(IPC)共用記憶體)等工具。同時不同進程的檔案控制代碼也是隔離的,所以在A進程建立的Socker連線開啟的檔案在B進程內是無效的。

  4.進程克隆,當server啟動時候,主進程會克隆當前進程狀態,此後開始進程內的資料互相獨立,互不影響。

  5.不要再控制器寫基礎類別來寫公共的變數,這樣會造成資料汙染,當下一個請求進來依然會請求到這個變數,因為常駐記憶體並且單利所以不會釋放掉。

  官方文件也有提示

https://www.swoft.org/documents/v2/dev-guide/dev-note/

Swoft框架安裝

  安裝環境要求:

    1. gcc版本大於等於4.8。

    2. PHP版本大於7.1。

    3. Composer包管理工具。

    4. 安裝Redis非同步用戶端hiredis,在最新版本的Swoole4.2.6之後已經內建了,不需要安裝。

    5. Swoole擴充套件,這個是必須的。

    6.連結疊代器依賴庫pcre。

    7. Swoole需要開啟協程和非同步redis。

  安裝

git clone https://github.com/swoft-cloud/swoft
cd swoft
composer install
cp .env.example .env   #編輯 .env 檔案,根據需要調整相關環境設定

如果出現下面錯誤說明redis擴充套件沒有,因為swoft需要redis擴充套件。

當然使用docker方式會更加簡單,執行下面命令

docker run -p 18306:18306 --name swoft swoft/swoft

在瀏覽器中輸入 http://127.0.0.1:18306 就可以開啟Swoft本地頁面。

關閉和開啟執行命令 docker start/stop swoft

Swoft目錄及檔案說明

進入容器檢視swoft目錄

複製代碼
[email protected]:/var/www/swoft# tree -L 2
.
|-- CONTRIBUTING.md
|-- Dockerfile
|-- LICENSE
|-- README.md
|-- README.zh-CN.md
|-- app                        #應用目錄
|   |-- Annotation        #定義注解相關目錄|   |-- Application.php
|   |-- Aspect
|   |-- AutoLoader.php
|   |-- Common
|   |-- Console
|   |-- Exception
|   |-- Helper          #助手函數目錄
|   |-- Http
|   |-- Listener         #事件監聽器目錄|   |-- Migration
|   |-- Model           #模型、邏輯等程式碼目錄|   |-- Process
|   |-- Rpc            #RPC服務程式碼目錄|   |-- Task            #任務投遞管理目錄,這裡可以做非同步任務或者定時器的工作
|   |-- Tcp
|   |-- Validator
|   |-- WebSocket         #WebSocket服務程式碼目錄|   `-- bean.php
|-- bin
|   |-- bootstrap.php
|   `-- swoft            #Swoft入口檔案|-- composer.cn.json
|-- composer.json
|-- composer.lock
|-- config
|   |-- base.php
|   |-- db.php
|   `-- dev
|-- database
|   |-- AutoLoader.php
|   `-- Migration
|-- dev.composer.json
|-- docker-compose.yml
|-- phpstan.neon.dist
|-- phpunit.xml
|-- public
|   |-- favicon.ico
|   `-- image
|-- resource                   #應用資源目錄|   |-- language
|   `-- views
|-- runtime             #臨時檔案目錄(紀錄檔、上傳檔案、檔案快取等)|   |-- logs
|   |-- sessions
|   |-- swoft.command
|   `-- swoft.pid
|-- test              #單元測試目錄   
|   |-- apitest
|   |-- bootstrap.php
|   |-- run.php
|   |-- testing
|   `-- unit
`-- vendor
    |-- autoload.php
    |-- bin
    |-- composer
    |-- doctrine
    |-- monolog
    |-- myclabs
    |-- nikic
    |-- phar-io
    |-- php-di
    |-- phpdocumentor
    |-- phpoption
    |-- phpspec
    |-- phpunit
    |-- psr
    |-- sebastian
    |-- swoft
    |-- symfony
    |-- text
    |-- theseer
    |-- toolkit
    |-- vlucas
    `-- webmozart
複製代碼

SwoftBean容器

   Bean容器是Swoft的核心,每一個Bean就是一個類物件的範例,容器就是一個工廠來存放和管理Bean。在HttpServer啟動時候會掃描帶有@Bean註解的類。傳統的PHP是沒有常駐記憶體的,每次請求都會重新初始化各種資源,每個物件也要重新範例化去申請記憶體,處理完請求後又被消耗,十分浪費資源。而Swoft在HttpServer啟動後會將這些物件範例化並存放在記憶體中,下次請求就直接取出使用,減少物件建立資源的消耗。

   Bean容器底層是一個BeanFactory管理容器(Container)。

Swoft註解(Annotations)機制

註解是Swoft裡面很多重要功能特別是AOP,IoC容器的基礎。熟悉Java的朋友應該更加瞭解註解。 

那麼註解是什麼樣呢?下面是Swoft的一部分程式碼在類、方法或成員變數上方的注釋部分就有註解。

複製代碼
namespace AppTcpController;

use AppTcpMiddlewareDemoMiddleware;
use SwoftTcpServerAnnotationMappingTcpController;
use SwoftTcpServerAnnotationMappingTcpMapping;
use SwoftTcpServerRequest;
use SwoftTcpServerResponse;
use function strrev;

/**
 * Class DemoController
 *
 * @TcpController(middlewares={DemoMiddleware::class})      #這個就是註解
 */
class DemoController
{
    /**
     * @TcpMapping("list", root=true)
     * @param Response $response
     */
    public function list(Response $response): void
    {
        $response->setData('[list]allow command: list, echo, demo.echo');
    }
複製代碼

  註解是什麼呢?有什麼作用呢?

    註解其實是通過反射把註釋當成程式碼的一部分,PHP可以通過ReflectionClass來獲取一個類的資訊,從而了解類裡的資訊,比如獲取類中的所有方法、成員變數,並包括私有方法等,並根據這些資訊實現一些操作。像很多PHP框架,比如laravel框架就利用PHP的反射機制來實現依賴注入。

    其實註解是設定的另一種方式,這裡注解就可以起到一個設定作用。比如定義路由,定義設定定時任務,許可權控制等。

    在Swoft中要是使用註解,需引入相關注解(Annotation)類,且必須以 /** 開始並以 */ 結束,否則會導致無法解析!

Aop切面程式設計

  Aop介紹

    1. Aspect(切面):通常是一個類,裡面可以定義切入點和通知。

    2. JointPoint(連線點):程式執行過程中明確的點,一般是方法的呼叫。

    3. Advice(通知):Aop在特定的切入點執行的增強處理,有before,after,afterReturning,afterThrowing,around。

    4. Pointcut(切入點):就是嗲有通知的連線點,在程式中主要體現為書寫切入點表示式。

   Swoft新版的Aop設計建立在PHP Parser上面。

    PHP-Parser的專案主頁是:https://github.com/nikic/PHP-Parser

推薦教學:《php教學

以上就是PHP之微服務協程框架Swoft的詳細內容,更多請關注TW511.COM其它相關文章!