forked from zeromicro/go-zero
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Co-authored-by: zhoushuguang <zhoushuguang@xiaoheiban.cn>
- Loading branch information
1 parent
3128d63
commit 3a9b9ce
Showing
3 changed files
with
123 additions
and
1 deletion.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
package main | ||
|
||
import ( | ||
"log" | ||
"time" | ||
|
||
"github.com/tal-tech/go-zero/core/mr" | ||
"github.com/tal-tech/go-zero/core/timex" | ||
) | ||
|
||
type user struct{} | ||
|
||
func (u *user) User(uid int64) (interface{}, error) { | ||
time.Sleep(time.Millisecond * 30) | ||
return nil, nil | ||
} | ||
|
||
type store struct{} | ||
|
||
func (s *store) Store(pid int64) (interface{}, error) { | ||
time.Sleep(time.Millisecond * 50) | ||
return nil, nil | ||
} | ||
|
||
type order struct{} | ||
|
||
func (o *order) Order(pid int64) (interface{}, error) { | ||
time.Sleep(time.Millisecond * 40) | ||
return nil, nil | ||
} | ||
|
||
var ( | ||
userRpc user | ||
storeRpc store | ||
orderRpc order | ||
) | ||
|
||
func main() { | ||
start := timex.Now() | ||
_, err := productDetail(123, 345) | ||
if err != nil { | ||
log.Printf("product detail error: %v", err) | ||
return | ||
} | ||
log.Printf("productDetail time: %v", timex.Since(start)) | ||
|
||
// the data processing | ||
res, err := checkLegal([]int64{1, 2, 3}) | ||
if err != nil { | ||
log.Printf("check error: %v", err) | ||
return | ||
} | ||
log.Printf("check res: %v", res) | ||
} | ||
|
||
type ProductDetail struct { | ||
User interface{} | ||
Store interface{} | ||
Order interface{} | ||
} | ||
|
||
func productDetail(uid, pid int64) (*ProductDetail, error) { | ||
var pd ProductDetail | ||
err := mr.Finish(func() (err error) { | ||
pd.User, err = userRpc.User(uid) | ||
return | ||
}, func() (err error) { | ||
pd.Store, err = storeRpc.Store(pid) | ||
return | ||
}, func() (err error) { | ||
pd.Order, err = orderRpc.Order(pid) | ||
return | ||
}) | ||
|
||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
return &pd, nil | ||
} | ||
|
||
func checkLegal(uids []int64) ([]int64, error) { | ||
r, err := mr.MapReduce(func(source chan<- interface{}) { | ||
for _, uid := range uids { | ||
source <- uid | ||
} | ||
}, func(item interface{}, writer mr.Writer, cancel func(error)) { | ||
uid := item.(int64) | ||
ok, err := check(uid) | ||
if err != nil { | ||
cancel(err) | ||
} | ||
if ok { | ||
writer.Write(uid) | ||
} | ||
}, func(pipe <-chan interface{}, writer mr.Writer, cancel func(error)) { | ||
var uids []int64 | ||
for p := range pipe { | ||
uids = append(uids, p.(int64)) | ||
} | ||
writer.Write(uids) | ||
}) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
return r.([]int64), nil | ||
} | ||
|
||
func check(uid int64) (bool, error) { | ||
// do something check user legal | ||
time.Sleep(time.Millisecond * 20) | ||
return true, nil | ||
} |