Who is your target audience for this?

You seem to know how to do it (socat + go tool pprof), which suggests you
want end users to do this or something?


On Fri, Jul 29, 2016 at 3:43 PM, nathan.leclaire via golang-nuts <
golang-nuts@googlegroups.com> wrote:

> Hi all,
>
> I am interested in doing performance profiling on the Docker daemon using
> the existing pprof tools and/or code inside of the internal packages of
> commands, and I was hoping to get some guidance on the challenges I've
> encountered attempting this.
>
> The Docker daemon (a Go program) exposes the pprof endpoints at
> /debug/pprof.  However, by default the Docker daemon only listens on a
> Unix domain socket to expose its HTTP API, and exposing it over a
> non-encrypted TCP port is generally inadvisable due to privilege escalation
> concerns.
>
> The current most common method for accessing this pprof information seems
> to be to use socat to temporarily forward requests from the socket to a
> locally listening TCP port, and use go tool pprof to collect profile
> information and analyze it.  This works OK for local development, but I
> have a few questions about how we might be able to expand support for
> collecting these pprof dumps and analyzing them more easily:
>
> 1. Would a proposal be considered to add support for collecting this
> information directly through go tool pprof , e.g. go tool pprof
> unix:///var/run/docker.sock, or is it not an area of interest for the Go
> tools?  Some possible dilemmas include the unix:// protocol convention,
> which seems to be fairly Docker-unique to me and a little odd to conflate
> (transport layer vs. protocol) with http://.  I've looked extensively at
> the code and it doesn't seem to cover this today.
> 2. Is it possible to install and use go tool pprof in a minimal manner,
> i.e. without the rest of the Golang toolchain?  If so, how?
> 3. How inadvisable would it be to use the internal code for generating 
> *Profile
> and symbolizing the profiles in a 3rd party program?  Obviously due to the
> internal it's not meant to be exported but it would be very nice to be
> able to directly embed this type of code in a library-like fashion to be
> able to quickly generate dumps from running daemons that could later be
> loaded with rich semantic information into go tool pprof on another
> computer (without also needing the source binary).  Naturally it's
> *possible* to just cp and vendor the code from the stdlib and work around
> this restriction, but is it advisable?
> 4. Any other ideas for getting a easily importable stand-alone *.pb.gz
> pprof output from inside of an exiting Go program (separate from the one
> that is being profiled)?  I had an idea to make a minimal Go program (or
> embed in an existing one) which might be quite good at this, but getting
> richly annotated information (including symbols, etc.) via HTTP alone
> without any of the surrounding internal code to process it has proven a lot
> trickier than I naively assumed at first.
>
> Thanks all, and thanks of course for go tool pprof in the first place,
> it's a really excellent tool.
>
> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to