gpt4 book ai didi

powershell - 带 powershell 的 Graphite

转载 作者:可可西里 更新时间:2023-11-01 02:31:43 26 4
gpt4 key购买 nike

我在一台服务器上配置了一个 Graphite 实例,我正在使用它来监控我的环境,遗憾的是它同时包含 Linux 和 Windows 机器。我想监控我的服务器的健康状况,所以我在我的 Linux 机器上选择了 collectl,它可以很好地收集系统统计信息。

可悲的是,对于 Windows,似乎没有那么多的解决方案来获取系统统计信息并将它们发送到 Graphite,但我已经设法使用 powershell 处理了这种情况。我正在使用此处建议的脚本 http://josh.behrends.us/2012/07/windows-powershell-graphite-awesome/用于 Graphite 连接,也用于从计算机中获取指标我正在使用 get-counter comandlet,令人惊讶的是,它可以收集大量信息。

我的脚本是这样的:

while (1 -eq 1)
{
$carbonServer = "hostname"
$carbonServerPort = 2003
$epochtime = [int][double]::Parse((Get-Date -UFormat %s))

$socket = New-Object System.Net.Sockets.TCPClient
$socket.connect($carbonServer, $carbonServerPort)
$stream = $socket.GetStream()
$writer = new-object System.IO.StreamWriter($stream)
#Write out metric to the stream.

$DiskQue = [int]((get-counter -Counter "\PhysicalDisk(1 e: f:)\Current Disk Queue Length" ).countersamples | select -property cookedvalue).cookedvalue
$BytesReceived = [int]((get-counter -Counter "\Server\Bytes Received/sec" ).countersamples | select -property cookedvalue).cookedvalue
$BytesSent = [int]((get-counter -Counter "\Server\Bytes Transmitted/sec").countersamples | select -property cookedvalue).cookedvalue
$MemAvail = ((get-counter -Counter "\Memory\Available Bytes").countersamples | select -property cookedvalue).cookedvalue
$MemCommit = ((get-counter -Counter "\Memory\Committed Bytes").countersamples | select -property cookedvalue).cookedvalue
$ReadOp = [int]((get-counter -Counter "\System\File Read Operations/sec").countersamples | select -property cookedvalue).cookedvalue
$WriteOp = [int]((get-counter -Counter "\System\File Write Operations/sec").countersamples | select -property cookedvalue).cookedvalue

$metric7 = ("hostname.metrics.WriteOp " + $WriteOp + " " + $epochTime+"`n")
$metric7

$writer.WriteLine($metric7)
$writer.Flush() #Flush and write our metrics.
$writer.Close()
$stream.Close()
sleep 5
}

现在,这个脚本输出了乍一看应该输出的内容。输出的格式为 hostname.metrics.name $metric_value $epochTime 但没有绘制图表。它们出现在 Graphite 仪表板中,但它们是空的。我已经使用 wireshark 检查了发送到 Graphite 服务器的输出。它接缝在 Windows 中,消息附加了 CRLF,而不是在只有 LF 的 linux 中。我手动添加了 \n 并在一小段时间内成功了,但现在它停止工作了。

我的问题是我在传输中做错了什么,因为我一直在分析流量,来自 linux 机器的流量之间的唯一区别是图形化的和来自没有图形化的窗口的是行终止符。在 linux 中它的 LF(0a) 在 windows 中是 CRLF(0d0a),但我再次尝试从 linux LFCRLF(0a0d0a) 发送希望 Graphite 服务器只读到第一个 LF,而不是解释消息,但我仍然没有得到图表。

此外,当我从 linux 传输时,我只有一条消息,而当我从 powershell 传输时,我有三条消息。从我在 carbon-cache 进程上用 strace 看到的情况来看,我有一个 recvfrom 系统调用,其中包含我想要的消息,而我有另一个是空的,而 write 系统调用(当从 powershell 传输时)与你相反只有一个 recvfrom 消息和一个 write(在 linux 上用 netcat 传输时),

最佳答案

似乎没有人提供任何建议,因此我采用了另一种方法。我仍然很好奇为什么 Graphite 不解释我发送的消息。这个问题的解决方案是使用 UDP 套接字而不是 TCP 套接字,并将指标发送到 statsd,后者又将它们发送到 Graphite。这似乎没有任何复杂性,并且如果您考虑它,它对您的网络更好,因为它最大限度地减少了流量(如果您将 statsd 和 Graphite 保持在同一节点上)。

我正在发布脚本,以防有人遇到我的问题并且他的环境与我的相似。这是脚本

[int] $Port = 8125
$IP = "here is your IP"
$Address = [system.net.IPAddress]::Parse($IP)
$End = New-Object System.Net.IPEndPoint $address, $port
$Saddrf = [System.Net.Sockets.AddressFamily]::InterNetwork
$Stype = [System.Net.Sockets.SocketType]::Dgram
$Ptype = [System.Net.Sockets.ProtocolType]::UDP
$Sock = New-Object System.Net.Sockets.Socket $saddrf, $stype, $ptype
$sock.Connect($end)

function Send_Graphite
{param ($Metric)

$Enc = [System.Text.Encoding]::ASCII
$Buffer = $Enc.GetBytes($Metric)
$Sent = $Sock.Send($Buffer)
"{0} characters sent to: {1} " -f $Sent,$IP
"Message is:"
$Metric
sleep 1

}

while (1 -eq 1)
{
$DiskQue = [int]((get-counter -Counter "\PhysicalDisk(1 e: f:)\Current Disk Queue Length" ).countersamples | select -property cookedvalue).cookedvalue
$BytesReceived = [int]((get-counter -Counter "\Server\Bytes Received/sec" ).countersamples | select -property cookedvalue).cookedvalue
$BytesSent = [int]((get-counter -Counter "\Server\Bytes Transmitted/sec").countersamples | select -property cookedvalue).cookedvalue
$MemAvail = ((get-counter -Counter "\Memory\Available Bytes").countersamples | select -property cookedvalue).cookedvalue
$MemCommit = ((get-counter -Counter "\Memory\Committed Bytes").countersamples | select -property cookedvalue).cookedvalue
$ReadOp = [int]((get-counter -Counter "\System\File Read Operations/sec").countersamples | select -property cookedvalue).cookedvalue
$WriteOp = [int]((get-counter -Counter "\System\File Write Operations/sec").countersamples | select -property cookedvalue).cookedvalue

$Message1 = "MAIN.OSmetrics.DiscQueue:"+$DiskQue+"|c"
$Message2 = "MAIN.OSmetrics.BytesReceived:"+$BytesReceived+"|c"
$Message3 = "MAIN.OSmetrics.BytesSent:"+$BytesSent+"|c"
$Message4 = "MAIN.OSmetrics.MemAvail:"+$MemAvail+"|c"
$Message5 = "MAIN.OSmetrics.MemCommit:"+$MemCommit+"|c"
$Message6 = "MAIN.OSmetrics.ReadOp:"+$ReadOp+"|c"
$Message7 = "MAIN.OSmetrics.WriteOp:"+$WriteOp+"|c"

$Mesages = $Message1, $Message2, $Message3, $Message4, $Message5, $Message6, $Message7
foreach($Message in $Mesages)
{
Send_Graphite $Message
}
}

该脚本是可扩展的,您可以监控很多事情,只需运行 get-counter -ListSet * 您就会看到。我已经使用 TaskScheduler 安装了脚本,您可以通过插休眠眠来控制 while 循环的频率。

关于powershell - 带 powershell 的 Graphite ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13119057/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com