Using ELK for log collection and analysis in Beego
ELK is a very popular log collection and analysis tool set, which consists of three open source software: Elasticsearch, Logstash and Kibana. This toolset can be used to search, analyze, and visualize large amounts of log data in real time.
In the development of web applications, logs are a very useful source of information that can be used to track application behavior, debugging, and performance optimization. Beego is an open source web framework written in Go language, which can easily use ELK for log collection and analysis.
This article will introduce how to configure and use ELK in Beego for log collection and analysis, and how to use Kibana for data visualization.
1. Install and configure ELK
First you need to install and configure ELK. You can download the latest version of the ELK software package on the official website: https://www.elastic.co/downloads/
Installing ELK requires first installing Java and setting the JAVA_HOME environment variable, then decompressing the ELK package, and starting Elasticsearch and Kibana:
cd elasticsearch-7.6.0/bin ./elasticsearch cd kibana-7.6.0/bin ./kibana
Then edit the Logstash configuration file logstash.conf, configure the input, Filters and Output:
input {
tcp {
port => 5000
codec => json
}
}
filter {
if [type] == "beego" {
grok {
match => { "message" => "%{COMBINEDAPACHELOG}" }
}
}
}
output {
elasticsearch {
hosts => ["localhost:9200"]
index => "%{type}-%{+YYYY.MM.dd}"
}
}This configuration file specifies that Logstash listens for TCP connections on port 5000 and uses JSON encoding and decoding. When a log message sent by a Beego application is received, the log message is parsed using a regular expression grok filter. The parsed log messages are then output to Elasticsearch.
2. Using ELK in the Beego application
Use logrus as the log library in the Beego application, and you can send the logs to the Logstash server:
package main
import (
"github.com/astaxie/beego"
"github.com/sirupsen/logrus"
"github.com/x-cray/logrus-prefixed-formatter"
"gopkg.in/natefinch/lumberjack.v2"
)
func init() {
logLevel, err := logrus.ParseLevel(beego.AppConfig.String("logrus.level"))
if err != nil {
logLevel = logrus.InfoLevel
}
logrus.SetLevel(logLevel)
logrus.SetFormatter(&prefixed.TextFormatter{})
logrus.SetOutput(&lumberjack.Logger{
Filename: beego.AppConfig.String("logrus.filename"),
MaxSize: 10, // megabytes
MaxBackups: 3,
MaxAge: 28, // days
})
logrus.AddHook(&logrusHook{})
}
type logrusHook struct{}
func (h *logrusHook) Levels() []logrus.Level {
return logrus.AllLevels
}
func (h *logrusHook) Fire(entry *logrus.Entry) error {
message, err := entry.String()
if err != nil {
return err
}
logstash := beego.AppConfig.String("logstash.addr")
connection, err := net.Dial("tcp", logstash)
if err != nil {
return err
}
defer connection.Close()
_, err = connection.Write([]byte(message))
return err
}This code snippet , first use the logrus library to initialize the logger and output the log to the file and standard output. Then add a logrusHook to send a JSON formatted log message to the Logstash server every time it is logged.
It is very convenient to use logrus as a logging library in Beego applications. You only need to import the logrus library in the code, and then use the logrus.WithFields() method to record log information in the form of key-value pairs.
3. Use Kibana for data visualization
Kibana is a web interface that can query, visualize and analyze log data. It can retrieve data from Elasticsearch and visualize it. Open Kibana's address in a browser, usually http://localhost:5601, and select the "Discover" menu to search and visualize the collected log data.
In Kibana, you can create dashboards to visualize multiple queries together to monitor the running status of the system. Filters and tags can also be used to query and visualize the data more precisely.
4. Summary
Using ELK for log collection and analysis in Beego applications is a very convenient and practical method. ELK provides flexible log filtering and visualization functions to quickly locate application problems and optimize performance. At the same time, the running status of the application can be monitored more intuitively through visualization and dashboards.
The above is the detailed content of Using ELK for log collection and analysis in Beego. For more information, please follow other related articles on the PHP Chinese website!
Golang vs. C : Code Examples and Performance AnalysisApr 15, 2025 am 12:03 AMGolang is suitable for rapid development and concurrent programming, while C is more suitable for projects that require extreme performance and underlying control. 1) Golang's concurrency model simplifies concurrency programming through goroutine and channel. 2) C's template programming provides generic code and performance optimization. 3) Golang's garbage collection is convenient but may affect performance. C's memory management is complex but the control is fine.
Golang's Impact: Speed, Efficiency, and SimplicityApr 14, 2025 am 12:11 AMGoimpactsdevelopmentpositivelythroughspeed,efficiency,andsimplicity.1)Speed:Gocompilesquicklyandrunsefficiently,idealforlargeprojects.2)Efficiency:Itscomprehensivestandardlibraryreducesexternaldependencies,enhancingdevelopmentefficiency.3)Simplicity:
C and Golang: When Performance is CrucialApr 13, 2025 am 12:11 AMC is more suitable for scenarios where direct control of hardware resources and high performance optimization is required, while Golang is more suitable for scenarios where rapid development and high concurrency processing are required. 1.C's advantage lies in its close to hardware characteristics and high optimization capabilities, which are suitable for high-performance needs such as game development. 2.Golang's advantage lies in its concise syntax and natural concurrency support, which is suitable for high concurrency service development.
Golang in Action: Real-World Examples and ApplicationsApr 12, 2025 am 12:11 AMGolang excels in practical applications and is known for its simplicity, efficiency and concurrency. 1) Concurrent programming is implemented through Goroutines and Channels, 2) Flexible code is written using interfaces and polymorphisms, 3) Simplify network programming with net/http packages, 4) Build efficient concurrent crawlers, 5) Debugging and optimizing through tools and best practices.
Golang: The Go Programming Language ExplainedApr 10, 2025 am 11:18 AMThe core features of Go include garbage collection, static linking and concurrency support. 1. The concurrency model of Go language realizes efficient concurrent programming through goroutine and channel. 2. Interfaces and polymorphisms are implemented through interface methods, so that different types can be processed in a unified manner. 3. The basic usage demonstrates the efficiency of function definition and call. 4. In advanced usage, slices provide powerful functions of dynamic resizing. 5. Common errors such as race conditions can be detected and resolved through getest-race. 6. Performance optimization Reuse objects through sync.Pool to reduce garbage collection pressure.
Golang's Purpose: Building Efficient and Scalable SystemsApr 09, 2025 pm 05:17 PMGo language performs well in building efficient and scalable systems. Its advantages include: 1. High performance: compiled into machine code, fast running speed; 2. Concurrent programming: simplify multitasking through goroutines and channels; 3. Simplicity: concise syntax, reducing learning and maintenance costs; 4. Cross-platform: supports cross-platform compilation, easy deployment.
Why do the results of ORDER BY statements in SQL sorting sometimes seem random?Apr 02, 2025 pm 05:24 PMConfused about the sorting of SQL query results. In the process of learning SQL, you often encounter some confusing problems. Recently, the author is reading "MICK-SQL Basics"...
Is technology stack convergence just a process of technology stack selection?Apr 02, 2025 pm 05:21 PMThe relationship between technology stack convergence and technology selection In software development, the selection and management of technology stacks are a very critical issue. Recently, some readers have proposed...


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 English version
Recommended: Win version, supports code prompts!

SublimeText3 Mac version
God-level code editing software (SublimeText3)






