簡介
Usage: APPLICATION COMMAND [OPTIONS]
mojo version
mojo generate lite_app
./myapp.pl daemon -m production -l http://*:8080
./myapp.pl get /foo
./myapp.pl routes -v
Tip: CGI and PSGI environments can be automatically detected very often and
work without commands.
Options (for all commands):
-h, --help Get more information on a specific command
--home <path> Path to home directory of your application, defaults to
the value of MOJO_HOME or auto-detection
-m, --mode <name> Operating mode for your application, defaults to the
value of MOJO_MODE/PLACK_ENV or "development"
Mojolicious::Commands是Mojolicious框架的交互式命令接口。它將自動(dòng)檢測Mojolicious命名空間中的所有可用命令。
可用命令介紹
默認(rèn)情況下在Mojolicious框架中已經(jīng)實(shí)現(xiàn)的命令會(huì)在接下來一一進(jìn)行簡單的介紹。
cgi
$ ./myapp.pl cgi
使用Mojolicious::Command::cgi對(duì)象中的CGI 支持啟動(dòng)應(yīng)用程序,通過是自動(dòng)檢測。
cpanify
$ mojo cpanify -u sri -p secr3t Mojolicious-Plugin-Fun-0.1.tar.gz
使用Mojolicious::Command::cpanify將文件上傳到CPAN。
daemon
$ ./myapp.pl daemon
使用Mojolicious::Command::deamon可啟動(dòng)獨(dú)立的HTTP和WebSocket服務(wù)器應(yīng)用。
eval
$ ./myapp.pl eval 'say app->home'
使用Mojolicious::Command::eval來運(yùn)行應(yīng)用程序的代碼。
generate
$ mojo generate
$ mojo generate help
$ ./myapp.pl generate help
列出可用的“生成器”命令,和簡短的描述。
$ mojo generate help <generator>
$ ./myapp.pl generate help <generator>
列出具有簡短說明的“生成器”命令的可用選項(xiàng)。
generate app
$ mojo generate app <AppName>
使用Mojolicious::Command::generate::app為全功能的Mojolicious應(yīng)用程序生成應(yīng)用程序目錄結(jié)構(gòu)。
generate lite_app
$ mojo generate lite_app
使用Mojolicious::Command::generate::lite_app生成一個(gè)功能完整的Mojolicious::Lite應(yīng)用程序。
generate makefile
$ mojo generate makefile
$ ./myapp.pl generate makefile
使用Mojolicious::Command::generate::makefile生成Makefile.PL應(yīng)用程序文件。
generate plugin
$ mojo generate plugin <PluginName>
使用Mojolicious::Command::generate::plugin來生成一個(gè)功能完整的Mojolicious插件的目錄結(jié)構(gòu)。
get
$ mojo get http://mojolicious.org
$ ./myapp.pl get /foo
使用Mojolicious::Command::get來執(zhí)行遠(yuǎn)程主機(jī)或本地應(yīng)用程序的請(qǐng)求。
help
$ mojo
$ mojo help
$ ./myapp.pl help
列出可用的命令和簡短描述。
$ mojo help <command>
$ ./myapp.pl help <command>
列出具有簡短描述的命令的可用選項(xiàng)。
inflate
$ ./myapp.pl inflate
使用Mojolicious::Command::inflate將嵌入在應(yīng)用程序DATA段中的模板和靜態(tài)文件轉(zhuǎn)換為真實(shí)文件。
prefork
$ ./myapp.pl prefork
使用Mojolicious::Command::prefork啟動(dòng)支持pre-forking 的 HTTP和WebSocket服務(wù)器。
psgi
$ ./myapp.pl psgi
使用Mojolicious::Command::psgi對(duì)象中的PSGI 支持啟動(dòng)應(yīng)用程序,通過是自動(dòng)檢測。
routes
$ ./myapp.pl routes
使用Mojolicious::Command::routes列出應(yīng)用程序路由。
test
$ ./myapp.pl test
$ ./myapp.pl test t/fun.t
使用Mojolicious::Command::test從t目錄運(yùn)行應(yīng)用程序的測試。
version
$ mojo version
$ ./myapp.pl version
使用Mojolicious::Command::version顯示可用的核心和可選模塊的版本信息,對(duì)調(diào)試非常有用。
屬性
hint
my $hint = $commands->hint;
$commands = $commands->hint('Foo');
列出可用命令后顯示的簡短提示。
message
my $msg = $commands->message;
$commands = $commands->message('Hello World!');
列出可用命令之前顯示的短使用信息。
namespaces
my $namespaces = $commands->namespaces;
$commands = $commands->namespaces(['MyApp::Command']);
從哪個(gè)命令空間來加載命令,默認(rèn)為Mojolicious::Command。
# Add another namespace to load commands from
push @{$commands->namespaces}, 'MyApp::Command';
方法
Mojolicious::Commands繼承Mojolicious::Command中的所有方法,并實(shí)現(xiàn)以下方法。
detect
my $env = $commands->detect;
嘗試檢測運(yùn)行環(huán)境,如果沒有檢測到的話返回undef。
run
$commands->run;
$commands->run(@ARGV);
加載并運(yùn)行命令??梢允褂肕OJO_NO_DETECT環(huán)境變量禁用自動(dòng)部署環(huán)境檢測。
start_app
Mojolicious::Commands->start_app('MyApp');
Mojolicious::Commands->start_app(MyApp => @ARGV);
從指定的類中加載應(yīng)用程序,并從命令行中啟動(dòng)它。
注:選項(xiàng)-h/ --help,--home和-m/ --mode,被所有命令共享,將在編譯時(shí)從解析@ARGV得到。
# Always start daemon for application
Mojolicious::Commands->start_app('MyApp', 'daemon', '-l', 'http://*:8080');