將 CentOS 與 Golang 日志收集結合起來,可以通過以下步驟實現:
首先,確保你的 Golang 應用程序正在使用一個日志庫(如 logrus、zap 等)來記錄日志。然后,配置日志輸出到標準輸出(stdout),這樣我們就可以通過管道將其捕獲并傳輸到其他地方。
例如,使用 logrus 庫配置日志輸出:
package main
import (
"github.com/sirupsen/logrus"
)
func main() {
log := logrus.New()
log.SetFormatter(&logrus.JSONFormatter{})
log.WithFields(logrus.Fields{
"animal": "walrus",
"size": 10,
}).Info("A group of walrus emerges from the ocean")
}
創建一個 systemd 服務文件(例如 /etc/systemd/system/myapp.service
),并將其配置為捕獲 Golang 應用程序的 stdout 和 stderr 日志。這樣,當應用程序運行時,其日志將被寫入到 systemd 的日志文件中。
[Unit]
Description=My Golang Application
After=network.target
[Service]
User=myuser
Group=mygroup
WorkingDirectory=/path/to/your/app
ExecStart=/path/to/your/app/myapp
StandardOutput=append:/var/log/myapp.log
StandardError=append:/var/log/myapp.err.log
Restart=always
[Install]
WantedBy=multi-user.target
在 CentOS 上,你可以使用 ELK(Elasticsearch、Logstash 和 Kibana)堆棧來收集和分析日志。首先,安裝并配置 Elasticsearch、Logstash 和 Kibana。
接下來,配置 Logstash 以從 systemd 日志文件中讀取日志。創建一個 Logstash 配置文件(例如 /etc/logstash/conf.d/myapp.conf
),并添加以下內容:
input {
file {
path => "/var/log/myapp.log"
start_position => "beginning"
}
file {
path => "/var/log/myapp.err.log"
start_position => "beginning"
}
}
filter {
# 在這里添加任何需要的過濾和解析邏輯
}
output {
elasticsearch {
hosts => ["localhost:9200"]
index => "myapp-logs"
}
}
sudo systemctl start logstash
sudo systemctl enable logstash
啟動 Kibana 服務,然后在 Web 瀏覽器中訪問 Kibana Web 界面(默認為 http://localhost:5601
)。在這里,你可以創建儀表板、搜索日志并分析應用程序的性能。
通過以上步驟,你可以將 CentOS 與 Golang 日志收集結合起來,從而更好地監控和管理你的應用程序。