1Net::Server::Coro(3)  User Contributed Perl Documentation Net::Server::Coro(3)
2
3
4

NAME

6       Net::Server::Coro - A co-operative multithreaded server using Coro
7

SYNOPSIS

9           use Coro;
10           use base qw/Net::Server::Coro/;
11
12           __PACKAGE__->new->run;
13
14           sub process_request {
15              ...
16              cede;
17              ...
18           }
19

DESCRIPTION

21       Net::Server::Coro implements multithreaded server for the Net::Server
22       architecture, using Coro and Coro::Socket to make all reads and writes
23       non-blocking.  Additionally, it supports non-blocking SSL negotiation.
24

METHODS

26       Most methods are inherited from Net::Server -- see it for further usage
27       details.
28
29   new
30       Create new Net::Server::Coro object. It accepts these parameters (in
31       addition to Net::Server parameters):
32
33       server_cert
34           Path to the SSL certificate that the server should use. This can be
35           either relative or absolute path.  Defaults to
36           certs/server-cert.pem
37
38       server_key
39           Path to the SSL certificate key that the server should use. This
40           can be either relative or absolute path.  Defaults to
41           certs/server-key.pem
42
43   proto_object HOST, PORT, PROTO
44       Wraps socket creation, turning all socket types into
45       Net::Server::Proto::Coro objects.
46
47   loop
48       The main loop uses starts a number of Coro coroutines:
49
50       •   One for each listening socket.
51
52       •   One for each active connection.  Since these may respawn on a
53           firlay frequent basis, "async_pool" in Coro is used to maintain a
54           pool of coroutines.
55
56       •   An AnyEvent infinite wait, which equates to the "run the event
57           loop."
58
59   server_cert [PATH]
60       Gets or sets the path of the SSL certificate used by the server.
61
62   server_key [PATH]
63       Gets or sets the path of the SSL key file used by the server.
64

DEPENDENCIES

66       Coro, AnyEvent, Net::Server
67

BUGS AND LIMITATIONS

69       The client filehandle, socket, and peer information all use
70       Coro::Specific in order to constrain their information to their
71       coroutine.  Attempting to access them from a different coroutine will
72       yield possibly unexpected results.
73
74       Generally, all those of Coro.  Please report any bugs or feature
75       requests specific to Net::Server::Coro to
76       "bug-net-server-coro@rt.cpan.org", or through the web interface at
77       <http://rt.cpan.org>.
78

AUTHORS

80       Alex Vandiver "<alexmv@bestpractical.com>"; code originally from Audrey
81       Tang "<cpan@audreyt.org>"
82
84       Copyright 2006 by Audrey Tang <cpan@audreyt.org>
85
86       Copyright 2007-2008 by Best Practical Solutions
87
88       This software is released under the MIT license cited below.
89
90   The "MIT" License
91       Permission is hereby granted, free of charge, to any person obtaining a
92       copy of this software and associated documentation files (the
93       "Software"), to deal in the Software without restriction, including
94       without limitation the rights to use, copy, modify, merge, publish,
95       distribute, sublicense, and/or sell copies of the Software, and to
96       permit persons to whom the Software is furnished to do so, subject to
97       the following conditions:
98
99       The above copyright notice and this permission notice shall be included
100       in all copies or substantial portions of the Software.
101
102       THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
103       OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
104       MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
105       IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
106       CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
107       TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
108       SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
109
110
111
112perl v5.36.0                      2023-01-20              Net::Server::Coro(3)
Impressum