init.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package ebpftracer
  2. import (
  3. "github.com/coroot/coroot-node-agent/proc"
  4. "k8s.io/klog/v2"
  5. "os"
  6. "path"
  7. "strconv"
  8. "strings"
  9. )
  10. type fd struct {
  11. pid uint32
  12. fd uint32
  13. }
  14. type sock struct {
  15. pid uint32
  16. proc.Sock
  17. }
  18. func readFds(pids []uint32) (fds []fd, socks []sock) {
  19. nss := map[string]map[string]sock{}
  20. for _, pid := range pids {
  21. ns, err := proc.GetNetNs(pid)
  22. if err != nil {
  23. continue
  24. }
  25. nsId := ns.UniqueId()
  26. sockets, ok := nss[nsId]
  27. _ = ns.Close()
  28. if !ok {
  29. sockets = map[string]sock{}
  30. nss[nsId] = sockets
  31. if ss, err := proc.GetSockets(pid); err != nil {
  32. klog.Warningln(err)
  33. } else {
  34. for _, s := range ss {
  35. sockets[s.Inode] = sock{Sock: s}
  36. }
  37. }
  38. }
  39. fdDir := proc.Path(pid, "fd")
  40. entries, err := os.ReadDir(fdDir)
  41. if err != nil {
  42. continue
  43. }
  44. for _, entry := range entries {
  45. dest, err := os.Readlink(path.Join(fdDir, entry.Name()))
  46. if err != nil {
  47. continue
  48. }
  49. switch {
  50. case strings.HasPrefix(dest, "socket:[") && strings.HasSuffix(dest, "]"):
  51. inode := dest[len("socket:[") : len(dest)-1]
  52. if s, ok := sockets[inode]; ok {
  53. s.pid = pid
  54. socks = append(socks, s)
  55. }
  56. default:
  57. i, err := strconv.Atoi(entry.Name())
  58. if err == nil {
  59. fds = append(fds, fd{pid: pid, fd: uint32(i)})
  60. }
  61. }
  62. }
  63. }
  64. return
  65. }