blob: 189164064a5a2e8434e368480f86375334b8f8f5 [file] [log] [blame]
// Licensed to Apache Software Foundation (ASF) under one or more contributor
// license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright
// ownership. Apache Software Foundation (ASF) licenses this file to you under
// the Apache License, Version 2.0 (the "License"); you may
// not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
package main
import (
"context"
"io"
"log"
"net/http"
"runtime/pprof"
"time"
_ "github.com/apache/skywalking-go"
)
func providerHandler(w http.ResponseWriter, r *http.Request) {
l := pprof.Labels("test-label", "test", "operation", "provider")
c := context.Background()
c = pprof.WithLabels(c, l)
pprof.SetGoroutineLabels(c)
doWork()
_, _ = w.Write([]byte("success"))
}
func consumerHandler(w http.ResponseWriter, r *http.Request) {
l := pprof.Labels("test-label", "consumer", "operation", "consumer")
c := context.Background()
c = pprof.WithLabels(c, l)
pprof.SetGoroutineLabels(c)
resp, err := http.Get("http://localhost:8080/provider?test=1")
if err != nil {
log.Printf("request provider error: %v", err)
w.WriteHeader(http.StatusInternalServerError)
return
}
defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
if err != nil {
log.Print(err)
w.WriteHeader(http.StatusInternalServerError)
return
}
resp2, err := http.Get("http://localhost:8080/provider?test=2")
if err != nil {
log.Printf("request provider error: %v", err)
w.WriteHeader(http.StatusInternalServerError)
return
}
defer resp2.Body.Close()
body2, err := io.ReadAll(resp2.Body)
if err != nil {
log.Print(err)
w.WriteHeader(http.StatusInternalServerError)
return
}
_, _ = w.Write(append(body, body2...))
}
func doWork() {
start := time.Now()
for time.Since(start) < 1*time.Second {
for i := 0; i < 1e6; i++ {
_ = i * i
}
}
}
func main() {
http.HandleFunc("/provider", providerHandler)
http.HandleFunc("/consumer", consumerHandler)
http.HandleFunc("/health", func(writer http.ResponseWriter, request *http.Request) {
writer.WriteHeader(http.StatusOK)
})
_ = http.ListenAndServe("0.0.0.0:8080", nil)
}