Created
May 6, 2020 14:13
-
-
Save cnnrznn/7b2aee7af852b67d0bb6481d21b667a5 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package main | |
import ( | |
"fmt" | |
"log" | |
"os" | |
"runtime" | |
"strconv" | |
"strings" | |
"sync" | |
"github.com/cnnrznn/gomr" | |
) | |
type Job struct{} | |
type Entry struct { | |
key int | |
val string | |
} | |
func (j *Job) Map(in <-chan interface{}, out chan<- interface{}) { | |
defer close(out) | |
for item := range in { | |
phone, err := strconv.Atoi(strings.Split(item.(string), ",")[0]) | |
if err != nil { | |
log.Fatal(err) | |
} | |
out <- Entry{key: phone, val: item.(string)} | |
} | |
} | |
func (j *Job) Partition(in <-chan interface{}, outs []chan interface{}, wg *sync.WaitGroup) { | |
defer wg.Done() | |
for item := range in { | |
key := item.(Entry).key | |
outs[key%len(outs)] <- item | |
} | |
} | |
func (j *Job) Reduce(in <-chan interface{}, out chan<- interface{}, wg *sync.WaitGroup) { | |
defer wg.Done() | |
counts := make(map[int][]string) | |
for item := range in { | |
entry := item.(Entry) | |
counts[entry.key] = append(counts[entry.key], entry.val) | |
} | |
for _, v := range counts { | |
out <- v | |
} | |
} | |
func main() { | |
job := &Job{} | |
p := runtime.NumCPU() | |
ins, out := gomr.RunLocal(2*p, p, job) | |
gomr.TextFileParallel(os.Args[1], ins) | |
for item := range out { | |
fmt.Println(item) | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment