本文介绍几种在debian系统中实现golang应用日志远程收集的常用方法。
方法一:利用Syslog
此方法利用系统自带的Syslog服务进行日志转发。
-
安装Syslog: Debian系统通常已预装rsyslog。若未安装,请执行:
立即学习“go语言免费学习笔记(深入)”;
sudo apt-get update sudo apt-get install rsyslog
-
Golang应用配置: 使用log/syslog包发送日志到Syslog。示例:
package main import ( "log" "log/syslog" ) func main() { writer, err := syslog.Dial("udp", "localhost:514", syslog.LOG_INFO|syslog.LOG_LOCAL0, "myapp") if err != nil { log.Fatalf("连接Syslog失败: %v", err) } defer writer.Close() writer.Info("信息日志") writer.Warning("警告日志") }
-
Syslog远程配置: 编辑/etc/rsyslog.conf或/etc/rsyslog.d/50-default.conf,添加以下内容接收远程日志(将remote_server_ip替换为远程服务器IP):
module(load="imudp") input(type="imudp" port="514") module(load="imtcp") input(type="imtcp" port="514") local0.* @@remote_server_ip:514
-
重启Syslog:
sudo systemctl restart rsyslog
方法二:使用Fluentd或Logstash
Fluentd和Logstash是流行的日志收集工具。
-
安装Fluentd或Logstash:
sudo apt-get update sudo apt-get install fluentd # 或 sudo apt-get install logstash
-
配置Fluentd/Logstash:
-
Fluentd: 修改/etc/td-agent/td-agent.conf,添加以下配置(替换remote_server_ip):
<source> @type syslog port 514 tag myapp </source> <match myapp.=""> @type forward <server remote_server_ip=""> port 24224 </server> </match>
-
Logstash: 修改/etc/logstash/conf.d/50-default.conf,添加以下配置(替换remote_server_ip):
input { syslog { port => 514 type => "myapp" } } output { tcp { host => "remote_server_ip" port => 24224 } }
-
-
重启Fluentd/Logstash:
sudo systemctl restart td-agent # 或 sudo systemctl restart logstash
-
Golang应用集成: 使用fluent-logger-golang (Fluentd) 或 logrus 和 gelf (Logstash) 库发送日志。
方法三:自定义http API
此方法需要自行搭建HTTP日志接收服务器。
-
搭建HTTP服务器: 使用Golang编写HTTP服务器接收日志并存储或转发。
-
Golang应用配置: 使用net/http包发送日志到HTTP API。示例:
package main import ( "bytes" "encoding/json" "fmt" "log" "net/http" ) func main() { url := "http://remote_server_ip:8080/log" data := map[string]string{"message": "日志信息"} jsonData, err := json.Marshal(data) if err != nil { log.Fatalf("JSON编码失败: %v", err) } resp, err := http.Post(url, "application/json", bytes.NewBuffer(jsonData)) if err != nil { log.Fatalf("发送日志失败: %v", err) } defer resp.Body.Close() fmt.Printf("状态码: %dn", resp.StatusCode) }
-
启动HTTP服务器: 运行你编写的HTTP日志接收服务器。