Phalcon+ é uma estrutura leve Zephir/C baseada em Phalconphp. Queremos construir uma solução de uma etapa para desenvolvedores da Phalcon. É precisamente por causa da flexibilidade extremamente alta da Phalcon que oferece aos desenvolvedores muita escolha. Às vezes, existem muitas interseções e é fácil me perder, então depois de fazer essa série de opções, gravei o processo e gradualmente evolui para o atual Phalcon+. Para impedir que todos os desenvolvedores façam essas escolhas repetidamente, eu resolutamente o Phalcon+ de código aberto para todos se comunicarem e aprenderem.
Portanto, para resumir, o Phalcon+ não é uma nova estrutura, mas uma excelente prática da estrutura Phalcon. É um reprocessamento e suplemento à estrutura Phalcon. Pode permitir que os desenvolvedores da Phalcon comecem e o dominem com mais facilidade e, finalmente, alcance o nível mais alto de unidade entre o homem e a natureza.
* 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 fornece serviços de RPC Web pode fornecer serviços 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
Gráfico TD
A [phalconplus bootstrap :: __ construct] -> | sys :: init, initconf | A1 (SuperApp :: Boot com Env, Runmode)
A1 -> | SYS :: Iniapp, defina constantes globais, o primeiro módulo é primário | A2 (SuperApp :: BootPrimaryModule)
A2 -> | Certifique -se de ter um módulo válido: web/cli/srv | a3 (moduledef)
A3 -> | Atribua SuperApp :: Bootted -> True, faça disso um DefaultModule | A4 (SuperApp :: RegisterModule com Moduledef)
A4 -> | Certifique -se de que este módulo não esteja em execução no SuperApp :: Modules | A5 (módulo de checkout)
A5 -> | AbstractModule :: RegisterAutoloaders/RegisterServices/RegisterEvents | A6 (SYS :: Load ComposerautoloadPath)
A6 -> A7 (SuperApp :: Handle)
A7-> | params = func_get_args, evento: SuperApp: AntesexecModule | B1 (SuperApp :: DefaultModule-> Exec com params)
B1 -> | Evento: SuperApp: AfterExecModule | B2 (AbstractModule :: RegisterEngine)
B2 -> | Evento: Módulo: BeforestartEngine | B3 (AbstractModule :: EXEC com params)
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 -> | Solicitação: GUZEHTTP \ PSR7 \ ServerRequest | C21 (PSRHANDLER :: Handle) -> D1
C2 -> | Reqeust: String | C22 (Phalcon MVC Application :: Handle) -> D1
C2 -> C23 (exceto: manipulador inválido)
B33 -> C3 {Application.Handler == Yar?}
C3 -> | Sim | C31 (YarService :: Handle) -> D1
C3 -> | NO | C32 (SIMPLESERVICE :: Handle) -> D1
D1 (Evento: Módulo: AfterStartEngine) -> | Evento: SuperApp: AfterExecModule | D2 (Retorno)
# 下载骨架
➜ 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 ...
...
...
A estrutura de um módulo da Web é a seguinte: Todos os modos são integrados no módulo da Web, incluindo CLI e 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
Obviamente, você também pode criar arquivos de configuração para facilitar o início cada vez
➜ cd test
➜ touch ppm.json
➜ ../vendor/bin/ppm start -c ppm.json
O conteúdo de Ppm.json é o seguinte:
{
"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
O conteúdo de .rr.json é o seguinte:
{
"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 " ]
}
}O conteúdo do PSR-worker.php é o seguinte:
<?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 );
}Em seguida, execute no diretório do módulo
➜ rr serve -d -v
Arquivo de configuração
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 ;
}
}Qualquer feedback é bem -vindo e espero receber doações e apoio de todos.
Desejo a você tudo de bom, sem irmão 82 :)