confusing returns from httpc:request/4

amitm amit.murthy@REDACTED
Thu Oct 21 16:06:46 CEST 2010


> Humm ... what settings did you have when you had the problem?

The function making the call in the situation when the problem
manifests itself is:

mkGetReq2(GetUrl) ->
    GetRequest = {GetUrl, []},
    GetHttpOptions = [{autoredirect, true}],
    Options = [ {sync,true}, {headers_as_is,true}, {body_format,
binary} ],
    httpc:request(get, GetRequest, GetHttpOptions, Options).

No other options were set, which means they run with their default
values.

> Did you set the pipeline timout ?

No pipeline timeout was set.

> What webserver did you connect to (apache, yaws, ...)?

The webserver is one used by Amazon internally on EC2. Curl in verbose
mode, as executed by the command
"curl -v http://169.254.169.254/2009-04-04/meta-data/instance-id "
prints out

  * About to connect() to 169.254.169.254 port 80 (#0)
  *   Trying 169.254.169.254... connected
  * Connected to 169.254.169.254 (169.254.169.254) port 80 (#0)
  > GET /2009-04-04/meta-data/instance-id HTTP/1.1
  > User-Agent: curl/7.19.7 (i486-pc-linux-gnu) libcurl/7.19.7 OpenSSL/
0.9.8k zlib/1.2.3.3 libidn/1.15
  > Host: 169.254.169.254
  > Accept: */*
  >
  * HTTP 1.0, assume close after body
  < HTTP/1.0 200 OK
  < Content-Type: text/plain
  < Accept-Ranges: bytes
  < ETag: "-1124024050"
  < Last-Modified: Tue, 19 Oct 2010 13:58:54 GMT
  < Content-Length: 10
  < Connection: close
  < Date: Thu, 21 Oct 2010 13:48:19 GMT
  < Server: EC2ws
  <
  * Closing connection #0

> What version of inets?

erl -v prints
"Erlang R14B (erts-5.8.1) [source] [rq:1] [async-threads:0] [kernel-
poll:false]"

Hope it helps,

  Amit


On Oct 21, 6:32 pm, Ingela Andin <ingela.an...@REDACTED> wrote:
> Hi!
>
> Humm ... what settings did you have when you had the problem?
> Did you set the pipeline timout ? What webserver did you connect to
> (apache, yaws, ...)? What
> version of inets? If there is some bug in the pipeling or
> persistenconnection code
> of course we would like to know so that we can fix it.
>
> Regards Ingela Erlang/OTP team - Ericsson AB
>
> 2010/10/20 amitm <amit.mur...@REDACTED>:
>
>
>
>
>
> > FWIW, I had a similar problem. It went away when I disabled pipelining
> > completely by executing
>
> >    ok = httpc:set_options([{max_keep_alive_length, 0},
> > {max_pipeline_length, 0}, {max_sessions, 0} ]),
>
> > before my http calls. I used to usually see it on the 4th consecutive
> > call to the same host when pipelining was enabled. The URL in question
> > in my case was an Amazon EC2 url.
>
> > The set of URLs in my case were
>
> > "http://169.254.169.254/2009-04-04/meta-data/instance-id",
> > "http://169.254.169.254/2009-04-04/meta-data/local-hostname",
> > "http://169.254.169.254/2009-04-04/meta-data/local-ipv4",
> > "http://169.254.169.254/2009-04-04/meta-data/public-hostname",
> > "http://169.254.169.254/2009-04-04/meta-data/public-ipv4",
> > "http://169.254.169.254/2009-04-04/meta-data/ami-id",
>
> > While executing this set, with pipelining enabled, it used to always
> > bomb on the 4th URL, i.e. for 'public-hostname' in 25% of the cases
>
> > with pipelining disabled, the problem disappears.
>
> >  Amit
>
> > On Oct 13, 2:58 pm, Ingela Andin <ingela.an...@REDACTED> wrote:
> >> 2010/10/13 Chandru <chandrashekhar.mullapar...@REDACTED>:
>
> >> > On 13 October 2010 09:53, Ingela Andin <ingela.an...@REDACTED> wrote:
> >> >> Hi!
>
> >> >> The only reason that the httpc-client will return the value {error,
> >> >> socket_closed_remotely}
> >> >> is that the connection is prematurely  closed by the server.
> >> >> Unfortunately  that something
> >> >> is sent on a tcp socket does not mean it has been sent on the wire
> >> >> yet, and depending on
> >> >> the circumstances it is possible for the socket to be closed before
> >> >> all data has been sent
> >> >> so occasionally a tcp_close can come before all data is delivered.
>
> >> >> When you use ibrowse do you verify that you always get a correct body?
> >> >> (compleate body) from what I can tell from the code ibrowse will on a
> >> >> tcp_closed  message always return whatever happens to be in the buffer
> >> >> compleate or not.
>
> >> > ibrowse does this only in the following cases:
> >> >  * server returned a "Connection: Close"
> >> >  * Server supports HTTP/0.9 or HTTP/1.0
>
> >> > In all other cases, it returns an error to the caller.
>
> >> > regards,
> >> > Chandru
>
> >> Well I do not know if any of these things is true in Dans senario. But
> >> I do know that
> >> getting the problem with a tcp close message before all data is
> >> deliverd is a highly timing dependant problem
> >> and if it happens in the server there is nothing inets-client or
> >> ibrows can do about it except return an error.
>
> >> Regards Ingela Erlang/OTP team - Ericsson AB
>
> >> ________________________________________________________________
> >> erlang-questions (at) erlang.org mailing list.
> >> Seehttp://www.erlang.org/faq.html
> >> To unsubscribe; mailto:erlang-questions-unsubscr...@REDACTED
>
> > ________________________________________________________________
> > erlang-questions (at) erlang.org mailing list.
> > Seehttp://www.erlang.org/faq.html
> > To unsubscribe; mailto:erlang-questions-unsubscr...@REDACTED
>
> ________________________________________________________________
> erlang-questions (at) erlang.org mailing list.
> Seehttp://www.erlang.org/faq.html
> To unsubscribe; mailto:erlang-questions-unsubscr...@REDACTED


More information about the erlang-questions mailing list