All of lore.kernel.org
 help / color / mirror / Atom feed
* Trying to export per process network bandwidth stats under /proc/[pid]/
@ 2018-07-14  3:24 Amos Bird
  2018-07-14  6:41 ` Greg KH
  0 siblings, 1 reply; 2+ messages in thread
From: Amos Bird @ 2018-07-14  3:24 UTC (permalink / raw)
  To: kernelnewbies

Hello!

I'm trying to add a proc entry under /proc/[pid] in order to get 
per process network bandwidth stats. I suppose it's similar to 
/proc/[pid]/io . However I couldn't find a modular way to add 
entries under /proc/[pid]. This thread 
https://lists.kernelnewbies.org/pipermail/kernelnewbies/2011-January/000475.html 
suggests modifying the kernel which isn't practical to me. Here is 
what I've found by going through a bit of the related kernel code.

1. I need to find a way to override or hooking 
`sock_sendmsg`/`sock_recvmsg` functions with accounting variables 
like `task_io_accounting`
2. a way to add proc entries under /proc/[pid] with readops 
printing `current` netio accounting variables.

Am I on the right path of implementing this? Thanks!

--
Amos Bird
amosbird at gmail.com

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Trying to export per process network bandwidth stats under /proc/[pid]/
  2018-07-14  3:24 Trying to export per process network bandwidth stats under /proc/[pid]/ Amos Bird
@ 2018-07-14  6:41 ` Greg KH
  0 siblings, 0 replies; 2+ messages in thread
From: Greg KH @ 2018-07-14  6:41 UTC (permalink / raw)
  To: kernelnewbies

On Sat, Jul 14, 2018 at 11:24:23AM +0800, Amos Bird wrote:
> Hello!
> 
> I'm trying to add a proc entry under /proc/[pid] in order to get per process
> network bandwidth stats. I suppose it's similar to /proc/[pid]/io . However
> I couldn't find a modular way to add entries under /proc/[pid]. This thread https://lists.kernelnewbies.org/pipermail/kernelnewbies/2011-January/000475.html
> suggests modifying the kernel which isn't practical to me. Here is what I've
> found by going through a bit of the related kernel code.
> 
> 1. I need to find a way to override or hooking `sock_sendmsg`/`sock_recvmsg`
> functions with accounting variables like `task_io_accounting`
> 2. a way to add proc entries under /proc/[pid] with readops printing
> `current` netio accounting variables.
> 
> Am I on the right path of implementing this? Thanks!

Please don't do this in /proc, that way lies madness.  There is code in
the android kernel tree that adds this type of process accounting to the
kernel, you should look at that.  It's been rejected by upstream for
valid reasons, which you should be aware of, and is currently being
rewritten to use ebpf, which might be the better solution for you in the
long run.

And yes, you will have to modify the kernel to try to achieve this, but
it's better to just go grab the android code if you want to see how this
is done instead of trying to do it on your own from scratch.

hope this helps,

greg k-h

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2018-07-14  6:41 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-07-14  3:24 Trying to export per process network bandwidth stats under /proc/[pid]/ Amos Bird
2018-07-14  6:41 ` Greg KH

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.