在Debian系統上使用Golang實現日志的遠程傳輸可以通過多種方式來完成。以下是幾種常見的方法:
rsyslog。sudo apt-get update
sudo apt-get install rsyslog
/etc/rsyslog.conf 或 /etc/rsyslog.d/50-default.conf 文件,添加以下內容以接收遠程日志:module(load="imudp")
input(type="imudp" port="514")
module(load="imtcp")
input(type="imtcp" port="514")
sudo systemctl restart rsyslog
go-syslog 庫將日志發送到遠程Syslog服務器。go get github.com/RackSec/srslog
在你的Golang代碼中:
package main
import (
"github.com/RackSec/srslog"
"log"
)
func main() {
logger, err := srslog.NewLogger(srslog.LOG_INFO, "myapp", "udp", "localhost:514")
if err != nil {
log.Fatalf("Failed to create logger: %v", err)
}
defer logger.Close()
logger.Info("This is an info message")
logger.Error("This is an error message")
}
nginx 或 apache2。sudo apt-get update
sudo apt-get install nginx
nginx 以接收日志請求。server {
listen 80;
server_name your_server_ip;
location /log {
proxy_pass http://localhost:8080/log;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
net/http 庫將日志發送到遠程HTTP服務器。package main
import (
"bytes"
"log"
"net/http"
)
func main() {
url := "http://your_server_ip/log"
logData := []byte("This is a log message")
resp, err := http.Post(url, "application/json", bytes.NewBuffer(logData))
if err != nil {
log.Fatalf("Failed to send log: %v", err)
}
defer resp.Body.Close()
if resp.StatusCode != http.StatusOK {
log.Fatalf("Failed to send log: status code %d", resp.StatusCode)
}
}
go get github.com/sirupsen/logrus
在你的Golang代碼中:
package main
import (
"github.com/sirupsen/logrus"
"os"
)
func main() {
logger := logrus.New()
logger.SetLevel(logrus.InfoLevel)
logger.SetFormatter(&logrus.JSONFormatter{})
logger.SetOutput(os.Stdout)
logger.Info("This is a logrus test log")
}
go get go.uber.org/zap
在你的Golang代碼中:
package main
import (
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
)
func main() {
logger := zap.NewProduction()
defer logger.Sync() // flushes buffer, if any
logger.Info("logger construction succeeded")
}