79 lines
1.5 KiB
Go
79 lines
1.5 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"log"
|
|
"net/http"
|
|
"os"
|
|
"strings"
|
|
"sync"
|
|
"time"
|
|
|
|
"gitea.urkob.com/urko/ess-etl-go/pkg/crono"
|
|
)
|
|
|
|
func main() {
|
|
log.SetFlags(log.Lmicroseconds)
|
|
logFileName := fmt.Sprintf("%s.txt", time.Now().Format(strings.ReplaceAll(time.RFC1123Z, ":", "_")))
|
|
f, err := os.OpenFile(logFileName, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0o644)
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
defer f.Close()
|
|
log.SetOutput(f)
|
|
|
|
cr := crono.New()
|
|
defer cr.Table()
|
|
host := "http://127.0.0.1:45654"
|
|
|
|
wg := &sync.WaitGroup{}
|
|
errChan := make(chan error, 1)
|
|
wg.Add(1)
|
|
go func(errChan chan error) {
|
|
defer wg.Done()
|
|
for i := 0; i < 1000; i++ {
|
|
wg.Add(1)
|
|
go doRequest(wg, host, "975135", errChan)
|
|
}
|
|
}(errChan)
|
|
|
|
wg.Wait()
|
|
cr.MarkAndRestart("finish handle all response")
|
|
}
|
|
|
|
func doRequest(wg *sync.WaitGroup, host, employeeID string, errChan chan error) error {
|
|
defer wg.Done()
|
|
url := host + "/employee_wi/" + employeeID
|
|
client := &http.Client{}
|
|
req, err := http.NewRequest("GET", url, nil)
|
|
|
|
if err != nil {
|
|
err = fmt.Errorf("http.NewRequest: %s", err)
|
|
errChan <- err
|
|
return err
|
|
}
|
|
req.Header.Add("Cache-Control", "no-cache")
|
|
req.Header.Add("Content-Type", "application/json")
|
|
|
|
res, err := client.Do(req)
|
|
if err != nil {
|
|
err = fmt.Errorf("client.Do: %s", err)
|
|
errChan <- err
|
|
return err
|
|
}
|
|
defer res.Body.Close()
|
|
|
|
readedBody, err := io.ReadAll(res.Body)
|
|
if err != nil {
|
|
err = fmt.Errorf("ioutil.ReadAll: %s", err)
|
|
errChan <- err
|
|
return err
|
|
}
|
|
|
|
log.Println("readed", string(readedBody))
|
|
|
|
return nil
|
|
}
|