Unique users via logs
Count how many users you have in your structured logs
Published: Wednesday, May 4, 2022 Last modified: Saturday, Sep 7, 2024
First you need to finger print your user, e.g. by setting a cookie, here I just use milliseconds since epoch:
func uniqueVisitor(next http.Handler) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
cookie, _ := r.Cookie("visitor")
if cookie != nil {
slog.Info("returning visitor", "vistor", cookie.Value)
} else {
setCookie := http.Cookie{Name: "visitor", Value: fmt.Sprint("visitor-", time.Now().UnixMilli()), Expires: time.Now().Add(365 * 24 * time.Hour)}
http.SetCookie(w, &setCookie)
}
next.ServeHTTP(w, r)
})
}
Once you are logging a unique visitor attribute in your logs, you can count your users!
A Log insights query like:
fields @timestamp, fields.visitor
| sort @timestamp desc
| filter ispresent(fields.visitor)
| stats count_distinct(fields.visitor) by bin(1h)
Check the Amazon documentation for more sample queries.
Also do checkout: https://www.rehanvdm.com/blog/aws-serverless-you-might-not-need-third-party-monitoring