Попытка внедрить statsd

This commit is contained in:
ErickSkrauch 2016-08-26 22:08:53 +03:00
parent 34179ae1fe
commit a0d940f8cd
6 changed files with 33 additions and 0 deletions

2
data/statsd/.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
*
!.gitignore

View File

@ -11,3 +11,8 @@ services:
RABBITMQ_DEFAULT_USER: "ely-skinsystem-app" RABBITMQ_DEFAULT_USER: "ely-skinsystem-app"
RABBITMQ_DEFAULT_PASS: "ely-skinsystem-app-password" RABBITMQ_DEFAULT_PASS: "ely-skinsystem-app-password"
RABBITMQ_DEFAULT_VHOST: "/ely" RABBITMQ_DEFAULT_VHOST: "/ely"
statsd:
image: hopsoft/graphite-statsd
volumes:
- ./data/statsd:/opt/graphite/storage

View File

@ -11,6 +11,7 @@ services:
links: links:
- redis - redis
- rabbitmq - rabbitmq
- statsd
redis: redis:
extends: extends:
@ -21,3 +22,10 @@ services:
extends: extends:
file: docker-compose.base.yml file: docker-compose.base.yml
service: rabbitmq service: rabbitmq
statsd:
extends:
file: docker-compose.base.yml
service: statsd
ports:
- "8123:80"

View File

@ -13,6 +13,7 @@ import (
) )
func Textures(w http.ResponseWriter, r *http.Request) { func Textures(w http.ResponseWriter, r *http.Request) {
services.Stats.Incr("textures-requests", 1)
username := tools.ParseUsername(mux.Vars(r)["username"]) username := tools.ParseUsername(mux.Vars(r)["username"])
log.Println("request textures for username " + username) log.Println("request textures for username " + username)

View File

@ -4,6 +4,7 @@ import (
"github.com/mediocregopher/radix.v2/pool" "github.com/mediocregopher/radix.v2/pool"
"github.com/streadway/amqp" "github.com/streadway/amqp"
"github.com/gorilla/mux" "github.com/gorilla/mux"
"github.com/quipo/statsd"
) )
var Router *mux.Router var Router *mux.Router
@ -13,3 +14,5 @@ var RedisPool *pool.Pool
var RabbitMQChannel *amqp.Channel var RabbitMQChannel *amqp.Channel
var RootFolder string var RootFolder string
var Stats *statsd.StatsdBuffer

View File

@ -11,6 +11,8 @@ import (
"github.com/gorilla/mux" "github.com/gorilla/mux"
"github.com/streadway/amqp" "github.com/streadway/amqp"
"github.com/mediocregopher/radix.v2/pool" "github.com/mediocregopher/radix.v2/pool"
"github.com/quipo/statsd"
//"github.com/mediocregopher/radix.v2/redis"
"elyby/minecraft-skinsystem/lib/routes" "elyby/minecraft-skinsystem/lib/routes"
"elyby/minecraft-skinsystem/lib/services" "elyby/minecraft-skinsystem/lib/services"
@ -56,6 +58,17 @@ func main() {
} }
log.Println("Connected to rabbitmq channel") log.Println("Connected to rabbitmq channel")
// init
statsClient := statsd.NewStatsdClient(statsString, "skinsystem.")
statsErr := statsClient.CreateSocket()
if statsErr != nil {
log.Fatal(statsErr)
}
interval := 2 * time.Second // aggregate stats and flush every 2 seconds
stats := statsd.NewStatsdBuffer(interval, statsClient)
defer stats.Close()
router := mux.NewRouter().StrictSlash(true) router := mux.NewRouter().StrictSlash(true)
router.HandleFunc("/skins/{username}", routes.Skin).Methods("GET").Name("skins") router.HandleFunc("/skins/{username}", routes.Skin).Methods("GET").Name("skins")
router.HandleFunc("/cloaks/{username}", routes.Cape).Methods("GET").Name("cloaks") router.HandleFunc("/cloaks/{username}", routes.Cape).Methods("GET").Name("cloaks")
@ -75,6 +88,7 @@ func main() {
services.Router = router services.Router = router
services.RedisPool = redisPool services.RedisPool = redisPool
services.RabbitMQChannel = rabbitChannel services.RabbitMQChannel = rabbitChannel
services.Stats = stats
_, file, _, _ := runtime.Caller(0) _, file, _, _ := runtime.Caller(0)
services.RootFolder = filepath.Dir(file) services.RootFolder = filepath.Dir(file)