From 026f712c80bdcca6853e248933f15bbe784d2b9d Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 19:51:58 +0400 Subject: [PATCH 1/7] bare plack app --- plack/app.psgi | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 plack/app.psgi diff --git a/plack/app.psgi b/plack/app.psgi new file mode 100644 index 00000000000..cede5d003b1 --- /dev/null +++ b/plack/app.psgi @@ -0,0 +1,28 @@ +# starman --workers N app.psgi +use v5.16; +use Plack::Builder; +use Plack::Request; +use JSON::XS 'encode_json'; +use DBI; + +my $dbh = DBI->connect('dbi:mysql:dbname=test', 'root') || die $!; +my $sth = $dbh->prepare('SELECT id, randomnumber FROM world WHERE id = ?'); +my $header = HTTP::Headers->new('Content-Type' => 'application/json'); + +builder { + mount '/json' => sub { + Plack::Request->new(shift)->new_response( + 200, $header, encode_json({ message => 'Hello, World!' }) + )->finalize + }, + mount '/dbi' => sub { + my $r = Plack::Request->new(shift); + $r->new_response( 200, $header, encode_json([ + map { id => $_->[0], randomnumber => $_->[1] }, + grep exists $_->[1], + map [$_, $sth->execute($_) && $sth->fetchrow_array], + map int rand 10000 + 1, + 1..$r->param('queries')//1 + ]) )->finalize + } +}; From 8ec540e7a6e4c64d82bf76ab5e35ba97b473b60b Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 20:11:26 +0400 Subject: [PATCH 2/7] cleanup --- plack/app.psgi | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/plack/app.psgi b/plack/app.psgi index cede5d003b1..01ed373f7b3 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -1,7 +1,8 @@ -# starman --workers N app.psgi +# starman --workers N myapp.psgi use v5.16; use Plack::Builder; use Plack::Request; +use Plack::Response; use JSON::XS 'encode_json'; use DBI; @@ -10,18 +11,16 @@ my $sth = $dbh->prepare('SELECT id, randomnumber FROM world WHERE id = ?'); my $header = HTTP::Headers->new('Content-Type' => 'application/json'); builder { - mount '/json' => sub { - Plack::Request->new(shift)->new_response( - 200, $header, encode_json({ message => 'Hello, World!' }) - )->finalize - }, + mount '/json' => sub { Plack::Response->new( + 200, $header, encode_json({ message => 'Hello, World!' }) + )->finalize }, mount '/dbi' => sub { my $r = Plack::Request->new(shift); $r->new_response( 200, $header, encode_json([ map { id => $_->[0], randomnumber => $_->[1] }, grep exists $_->[1], map [$_, $sth->execute($_) && $sth->fetchrow_array], - map int rand 10000 + 1, + map int rand 10000 + 1, 1..$r->param('queries')//1 ]) )->finalize } From d2e4b7322de6b6ff6fe070c58057636c1fc64bdb Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 20:19:35 +0400 Subject: [PATCH 3/7] whitespaces cleanup --- plack/app.psgi | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/plack/app.psgi b/plack/app.psgi index 01ed373f7b3..20038c5824c 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -1,4 +1,4 @@ -# starman --workers N myapp.psgi +# starman --workers N app.psgi use v5.16; use Plack::Builder; use Plack::Request; @@ -16,12 +16,12 @@ builder { )->finalize }, mount '/dbi' => sub { my $r = Plack::Request->new(shift); - $r->new_response( 200, $header, encode_json([ - map { id => $_->[0], randomnumber => $_->[1] }, - grep exists $_->[1], - map [$_, $sth->execute($_) && $sth->fetchrow_array], + $r->new_response( 200, $header, encode_json([ + map { id => $_->[0], randomnumber => $_->[1] }, + grep exists $_->[1], + map [$_, $sth->execute($_) && $sth->fetchrow_array], map int rand 10000 + 1, - 1..$r->param('queries')//1 + 1..$r->param('queries')//1 ]) )->finalize } }; From 32d9de81997a16ddb258a8645afc0a4604aa4807 Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 20:25:55 +0400 Subject: [PATCH 4/7] sql fix --- plack/app.psgi | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plack/app.psgi b/plack/app.psgi index 20038c5824c..870b5f24b19 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -7,7 +7,7 @@ use JSON::XS 'encode_json'; use DBI; my $dbh = DBI->connect('dbi:mysql:dbname=test', 'root') || die $!; -my $sth = $dbh->prepare('SELECT id, randomnumber FROM world WHERE id = ?'); +my $sth = $dbh->prepare('SELECT randomnumber FROM world WHERE id = ?'); my $header = HTTP::Headers->new('Content-Type' => 'application/json'); builder { From 1985150f919736a977626957b37294bde515f5dc Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 20:47:45 +0400 Subject: [PATCH 5/7] raw response --- plack/app.psgi | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/plack/app.psgi b/plack/app.psgi index 870b5f24b19..c11763bff86 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -2,26 +2,20 @@ use v5.16; use Plack::Builder; use Plack::Request; -use Plack::Response; use JSON::XS 'encode_json'; use DBI; my $dbh = DBI->connect('dbi:mysql:dbname=test', 'root') || die $!; my $sth = $dbh->prepare('SELECT randomnumber FROM world WHERE id = ?'); -my $header = HTTP::Headers->new('Content-Type' => 'application/json'); +my $header = ['Content-Type' => 'application/json']; builder { - mount '/json' => sub { Plack::Response->new( - 200, $header, encode_json({ message => 'Hello, World!' }) - )->finalize }, - mount '/dbi' => sub { - my $r = Plack::Request->new(shift); - $r->new_response( 200, $header, encode_json([ - map { id => $_->[0], randomnumber => $_->[1] }, - grep exists $_->[1], - map [$_, $sth->execute($_) && $sth->fetchrow_array], - map int rand 10000 + 1, - 1..$r->param('queries')//1 - ]) )->finalize - } + mount '/json' => sub { [ 200, $header, [ encode_json({ message => 'Hello, World!' })] ] }, + mount '/dbi' => sub { [ 200, $header, [ encode_json([ + map { id => $_->[0], randomnumber => $_->[1] }, + grep exists $_->[1], + map [$_, $sth->execute($_) && $sth->fetchrow_array], + map int rand 10000 + 1, + 1..Plack::Request->new(shift)->param('queries')//1 + ]) ] ] } }; From 7eb5b4d56ae240c08bdfa721681850c463bf74b9 Mon Sep 17 00:00:00 2001 From: vividsnow Date: Wed, 17 Apr 2013 21:03:15 +0400 Subject: [PATCH 6/7] numberize id --- plack/app.psgi | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plack/app.psgi b/plack/app.psgi index c11763bff86..9fa5edd3a19 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -12,7 +12,7 @@ my $header = ['Content-Type' => 'application/json']; builder { mount '/json' => sub { [ 200, $header, [ encode_json({ message => 'Hello, World!' })] ] }, mount '/dbi' => sub { [ 200, $header, [ encode_json([ - map { id => $_->[0], randomnumber => $_->[1] }, + map { id => $_->[0] + 0, randomnumber => $_->[1] }, grep exists $_->[1], map [$_, $sth->execute($_) && $sth->fetchrow_array], map int rand 10000 + 1, From c4e6b88379bd55861cbc74dabac8a80f769f598d Mon Sep 17 00:00:00 2001 From: vividsnow Date: Thu, 18 Apr 2013 03:01:59 +0400 Subject: [PATCH 7/7] Update app.psgi --- plack/app.psgi | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plack/app.psgi b/plack/app.psgi index 9fa5edd3a19..70e0095ba92 100644 --- a/plack/app.psgi +++ b/plack/app.psgi @@ -1,4 +1,6 @@ -# starman --workers N app.psgi +# plackup -s Starman --workers N -E deployment app.psgi +# -or- +# plackup -s Twiggy::Prefork --max_workers N -E deployment app.psgi use v5.16; use Plack::Builder; use Plack::Request;