Return-Path: Delivered-To: apmail-couchdb-commits-archive@www.apache.org Received: (qmail 25437 invoked from network); 1 Feb 2009 02:43:25 -0000 Received: from hermes.apache.org (HELO mail.apache.org) (140.211.11.2) by minotaur.apache.org with SMTP; 1 Feb 2009 02:43:25 -0000 Received: (qmail 91995 invoked by uid 500); 1 Feb 2009 02:43:24 -0000 Delivered-To: apmail-couchdb-commits-archive@couchdb.apache.org Received: (qmail 91969 invoked by uid 500); 1 Feb 2009 02:43:24 -0000 Mailing-List: contact commits-help@couchdb.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@couchdb.apache.org Delivered-To: mailing list commits@couchdb.apache.org Received: (qmail 91960 invoked by uid 99); 1 Feb 2009 02:43:24 -0000 Received: from nike.apache.org (HELO nike.apache.org) (192.87.106.230) by apache.org (qpsmtpd/0.29) with ESMTP; Sat, 31 Jan 2009 18:43:24 -0800 X-ASF-Spam-Status: No, hits=-2000.0 required=10.0 tests=ALL_TRUSTED X-Spam-Check-By: apache.org Received: from [140.211.11.4] (HELO eris.apache.org) (140.211.11.4) by apache.org (qpsmtpd/0.29) with ESMTP; Sun, 01 Feb 2009 02:43:22 +0000 Received: by eris.apache.org (Postfix, from userid 65534) id 38FE5238889E; Sun, 1 Feb 2009 02:43:01 +0000 (UTC) Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Subject: svn commit: r739681 - in /couchdb/trunk/src/couchdb: couch_external_manager.erl couch_external_server.erl Date: Sun, 01 Feb 2009 02:43:00 -0000 To: commits@couchdb.apache.org From: jchris@apache.org X-Mailer: svnmailer-1.0.8 Message-Id: <20090201024301.38FE5238889E@eris.apache.org> X-Virus-Checked: Checked by ClamAV on apache.org Author: jchris Date: Sun Feb 1 02:43:00 2009 New Revision: 739681 URL: http://svn.apache.org/viewvc?rev=739681&view=rev Log: via davisp: external server launches on request to avoid runaway errors. Modified: couchdb/trunk/src/couchdb/couch_external_manager.erl couchdb/trunk/src/couchdb/couch_external_server.erl Modified: couchdb/trunk/src/couchdb/couch_external_manager.erl URL: http://svn.apache.org/viewvc/couchdb/trunk/src/couchdb/couch_external_manager.erl?rev=739681&r1=739680&r2=739681&view=diff ============================================================================== --- couchdb/trunk/src/couchdb/couch_external_manager.erl (original) +++ couchdb/trunk/src/couchdb/couch_external_manager.erl Sun Feb 1 02:43:00 2009 @@ -19,7 +19,8 @@ -include("couch_db.hrl"). start_link() -> - gen_server:start_link({local, couch_external_manager}, couch_external_manager, [], []). + gen_server:start_link({local, couch_external_manager}, + couch_external_manager, [], []). execute(UrlName, JsonReq) -> Pid = gen_server:call(couch_external_manager, {get, UrlName}), @@ -37,10 +38,6 @@ init([]) -> Handlers = ets:new(couch_external_manager_handlers, [set, private]), - lists:foreach(fun({UrlName, Command}) -> - {ok, Pid} = couch_external_server:start_link(UrlName, Command), - true = ets:insert(Handlers, {UrlName, Pid}) - end, couch_config:get("external")), couch_config:register(fun config_change/2), {ok, Handlers}. @@ -52,14 +49,21 @@ ok. handle_call({get, UrlName}, _From, Handlers) -> - Resp = case ets:lookup(Handlers, UrlName) of - [{UrlName, Pid}] -> - Pid; + case ets:lookup(Handlers, UrlName) of [] -> - Mesg = lists:flatten(io_lib:format("No server configured for ~p.", [UrlName])), - {error, {unknown_external_server, Mesg}} - end, - {reply, Resp, Handlers}; + case couch_config:get("external", UrlName, nil) of + nil -> + Mesg = lists:flatten( + io_lib:format("No server configured for ~p.", [UrlName])), + {reply, {error, {unknown_external_server, Mesg}}, Handlers}; + Command -> + {ok, NewPid} = couch_external_server:start_link(UrlName, Command), + true = ets:insert(Handlers, {UrlName, NewPid}), + {reply, NewPid, Handlers} + end; + [{UrlName, Pid}] -> + {reply, Pid, Handlers} + end; handle_call({config, UrlName}, _From, Handlers) -> % A newly added handler and a handler that had it's command % changed are treated exactly the same. @@ -68,25 +72,17 @@ case ets:lookup(Handlers, UrlName) of [{UrlName, Pid}] -> couch_external_server:stop(Pid); - _ -> + [] -> ok end, - case couch_config:get("external", UrlName, nil) of - % Handler no longer exists - nil -> - ok; - % New handler start up. - Command -> - {ok, NewPid} = couch_external_server:start_link(UrlName, Command), - true = ets:insert(Handlers, {Command, NewPid}) - end, + % Wait for next request to boot the handler. {reply, ok, Handlers}. handle_cast(_Whatever, State) -> {noreply, State}. handle_info({'EXIT', Reason, Pid}, Handlers) -> - ?LOG_DEBUG("External server ~p died. (reason: ~p)", [Pid, Reason]), + ?LOG_DEBUG("EXTERNAL: Server ~p died. (reason: ~p)", [Pid, Reason]), % Remove Pid from the handlers table so we don't try closing % it a second time in terminate/2. ets:match_delete(Handlers, {'_', Pid}), Modified: couchdb/trunk/src/couchdb/couch_external_server.erl URL: http://svn.apache.org/viewvc/couchdb/trunk/src/couchdb/couch_external_server.erl?rev=739681&r1=739680&r2=739681&view=diff ============================================================================== --- couchdb/trunk/src/couchdb/couch_external_server.erl (original) +++ couchdb/trunk/src/couchdb/couch_external_server.erl Sun Feb 1 02:43:00 2009 @@ -16,8 +16,6 @@ -export([start_link/2, stop/1, execute/2]). -export([init/1, terminate/2, handle_call/3, handle_cast/2, handle_info/2, code_change/3]). --define(TIMEOUT, 5000). - -include("couch_db.hrl"). % External API @@ -34,12 +32,12 @@ % Gen Server Handlers init([Name, Command]) -> - ?LOG_INFO("Starting process for: ~s", [Name]), + ?LOG_INFO("EXTERNAL: Starting process for: ~s", [Name]), + ?LOG_INFO("COMMAND: ~s", [Command]), {ok, Pid} = couch_os_process:start_link(Command), {ok, {Name, Command, Pid}}. -terminate(_Reason, {Name, _Command, Pid}) -> - ?LOG_INFO("External Process Terminating: ~p: ~p", [Name, Pid]), +terminate(_Reason, {_Name, _Command, Pid}) -> couch_os_process:stop(Pid), ok. @@ -47,12 +45,13 @@ {reply, couch_os_process:prompt(Pid, JsonReq), {Name, Command, Pid}}. handle_info({'EXIT', Pid, Reason}, {Name, Command, Pid}) -> - ?LOG_INFO("EXTERNAL: Restarting process for ~s (reason: ~w)", [Name, Reason]), - {ok, Pid} = couch_os_process:start_link(Command), - {noreply, {Name, Command, Pid}}. + ?LOG_INFO("EXTERNAL: Process for ~s exiting. (reason: ~w)", [Name, Reason]), + {stop, normal, {Name, Command, Pid}}. -handle_cast(stop, State) -> - {stop, normal, State}; +handle_cast(stop, {Name, Command, Pid}) -> + ?LOG_INFO("EXTERNAL: Shutting down ~s", [Name]), + exit(Pid, normal), + {stop, normal, {Name, Command, Pid}}; handle_cast(_Whatever, State) -> {noreply, State}.