Skip to content

Commit

Permalink
tcp stat ipv4
Browse files Browse the repository at this point in the history
  • Loading branch information
askuy committed Jun 6, 2024
1 parent 342129c commit 906fb4d
Show file tree
Hide file tree
Showing 3 changed files with 80 additions and 14 deletions.
10 changes: 5 additions & 5 deletions core/emetric/metric.go
Original file line number Diff line number Diff line change
Expand Up @@ -137,11 +137,11 @@ var (
}.Build()

// ConnGauge ...
ConnGauge = GaugeVecOpts{
Namespace: DefaultNamespace,
Name: "connection_states",
Labels: []string{"state"},
}.Build()
//ConnGauge = GaugeVecOpts{
// Namespace: DefaultNamespace,
// Name: "connection_states",
// Labels: []string{"state", "addr"},
//}.Build()
)

func init() {
Expand Down
68 changes: 59 additions & 9 deletions core/emetric/tcpstat.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,11 @@
package emetric

import (
"encoding/binary"
"encoding/hex"
"fmt"
"io"
"net"
"os"
"path"
"strconv"
Expand Down Expand Up @@ -72,10 +75,14 @@ func (c *TcpStatCollector) Update() error {
return
}
for {
for name, value := range tcpStats {
ConnGauge.WithLabelValues(
name.String(),
).Set(value)
for index, value := range tcpStats {
for addr, number := range value {
ClientStatsGauge.WithLabelValues(
"conn_states",
addr,
index.String(),
).Set(number)
}
time.Sleep(5 * time.Second)
}
}
Expand All @@ -100,7 +107,7 @@ func (c *TcpStatCollector) Update() error {
return nil
}

func getTCPStats(statsFile string) (map[tcpConnectionState]float64, error) {
func getTCPStats(statsFile string) (map[tcpConnectionState]map[string]float64, error) {
file, err := os.Open(statsFile)
if err != nil {
return nil, err
Expand All @@ -110,8 +117,19 @@ func getTCPStats(statsFile string) (map[tcpConnectionState]float64, error) {
return parseTCPStats(file)
}

func parseTCPStats(r io.Reader) (map[tcpConnectionState]float64, error) {
tcpStats := map[tcpConnectionState]float64{}
/*
46: 010310AC:9C4C 030310AC:1770 01
| | | | | |--> connection state(套接字状态)
| | | | |------> remote TCP port number(远端端口,主机字节序)
| | | |-------------> remote IPv4 address(远端IP,网络字节序)
| | |--------------------> local TCP port number(本地端口,主机字节序)
| |---------------------------> local IPv4 address(本地IP,网络字节序)
|----------------------------------> number of entry
*/

func parseTCPStats(r io.Reader) (map[tcpConnectionState]map[string]float64, error) {
//tcpStats := map[tcpConnectionState]float64{}
tcpStatsMap := map[tcpConnectionState]map[string]float64{}
contents, err := io.ReadAll(r)
if err != nil {
return nil, err
Expand Down Expand Up @@ -143,16 +161,25 @@ func parseTCPStats(r io.Reader) (map[tcpConnectionState]float64, error) {
//}
//tcpStats[tcpConnectionState(tcpRxQueuedBytes)] += float64(rx)

ipv4, _ := parseIpV4(parts[2])
st, err := strconv.ParseInt(parts[3], 16, 8)
if err != nil {
return nil, err
}

tcpStats[tcpConnectionState(st)]++
info, flag := tcpStatsMap[tcpConnectionState(st)]
if !flag {
info[ipv4] = 1
} else {
info[ipv4]++
}
tcpStatsMap[tcpConnectionState(st)] = info

//tcpStats[tcpConnectionState(st)]++

}

return tcpStats, nil
return tcpStatsMap, nil
}

func (st tcpConnectionState) String() string {
Expand Down Expand Up @@ -187,3 +214,26 @@ func (st tcpConnectionState) String() string {
return "unknown"
}
}

// 只解析IPV4
// 34190A0A:3D2D
func parseIpV4(s string) (string, error) {
if len(s) == 13 {
return "", fmt.Errorf("not ipv4")
}
hexIP := s[:len(s)-5]
hexPort := s[len(s)-4:]
bytesIP, err := hex.DecodeString(hexIP)
if err != nil {
return "", nil
}
uint32IP := binary.LittleEndian.Uint32(bytesIP) //转换为主机字节序
IP := make(net.IP, 4)
binary.BigEndian.PutUint32(IP, uint32IP)
port, err := strconv.ParseUint(hexPort, 16, 16)
return fmt.Sprintf("%s:%d", IP.String(), port), err
}

//func parsePort(portStr string) (int64, error) {
// return strconv.ParseInt(portStr, 16, 16)
//}
16 changes: 16 additions & 0 deletions core/emetric/tcpstat_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package emetric

import (
"testing"

"github.com/stretchr/testify/assert"
)

func Test_parsePort(t *testing.T) {
//got, err := parsePort("18EB")
//assert.Equal(t, nil, err)
//assert.Equal(t, 6379, got)
got1, err1 := parseIpV4("95141EAC:18EB")
assert.Equal(t, nil, err1)
assert.Equal(t, 6379, string(got1))
}

0 comments on commit 906fb4d

Please sign in to comment.