ernie 0.3.2 → 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/VERSION.yml +1 -1
- data/bin/ernie +2 -1
- data/elib/asset_pool.erl +7 -1
- data/elib/ernie_server.erl +8 -0
- data/ernie.gemspec +1 -1
- metadata +1 -1
data/VERSION.yml
CHANGED
data/bin/ernie
CHANGED
@@ -68,9 +68,10 @@ OptionParser.new do |opts|
|
|
68
68
|
end.parse!
|
69
69
|
|
70
70
|
if command = ARGV[0]
|
71
|
-
if !%w{reload-handlers}.include?(command)
|
71
|
+
if !%w{reload-handlers stats}.include?(command)
|
72
72
|
puts "Invlalid command. Valid commands are:"
|
73
73
|
puts " reload-handlers"
|
74
|
+
puts " stats"
|
74
75
|
exit(1)
|
75
76
|
end
|
76
77
|
|
data/elib/asset_pool.erl
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
-behaviour(gen_server).
|
3
3
|
|
4
4
|
%% api
|
5
|
-
-export([start_link/1, start/1, lease/0, return/1, reload_assets/0]).
|
5
|
+
-export([start_link/1, start/1, lease/0, return/1, reload_assets/0, idle_worker_count/0]).
|
6
6
|
|
7
7
|
%% gen_server callbacks
|
8
8
|
-export([init/1, handle_call/3, handle_cast/2, handle_info/2,
|
@@ -31,6 +31,9 @@ return(Asset) ->
|
|
31
31
|
reload_assets() ->
|
32
32
|
gen_server:call({global, ?MODULE}, {reload_assets}).
|
33
33
|
|
34
|
+
idle_worker_count() ->
|
35
|
+
gen_server:call({global, ?MODULE}, {idle_worker_count}).
|
36
|
+
|
34
37
|
%%====================================================================
|
35
38
|
%% gen_server callbacks
|
36
39
|
%%====================================================================
|
@@ -91,6 +94,9 @@ handle_call({return, Asset}, _From, State) ->
|
|
91
94
|
handle_call({reload_assets}, _From, State) ->
|
92
95
|
Token = make_ref(),
|
93
96
|
{reply, ok, State#state{token = Token}};
|
97
|
+
handle_call({idle_worker_count}, _From, State) ->
|
98
|
+
WorkerCount = queue:len(State#state.assets),
|
99
|
+
{reply, WorkerCount, State};
|
94
100
|
handle_call(_Request, _From, State) ->
|
95
101
|
{reply, ok, State}.
|
96
102
|
|
data/elib/ernie_server.erl
CHANGED
@@ -126,6 +126,14 @@ process_admin(Sock, reload_handlers, _Args, State) ->
|
|
126
126
|
gen_tcp:send(Sock, term_to_binary({reply, <<"Handlers reloaded.">>})),
|
127
127
|
ok = gen_tcp:close(Sock),
|
128
128
|
State;
|
129
|
+
process_admin(Sock, stats, _Args, State) ->
|
130
|
+
IdleWorkers = asset_pool:idle_worker_count(),
|
131
|
+
IdleWorkersString = list_to_binary([<<"idle workers: ">>, integer_to_list(IdleWorkers), <<"\n">>]),
|
132
|
+
QueueLength = queue:len(State#state.pending),
|
133
|
+
QueueLengthString = list_to_binary([<<"pending connections: ">>, integer_to_list(QueueLength), <<"\n">>]),
|
134
|
+
gen_tcp:send(Sock, term_to_binary({reply, list_to_binary([IdleWorkersString, QueueLengthString])})),
|
135
|
+
ok = gen_tcp:close(Sock),
|
136
|
+
State;
|
129
137
|
process_admin(Sock, _Fun, _Args, State) ->
|
130
138
|
gen_tcp:send(Sock, term_to_binary({reply, <<"Admin function not supported.">>})),
|
131
139
|
ok = gen_tcp:close(Sock),
|
data/ernie.gemspec
CHANGED