golang 并行执行 收集结果 超时控制 失败提前退出

该博客介绍了如何在Go语言中实现并行调用多个服务,同时实现服务失败快速返回和超时控制。示例代码展示了使用channel和sync.Map两种方式来收集和处理服务结果,确保在服务执行过程中能够及时响应错误和超时情况。
摘要由CSDN通过智能技术生成

背景

有这么个需求
1、调用多个服务,pack1、pack2、pack3…,需要并行调用;
2、任意一个服务返回失败,提前返回失败
3、需要有超时控制不能等待太久
4、收集每个服务返回的结果,后面要做处理

怎么实现呢?

code

package main

import (
	"code.byted.org/gopkg/logs"
	"fmt"
	"github.com/pkg/errors"
	"time"
)

func pack1(secs time.Duration) (result string, err error) {
   
	fmt.Printf("waiting %v\n", secs)
	time.Sleep(secs * time.Second)
	result = fmt.Sprintf("waited for %v seconds", secs)
	//return result, errors.New("pack1 error")
	return result, nil
}

func pack2(secs time.Duration) (result string, err error) {
   
	fmt.Printf("waiting %v\n", secs)
	time.Sleep(secs * time.Second)
	result = fmt.Sprintf("waited for %v seconds", secs)
	return result, errors.New("pack2 error")
	//return result, nil
}

// golang parallel return functions
// 并行执行多个pack,只要有一个错误,就可以提前返回,否则需要收集多个pack结果拼接一起(reduce)
func runParallel() (string, error) {
   
	defer logs.Flush()
	outChan1 := make(chan *string)
	outChan2 := make(chan *string)
	go func() {
   
		res1, err := pack1(1)
		if err != nil {
   
			logs.Error("pack1 error")
			outChan1 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值