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' => [ args => qr/.*/ ] => sub {
38 my $ret = $gearman->req( 'SUBMIT_JOB', $self->param('call'), '', $self->param('args') );
39 warn $self->param('call'), " = ", dump($ret), "\n";
40 die "no result for ", $self->param('call'), ' args: ', $self->param('args') unless defined $ret;
41 my $json = Mojo::JSON->new->decode( $ret );
42 $self->render_json( $json );
49 % title 'Gearman demo';
50 Welcome to Mojolicious Gearman integration demo!
52 <%= link_to 'HTTP ping' => 'ping_http' %>
53 <%= link_to 'Gearman ping' => 'ping_g' %>
57 pong: <tt><%= $pong %>
61 <pre><%= $dump %></pre>
63 @@ layouts/default.html.ep
65 <head><title><%= title %></title></head>
66 <body><%= content %></body>