5 use lib '/srv/MojoX-Gearman/lib';
8 use Data::Dump qw(dump);
10 # Documentation browser under "/perldoc" (this plugin requires Perl 5.10)
11 plugin 'pod_renderer';
15 $self->render('index');
18 get '/ping_http' => sub {
20 my $gearman = $self->client;
21 my $pong = $gearman->post( "http://localhost:4780/ping" => { Connection => 'close' } => "some data" )->res->body;
23 $self->render( 'ping', pong => $pong );
26 my $gearman = MojoX::Gearman->new; #( ioloop => Mojo::IOLoop->singleton );
27 $gearman->server( $ENV{GEARMAN} || 'localhost:4730' );
29 get '/ping_g' => sub {
31 my $pong = $gearman->req( 'SUBMIT_JOB', 'ping', '', "some data 2" );
33 $self->render( 'ping', pong => $pong );
36 get '/g/:call/:args' => sub {
38 my $ret = $gearman->req( 'SUBMIT_JOB', $self->param('call'), '', $self->param('args') );
39 warn $self->param('call'), " = ", dump($ret), "\n";
40 my $json = Mojo::JSON->new->decode( $ret );
41 $self->render_json( $json );
48 % title 'Gearman demo';
49 Welcome to Mojolicious Gearman integration demo!
51 <%= link_to 'HTTP ping' => 'ping_http' %>
52 <%= link_to 'Gearman ping' => 'ping_g' %>
56 pong: <tt><%= $pong %>
60 <pre><%= $dump %></pre>
62 @@ layouts/default.html.ep
64 <head><title><%= title %></title></head>
65 <body><%= content %></body>