gpt4 book ai didi

c# - TcpClient在tcp流关闭之前不会将数据发送到Logstash

转载 作者:行者123 更新时间:2023-12-02 23:58:21 25 4
gpt4 key购买 nike

我正在尝试通过TcpClient将数据写入logstash。代码工作正常,但是logstash仅显示最后发送的记录,并且仅在关闭tcp流之后显示。

_client = new TcpClient();
_client.Connect(_settings.Host, _settings.Port);
var stream = _client.GetStream();
stream.Write(encoded, 0, encoded.Length);
stream.Flush();

Logstash tcp设置:
input{
tcp{
type=>"app"
port=>"9876"
}
}

我怎么了错误的代码或错误的logstash设置

最佳答案

我知道这是一个旧帖子,但是想过为那些可能遇到相同问题的人发布解决方案。我认为,通过TCP将C#日志数据发送到LogStash的最简单方法如下。

#From logstash configs 
input{
tcp{
port=>"9876"
codec=>"json"
}
}

从C#方面,我们需要创建一个json字符串以发送到logstash。首先创建一个LogJson.cs类,并重写ToString()。此类将仅返回所需的格式化json字符串。
using System;
using Newtonsoft.Json;

namespace FeedLogstash
{
class LogJson
{
public readonly int Id;
public readonly DateTime DateTime;
public readonly string Message;

public LogJson(int id, DateTime dateTime, string message) {
Id=id; DateTime=dateTime; Message=message;
}

public override string ToString() {
return JsonConvert.SerializeObject(this);
}
}
}

现在,我们可以将上述json字符串发送到LogStash tcp输入。我正在使用C#SimpleTcpClient类创建简单连接。注意:您必须关闭连接才能写入数据。
using SimpleTCP;
...
public void PushData() {
LogJson log = new LogJson(1001, DateTime.Now, "Danger: Will Robinson");
SimpleTcpClient _client;
_client = new SimpleTcpClient().Connect(host, port);
_client.Write(log.ToString() + "\n");
_client.Disconnect();
}

希望这对希望从C#通过TCP推送日志数据的人有所帮助。我相信Java可以采用相同的算法。

关于c# - TcpClient在tcp流关闭之前不会将数据发送到Logstash,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51385958/

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