You might want to take a look at this video https://youtu.be/ySy3sR1LFCQ which 
shows some common issues with concurrency in go and how to use pprof and 
the go tracer to inspect and fix them.

Hope this helps a bit.

Yannic

On Friday, October 27, 2017 at 2:38:00 PM UTC+2, Christian LeMoussel wrote:
>
> Hi, I am studying about golang and use of goroutine.  
> With this sample code, on my PC with 4 logical CPUs,  I can't understand 
> why I don't have any performance improvement.
>
> If I add in concurrency, the time it takes to do tends to slow down by the 
> original without concurrency. 
>
>     2017/10/27 13:57:17 Starting 1 threads
>     2017/10/27 13:57:27 Id routine: 0  rate: 232.558140
>     2017/10/27 13:57:27 Current total rate was 232.56 K/s
>     2017/10/27 13:57:27 Starting 1 threads
>     2017/10/27 13:57:37 Id routine: 0  rate: 357.142857
>     2017/10/27 13:57:37 Current total rate was 357.14 K/s
>     
>     2017/10/27 13:58:04 Starting 2 threads
>     2017/10/27 13:58:14 Id routine: 0  rate: 131.578947
>     2017/10/27 13:58:14 Id routine: 1  rate: 129.870130
>     2017/10/27 13:58:14 Current total rate was 261.45 K/s
>     2017/10/27 13:58:14 Starting 2 threads
>     2017/10/27 13:58:24 Id routine: 1  rate: 144.927536
>     2017/10/27 13:58:24 Id routine: 0  rate: 151.515152
>     2017/10/27 13:58:24 Current total rate was 296.44 K/s
>     
>     2017/10/27 13:59:15 Starting 3 threads
>     2017/10/27 13:59:25 Id routine: 2  rate: 94.339623
>     2017/10/27 13:59:25 Id routine: 0  rate: 92.592593
>     2017/10/27 13:59:25 Id routine: 1  rate: 90.090090
>     2017/10/27 13:59:25 Current total rate was 277.02 K/s
>     2017/10/27 13:59:25 Starting 3 threads
>     2017/10/27 13:59:35 Id routine: 2  rate: 92.592593
>     2017/10/27 13:59:35 Id routine: 0  rate: 90.090090
>     2017/10/27 13:59:35 Id routine: 1  rate: 101.010101
>     2017/10/27 13:59:35 Current total rate was 283.69 K/s
>     
>     2017/10/27 14:00:12 Starting 4 threads
>     2017/10/27 14:00:22 Id routine: 1  rate: 56.818182
>     2017/10/27 14:00:22 Id routine: 3  rate: 56.818182
>     2017/10/27 14:00:22 Id routine: 0  rate: 61.349693
>     2017/10/27 14:00:22 Id routine: 2  rate: 62.500000
>     2017/10/27 14:00:22 Current total rate was 237.49 K/s
>     2017/10/27 14:00:22 Starting 4 threads
>     2017/10/27 14:00:32 Id routine: 1  rate: 67.114094
>     2017/10/27 14:00:32 Id routine: 3  rate: 61.349693
>     2017/10/27 14:00:32 Id routine: 0  rate: 57.803468
>     2017/10/27 14:00:32 Id routine: 2  rate: 65.789474
>     2017/10/27 14:00:32 Current total rate was 252.06 K/s
>
> And, here is the concurrent code with the goroutines:
>
>     package main
>     
>     import (
>         "fmt"
>         "log"
>         "sync"
>         "time"
>     )
>     
>     var (
>         tryArr           []string
>         goroutineQuit    = make(chan struct{})
>         concurrencyMapHQ = struct {
>             sync.RWMutex
>             HQ map[int]float64
>         }{HQ: make(map[int]float64)}
>     )
>     
>     func rateStats() {
>         var totalRate float64
>         for i, rate := range concurrencyMapHQ.HQ {
>             log.Printf("Id routine: %d  rate: %f", i, rate)
>             totalRate += rate
>         }
>     
>         log.Printf("Current total rate was %.2f K/s", totalRate)
>     }
>     
>     func stopThreads(threads int) {
>         for i := 0; i < threads; i++ {
>             goroutineQuit <- struct{}{}
>         }
>     
>         rateStats()
>     }
>     
>     func runThreads(threads int, steps int) {
>         log.Printf("Starting %d threads", threads)
>     
>         for i := 0; i < threads; i++ {
>             i := i
>             go func(id int, steps int) {
>                 calculate(i, steps)
>             }(i, steps)
>         }
>     }
>     
>     func calculate(idRoutine int, steps int) {
>         var (
>             possibles []string
>             numBatchs = 0
>             t1        = time.Now()
>         )
>     
>         for {
>             select {
>             case <-goroutineQuit:
>                 return
>             default:
>                 possibles = nil
>     
>                 for _, nonce := range tryArr {
>                     possibles = append(possibles, nonce)
>                 }
>     
>                 numBatchs++
>                 if numBatchs == 99 {
>                     t2 := time.Now()
>     
>                     timeExecution := t2.Sub(t1) / time.Millisecond
>     
>                     concurrencyMapHQ.Lock()
>                     concurrencyMapHQ.HQ[idRoutine] = float64(steps) / 
> float64(timeExecution)
>                     concurrencyMapHQ.Unlock()
>     
>                     numBatchs = 0
>                     t1 = t2
>     
>                 }
>             }
>         }
>     }
>     
>     func main() {
>         threads := 4
>         steps := 10000
>     
>         tryArr = make([]string, steps)
>         for i := 0; i < steps; i++ {
>             tryArr[i] = fmt.Sprintf("indice: %d", i)
>         }
>     
>         for {
>             runThreads(threads, steps)
>             time.Sleep(10 * time.Second)
>             stopThreads(threads)
>     
>             runThreads(threads, steps)
>             time.Sleep(10 * time.Second)
>             stopThreads(threads)
>         }
>     }
>
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to