mirror of
https://github.com/ninenines/cowboy.git
synced 2025-07-14 12:20:24 +00:00
Make Cowboy an OTP application again, properly this time.
As requested by many people on IRC Cowboy is now a proper OTP application to support soft code upgrades. It should also be easier to start and stop listeners now using cowboy:start_listener/6 and cowboy:stop_listener/1.
This commit is contained in:
parent
e4da6956fc
commit
718baffa3c
5 changed files with 115 additions and 20 deletions
35
README.md
35
README.md
|
@ -33,8 +33,8 @@ Embedding Cowboy
|
||||||
Getting Started
|
Getting Started
|
||||||
---------------
|
---------------
|
||||||
|
|
||||||
Cowboy provides an anonymous listener supervisor that you can directly embed
|
Cowboy can be started and stopped like any other application. However, the
|
||||||
in your application's supervision tree.
|
Cowboy application do not start any listener, those must be started manually.
|
||||||
|
|
||||||
A listener is a special kind of supervisor that handles a pool of acceptor
|
A listener is a special kind of supervisor that handles a pool of acceptor
|
||||||
processes. It also manages all its associated request processes. This allows
|
processes. It also manages all its associated request processes. This allows
|
||||||
|
@ -48,25 +48,22 @@ before you can start a listener supervisor.
|
||||||
For HTTP applications the transport can be either TCP or SSL for HTTP and
|
For HTTP applications the transport can be either TCP or SSL for HTTP and
|
||||||
HTTPS respectively. On the other hand, the protocol is of course HTTP.
|
HTTPS respectively. On the other hand, the protocol is of course HTTP.
|
||||||
|
|
||||||
|
You can start and stop listeners by calling cowboy:start_listener and
|
||||||
|
cowboy:stop_listener respectively. It is your responsability to give each
|
||||||
|
listener a unique name.
|
||||||
|
|
||||||
Code speaks more than words:
|
Code speaks more than words:
|
||||||
|
|
||||||
-module(my_app).
|
application:start(cowboy),
|
||||||
-behaviour(application).
|
Dispatch = [
|
||||||
-export([start/2, stop/1]).
|
%% {Host, list({Path, Handler, Opts})}
|
||||||
|
{'_', [{'_', my_handler, []}]}
|
||||||
start(_Type, _Args) ->
|
],
|
||||||
Dispatch = [
|
%% Name, NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts
|
||||||
%% {Host, list({Path, Handler, Opts})}
|
cowboy:start_listener(http, 100,
|
||||||
{'_', [{'_', my_handler, []}]}
|
cowboy_tcp_transport, [{port, 8080}],
|
||||||
],
|
cowboy_http_protocol, [{dispatch, Dispatch}]
|
||||||
%% NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts
|
).
|
||||||
cowboy_listener_sup:start_link(100,
|
|
||||||
cowboy_tcp_transport, [{port, 8080}],
|
|
||||||
cowboy_http_protocol, [{dispatch, Dispatch}]
|
|
||||||
).
|
|
||||||
|
|
||||||
stop(_State) ->
|
|
||||||
ok.
|
|
||||||
|
|
||||||
You must also write the `my_handler` module to process requests. You can
|
You must also write the `my_handler` module to process requests. You can
|
||||||
use one of the predefined handlers or write your own. An hello world HTTP
|
use one of the predefined handlers or write your own. An hello world HTTP
|
||||||
|
|
|
@ -20,5 +20,7 @@
|
||||||
{applications, [
|
{applications, [
|
||||||
kernel,
|
kernel,
|
||||||
stdlib
|
stdlib
|
||||||
]}
|
]},
|
||||||
|
{mod, {cowboy_app, []}},
|
||||||
|
{env, []}
|
||||||
]}.
|
]}.
|
||||||
|
|
33
src/cowboy.erl
Normal file
33
src/cowboy.erl
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
%% Copyright (c) 2011, Loïc Hoguin <essen@dev-extend.eu>
|
||||||
|
%%
|
||||||
|
%% Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
%% purpose with or without fee is hereby granted, provided that the above
|
||||||
|
%% copyright notice and this permission notice appear in all copies.
|
||||||
|
%%
|
||||||
|
%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
-module(cowboy).
|
||||||
|
-export([start_listener/6, stop_listener/1]). %% API.
|
||||||
|
|
||||||
|
%% API.
|
||||||
|
|
||||||
|
-spec start_listener(Ref::term(), NbAcceptors::non_neg_integer(),
|
||||||
|
Transport::module(), TransOpts::term(), Protocol::module(),
|
||||||
|
ProtoOpts::term()) -> {ok, Pid::pid()}.
|
||||||
|
start_listener(Ref, NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts) ->
|
||||||
|
supervisor:start_child(cowboy_sup,
|
||||||
|
{{cowboy_listener_sup, Ref}, {cowboy_listener_sup, start_link, [
|
||||||
|
NbAcceptors, Transport, TransOpts, Protocol, ProtoOpts
|
||||||
|
]},
|
||||||
|
permanent, 5000, supervisor, [cowboy_listener_sup]}).
|
||||||
|
|
||||||
|
-spec stop_listener(Ref::term()) -> ok.
|
||||||
|
stop_listener(Ref) ->
|
||||||
|
supervisor:terminate_child(cowboy_sup, {cowboy_listener_sup, Ref}),
|
||||||
|
supervisor:delete_child(cowboy_sup, {cowboy_listener_sup, Ref}).
|
30
src/cowboy_app.erl
Normal file
30
src/cowboy_app.erl
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
%% Copyright (c) 2011, Loïc Hoguin <essen@dev-extend.eu>
|
||||||
|
%%
|
||||||
|
%% Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
%% purpose with or without fee is hereby granted, provided that the above
|
||||||
|
%% copyright notice and this permission notice appear in all copies.
|
||||||
|
%%
|
||||||
|
%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
-module(cowboy_app).
|
||||||
|
-behaviour(application).
|
||||||
|
|
||||||
|
-export([start/2, stop/1]). %% API.
|
||||||
|
|
||||||
|
-include("include/types.hrl").
|
||||||
|
|
||||||
|
%% API.
|
||||||
|
|
||||||
|
-spec start(Type::application_start_type(), Args::term()) -> {ok, Pid::pid()}.
|
||||||
|
start(_Type, _Args) ->
|
||||||
|
cowboy_sup:start_link().
|
||||||
|
|
||||||
|
-spec stop(State::term()) -> ok.
|
||||||
|
stop(_State) ->
|
||||||
|
ok.
|
33
src/cowboy_sup.erl
Normal file
33
src/cowboy_sup.erl
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
%% Copyright (c) 2011, Loïc Hoguin <essen@dev-extend.eu>
|
||||||
|
%%
|
||||||
|
%% Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
%% purpose with or without fee is hereby granted, provided that the above
|
||||||
|
%% copyright notice and this permission notice appear in all copies.
|
||||||
|
%%
|
||||||
|
%% THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
%% WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
%% MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
%% ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
%% WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
%% ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
%% OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
-module(cowboy_sup).
|
||||||
|
-behaviour(supervisor).
|
||||||
|
|
||||||
|
-export([start_link/0]). %% API.
|
||||||
|
-export([init/1]). %% supervisor.
|
||||||
|
|
||||||
|
-define(SUPERVISOR, ?MODULE).
|
||||||
|
|
||||||
|
%% API.
|
||||||
|
|
||||||
|
-spec start_link() -> {ok, Pid::pid()}.
|
||||||
|
start_link() ->
|
||||||
|
supervisor:start_link({local, ?SUPERVISOR}, ?MODULE, []).
|
||||||
|
|
||||||
|
%% supervisor.
|
||||||
|
|
||||||
|
-spec init([]) -> term(). %% @todo These specs should be improved.
|
||||||
|
init([]) ->
|
||||||
|
{ok, {{one_for_one, 10, 10}, []}}.
|
Loading…
Add table
Add a link
Reference in a new issue