- vừa được xem lúc

[Golang] Leaks In Goroutine And Debug Resource

0 0 21

Người đăng: Open Dev

Theo Viblo Asia

Ví Dụ Đơn Giản

func leak() { doWork := func(strings <-chan string) <-chan interface{} { completed := make(chan interface{}) go func() { defer fmt.Println("doWork exited.") defer close(completed) for s := range strings { // Do something interesting fmt.Println(s) } }() fmt.Println("end function doWork") return completed } fmt.Println("dowork") doWork(nil) // Perhaps more work is done here fmt.Println("Done.")
}
  • trong func doWork với parameter là một chan string.
  • func sẽ leak vì string channel là một giá trị nil. Có nghĩa là goroutine này không clear tài nguyên, không stop func.
  • ví dụ trên có lẽ là cực kì ngắn, nhưng trong thực tế thì func sẽ tồn tại trong lifetime và ảnh hưởng đến tài nguyên của chương trình.

Debug Resource

Cài package

  • cài package: apt-get install graphviz gv (debian) or brew install graphviz (mac)
  • cài pprof: go get -u github.com/google/pprof
  • import pprof: import _ "net/http/pprof"
  • add server: pprof

source

package main import ( "fmt" "net/http" _ "net/http/pprof" "os" "os/signal" "syscall"
) func leak() { doWork := func(strings <-chan string) <-chan interface{} { completed := make(chan interface{}) go func() { defer func() { fmt.Println("doWork exited.") }() defer func() { close(completed) }() for s := range strings { // Do something interesting fmt.Println(s) } }() fmt.Println("end function doWork") return completed } fmt.Println("dowork") doWork(nil) // Perhaps more work is done here fmt.Println("Done.")
} func main() { leak() leak() leak() go func() { http.ListenAndServe(":1234", nil) }() // sigs := make(chan os.Signal, 1) signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM) done := make(chan bool, 1) go func() { <-sigs done <- true }() <-done
}
  • trong func main, gọi 3 hàm leak() -> trong lifetime sẽ có 3 goroutine bị leak
  • start server với port 1234
  • sau khi start server, mở một terminal khác go tool pprof http://localhost:1234/debug/pprof/goroutine và enter png
  • sẽ có kết quả Generating report in profile001.png
  • Kết quả trong hình sử dụng pprof thì sẽ có 3 leak.

Video https://www.youtube.com/watch?v=e1Aa4d90nzk

Source https://github.com/ducnpdev/open-dev/blob/master/concurrency/leak.go

Bình luận

Bài viết tương tự

- vừa được xem lúc

gRPC - Nó là gì và có nên sử dụng hay không?

Nhân một ngày rảnh rỗi, mình ngồi đọc lại RPC cũng như gRPC viết lại để nhớ lâu hơn. Vấn đề là gì và tại sao cần nó .

0 0 131

- vừa được xem lúc

Embedded Template in Go

Getting Start. Part of developing a web application usually revolves around working with HTML as user interface.

0 0 56

- vừa được xem lúc

Tạo Resful API đơn giản với Echo framework và MySQL

1. Giới thiệu.

0 0 60

- vừa được xem lúc

Sử dụng goquery trong golang để crawler thông tin các website Việt Nam bị deface trên mirror-h.org

. Trong bài viết này, mình sẽ cùng mọi người khám phá một package thu thập dữ liệu có tên là goquery của golang. Mục tiêu chính của chương trình crawler này sẽ là lấy thông tin các website Việt Nam bị deface (là tấn công, phá hoại website, làm thay đổi giao diện hiển thị của một trang web, khi người

0 0 237

- vừa được xem lúc

Tạo ứng dụng craw dữ liệu bing với Golang, Mysql driver

Chào mọi người . Lâu lâu ta lại gặp nhau 1 lần, để tiếp tục series chia sẻ kiến thức về tech, hôm nay mình sẽ tìm hiểu và chia sẻ về 1 ngôn ngữ đang khá hot trong cộng đồng IT đó là Golang.

0 0 75

- vừa được xem lúc

Golang: Rest api and routing using MUX

Routing with MUX. Let's create a simple CRUD api for a blog site. # All . GET articles/ .

0 0 54