創建適合自己的骨架包

有網友每次創建新項目時,都要去執行一次 composer create-project hyperf/hyperf-skeleton。其實每次這樣創建項目,效率會很低。個人項目其實還好,但是對於公司項目而言,就不是那麼友好了。比如有的公司會創建很多組件包,或者很多公共配置之類的代碼。每次 create 項目都需要重新 copy 進來,效率很差,而且又不方便維護。

所以我們可以製作一個骨架包,每次創建新項目,都可以當前骨架包爲藍本進行初始化。

製作骨架包

我們使用 hyperf/hyperf-skeleton 來創建骨架包,並不安裝任何可選項。

composer create-project hyperf/hyperf-skeleton parent
爲了方便演示,我使用 Github 做版本控制。

將代碼上傳到 Aquarmini/skeleton-parent

cd parent
git init
git remote add -m master origin [email protected]:Aquarmini/skeleton-parent.git
git add .
git commit -a -m "INIT"
git push origin master
git branch --set-upstream-to=origin/master master

創建 Demo 項目

接下來讓我們基於 parent 創建 demo 項目

mkdir demo
git init
git remote add -m master parent [email protected]:Aquarmini/skeleton-parent.git
git pull parent master
git branch parent
git branch --set-upstream-to=parent/master parent
git remote add -m master origin [email protected]:Aquarmini/skeleton-demo.git

git checkout master
git push origin master
git push origin master
git branch --set-upstream-to=origin/master master

接下來看一下我們的 git 配置

$ cat .git/config
[core]
    repositoryformatversion = 0
    filemode = true
    bare = false
    logallrefupdates = true
    ignorecase = true
    precomposeunicode = true
[remote "parent"]
    url = [email protected]:Aquarmini/skeleton-parent.git
    fetch = +refs/heads/*:refs/remotes/parent/*
[branch "parent"]
    remote = parent
    merge = refs/heads/master
[remote "origin"]
    url = [email protected]:Aquarmini/skeleton-demo.git
    fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
    remote = origin
    merge = refs/heads/master

讓我們隨意修改一點代碼,並推送到 demo 倉庫。

合併 Parent

當我們 parent 有任何修改時,只需要合並進來即可。

比如我們增加一個 di 方法,可以方便拿到 Container

修改 composer.json,以下省略不想關的代碼

{
    "autoload": {
        "psr-4": {
            "App\\": "app/"
        },
        "files": [
            "app/Kernel/Functions.php"
        ]
    }
}

然後增加 app/Kernel/Functions.php 文件

<?php

declare(strict_types=1);
/**
 * This file is part of Hyperf.
 *
 * @link     https://www.hyperf.io
 * @document https://doc.hyperf.io
 * @contact  [email protected]
 * @license  https://github.com/hyperf-cloud/hyperf/blob/master/LICENSE
 */

use Hyperf\Utils\ApplicationContext;

if (! function_exists('di')) {
    /**
     * Finds an entry of the container by its identifier and returns it.
     * @param null|mixed $id
     * @return mixed|\Psr\Container\ContainerInterface
     */
    function di($id = null)
    {
        $container = ApplicationContext::getContainer();
        if ($id) {
            return $container->get($id);
        }

        return $container;
    }
}

提交代碼到 parent 項目

然後在 demo 項目中拉取 parent 分支。

git checkout parent
git pull parent master
git checkout master
git merge parent
git push origin master

寫在最後

Hyperf

Hyperf 是基於 Swoole 4.4+ 實現的高性能、高靈活性的 PHP 協程框架,內置協程服務器及大量常用的組件,性能較傳統基於 PHP-FPM 的框架有質的提升,提供超高性能的同時,也保持着極其靈活的可擴展性,標準組件均基於 PSR 標準 實現,基於強大的依賴注入設計,保證了絕大部分組件或類都是 可替換可複用 的。

框架組件庫除了常見的協程版的 MySQL 客戶端Redis 客戶端,還爲您準備了協程版的 Eloquent ORMWebSocket 服務端及客戶端JSON RPC 服務端及客戶端GRPC 服務端及客戶端Zipkin/Jaeger (OpenTracing) 客戶端Guzzle HTTP 客戶端Elasticsearch 客戶端Consul 客戶端ETCD 客戶端AMQP 組件Apollo 配置中心阿里雲 ACM 應用配置管理ETCD 配置中心基於令牌桶算法的限流器通用連接池熔斷器Swagger 文檔生成Swoole TrackerBlade 和 Smarty 視圖引擎Snowflake 全局ID生成器 等組件,省去了自己實現對應協程版本的麻煩。

Hyperf 還提供了 基於 PSR-11 的依賴注入容器註解AOP 面向切面編程基於 PSR-15 的中間件自定義進程基於 PSR-14 的事件管理器Redis/RabbitMQ 消息隊列自動模型緩存基於 PSR-16 的緩存Crontab 秒級定時任務Translation 國際化Validation 驗證器 等非常便捷的功能,滿足豐富的技術場景和業務場景,開箱即用。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章