Phalcon+ - это легкая структура Zephir/C, основанная на Phalconphp. Мы хотим создать одноступенческое решение для разработчиков Phalcon. Именно из -за чрезвычайно высокой гибкости Phalcon дает разработчикам слишком большой выбор. Иногда слишком много пересечений, и их легко терять, поэтому после того, как я сделал этот серию вариантов, я записал процесс и постепенно превратился в текущий Phalcon+. Чтобы каждый разработчик не делал этот выбор неоднократно, я решительно открылся Phalcon+ для общения и обучения с открытым исходным кодом.
Таким образом, под сумму, Phalcon+ не является новой структурой, а отличной практикой фреймворка Phalcon. Это переработка и дополнение к рамке Phalcon. Это может позволить разработчикам Phalcon начать работу и легче освоить его и, наконец, достичь высшего уровня единства между человеком и природой.
* PHP 7.0 or above
* cPhalcon 3.4.x,在官方发布3.4.6之前一定要下载此分支,通过`zephir build`手动编译phalcon - https://github.com/phalcon/cphalcon/tree/3.4.x
> 安装zephir之前,需要先安装扩展 https://github.com/phalcon/php-zephir-parser ,然后使用`composer`安装`zephir`
`composer global require phalcon/zephir`
Srv предоставляет услуги RPC, Web может предоставлять услуги RestfulApp::import("test") ➜ git clone https://github.com/bullsoft/phalconplus.git
➜ cd phalconplus/ext/
➜ /usr/bin/phpize
➜ ./configure --with-php-config=/usr/bin/php-configure
➜ make
➜ make install
График тд
A [phalconplus bootstrap :: __ construct] -> | sys :: init, initConf | A1 (SuperApp :: Boot с Env, RunMode)
A1 -> | sys :: iniapp, определить глобальные константы, первый модуль -первичный | A2 (SuperApp :: BootPrimaryModule)
A2 -> | Убедитесь, что у нас есть действительный модуль: web/cli/srv | a3 (moduledef)
A3 -> | Назначить SuperApp :: Booted -> true, сделайте это по умолчанию модуля | A4 (SuperApp :: RegisterModule с ModuLedef)
A4 -> | Убедитесь, что этот модуль не работает в SuperApp :: Модули | A5 (модуль проверки)
A5 -> | AbstractModule :: RegisterAutoloLoaders/RegisterServices/RegisterVents | A6 (sys :: нагрузка Composerautoloadpath)
A6 -> a7 (superapp :: handle)
A7-> | params = func_get_args, Event: SuperApp: передэксекмодуль | b1 (SuperApp :: defaultmodule-> exec с params)
B1 -> | Событие: SuperApp: AfterExeCmodule | B2 (AbstractModule :: RegisteringEngine)
B2 -> | Событие: модуль: Beforestartengine | B3 (AbstractModule :: Exec с парамис)
B3 -> b31 (runmode: cli) -> c1 (phalcon cli console :: handle) -> d1
B3 -> B32 (RunMode: Web)
B3 -> B33 (RunMode: SRV)
B32 -> C2 {Engine web :: Handler is}
C2 -> | Запрос: Guzzehttp \ psr7 \ serverRequest | c21 (psrhandler :: handle) -> d1
C2 -> | reqeust: String | C22 (Phalcon MVC Application :: Harder) -> D1
C2 -> C23 (кроме неверного обработчика)
B33 -> c3 {application.handler == yar?}
C3 -> | Да | C31 (ourservice :: Harder) -> D1
C3 -> | Нет | C32 (Simpleservice :: Harder) -> D1
D1 (Событие: Модуль: AfterStartengine) -> | Событие: SuperApp: AfterExeCmodule | D2 (возврат)
# 下载骨架
➜ composer create-project bullsoft/fp-project fp-app
# 生成模块,假设生成的模块名为test
➜ cd fp-app
➜ ./common/bin/fp-devtool module:create
现在开始引导您创建Phalcon+模块 ...
Step 1 请输入该模块的名称,如"api"
[Enter]: test
Step 2 ...
...
...
Структура веб -модуля заключается в следующем: все режимы интегрированы в веб -модуль, включая CLI и RPCService.
test
.
├── app
│ ├── Module.php
│ ├── auth
│ │ ├── AclResources.php
│ │ ├── Model.php
│ │ ├── Resources
│ │ │ ├── Actions.php
│ │ │ └── Models.php
│ │ └── User.php
│ ├── config
│ │ └── dev.php
│ ├── controllers
│ │ ├── BaseController.php
│ │ ├── ErrorController.php
│ │ ├── IndexController.php
│ │ ├── UserController.php
│ │ └── apis
│ │ └── DemoController.php
│ ├── events
│ │ ├── Acl.php
│ │ ├── AppConsole.php
│ │ ├── AppHandler.php
│ │ ├── BackendServer.php
│ │ ├── Db.php
│ │ ├── EventProvider.php
│ │ ├── Model.php
│ │ ├── MvcDispatch.php
│ │ ├── Router.php
│ │ ├── SuperApp.php
│ │ └── View.php
│ ├── exceptions
│ │ ├── EnumExceptionCode.php
│ │ ├── Handler.php
│ │ ├── UnknownException.php
│ │ ├── UserAlreadyExistsException.php
│ │ └── UserNotExistsException.php
│ ├── plugins
│ │ └── Volt.php
│ ├── providers
│ │ ├── CookieServiceProvider.php
│ │ ├── CryptServiceProvider.php
│ │ ├── DatabaseServiceProvider.php
│ │ ├── DispatcherServiceProvider.php
│ │ ├── LoggerServiceProvider.php
│ │ ├── RedisServiceProvider.php
│ │ ├── RouterServiceProvider.php
│ │ ├── RpcServiceProvider.php
│ │ ├── ServiceProvider.php
│ │ ├── SessionServiceProvider.php
│ │ ├── UrlServiceProvider.php
│ │ └── ViewServiceProvider.php
│ ├── routes
│ │ ├── Api.php
│ │ └── Bare.php
│ └── views
│ ├── error
│ │ ├── show403.volt
│ │ ├── show404.volt
│ │ └── show500.volt
│ ├── index
│ │ └── index.volt
│ └── index.volt
├── cli
│ ├── init.php
│ └── tasks
│ └── HelloTask.php
├── public
│ ├── index.php
│ └── rpc.php
├── src
│ ├── models
│ │ └── UserModel.php
│ ├── protos
│ │ ├── Enums
│ │ │ └── UserStatus.php
│ │ └── Schemas
│ │ └── RegInfo.php
│ └── services
│ ├── BaseService.php
│ └── DemoService.php
└── var
└── cache
➜ ./common/bin/fp-devtool server:start test
正在为您启动服务器...
{
" command " : " { (php -S 0.0.0.0:8181 -t public/ .htrouter.php) <&3 3<&- 3>/dev/null & } 3<&0;pid= $! ; echo $pid > /path/to/test/var/run/server.pid " ,
" pid " : 8249,
" running " : true,
" signaled " : false,
" stopped " : false,
" exitcode " : -1,
" termsig " : 0,
" stopsig " : 0
}
... 启动成功,请使用 http://127.0.0.1:8181 访问 ➜ cd test
➜ ../vendor/bin/ppm start --bridge="PhalconPlus\Bridge" --bootstrap="PhalconPlus\Bootstrap" --static-directory=public/ --port=8181 --workers=2
Конечно, вы также можете создавать файлы конфигурации, чтобы упростить запуск каждый раз каждый раз
➜ cd test
➜ touch ppm.json
➜ ../vendor/bin/ppm start -c ppm.json
Содержание Ppm.json заключается в следующем:
{
"bridge" : " PhalconPlus \ Bridge " ,
"host" : " 127.0.0.1 " ,
"port" : 8181 ,
"workers" : 2 ,
"app-env" : " dev " ,
"debug" : 1 ,
"logging" : 1 ,
"static-directory" : " public/ " ,
"bootstrap" : " PhalconPlus \ Bootstrap " ,
"max-requests" : 1000 ,
"concurrent-requests" : 20 ,
"php-cgi" : " /usr/local/opt/[email protected]/bin/php "
} ➜ composer require spiral/roadrunner
➜ cd test
➜ touch .rr.json
➜ touch psr-worker.php
Содержание .rr.json заключается в следующем:
{
"http" : {
"address" : " 0.0.0.0:8181 " ,
"workers" : {
"command" : " /usr/local/opt/[email protected]/bin/php psr-worker.php " ,
"relay" : " unix://rr.sock " ,
"pool" : {
"numWorkers" : 2
}
}
},
"static" : {
"enable" : true ,
"dir" : " public " ,
"forbid" : [ " .php " , " .htaccess " ]
}
}Содержание psr-worker.php заключается в следующем:
<?php
use Spiral Goridge ;
use Spiral RoadRunner ;
use PhalconPlus Http PsrResponseFactory ;
ini_set ( ' display_errors ' , ' stderr ' );
$ app = ( new PhalconPlus Bootstrap ( __DIR__ ))-> app ();
$ worker = new RoadRunner Worker (
new Goridge SocketRelay ( __DIR__ . " /rr.sock " , null , Goridge SocketRelay:: SOCK_UNIX )
);
$ psr7 = new RoadRunner PSR7Client ( $ worker );
while ( $ req = $ psr7 -> acceptRequest ()) {
try {
$ resp = $ app -> handle ( $ req );
} catch ( Throwable $ e ) {
Test Exceptions Handler:: catch ( $ e );
$ resp = $ app -> response ();
}
$ psr7 -> respond (PsrResponseFactory:: create ( $ resp ));
$ app -> terminate ();
unset( $ req , $ resp );
}Затем выполнить в каталоге модуля
➜ rr serve -d -v
Файл конфигурации
server {
listen 8181 ;
server_name localhost;
access_log /var/log/nginx/test.access.log;
index index.php index.html index.htm;
set $root_path '/home/work/wwwroot/fp-app/test/public' ;
root $root_path ;
try_files $uri $uri / @rewrite;
location @rewrite {
rewrite ^/(.*)$ /index.php last ;
}
location ~ .php {
fastcgi_pass unix:/run/php/php7.2-fpm.sock;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name ;
}
location ~* ^/(css|img|js|flv|swf|download)/(.+)$ {
root $root_path ;
}
location ~ /.ht {
deny all ;
}
}Любые отзывы приветствуются, и я надеюсь получить пожертвования и поддержку от всех.
Желаю вам всего наилучшего, нет брата 82 :)