feat: read,write data with buffered
This commit is contained in:
		| @@ -3,9 +3,7 @@ package cmd | |||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"encoding/json" | 	"encoding/json" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"io" |  | ||||||
| 	"net/url" | 	"net/url" | ||||||
| 	"os" | 	"os" | ||||||
|  |  | ||||||
| @@ -88,37 +86,74 @@ func run(cmd *cobra.Command, args []string) error { | |||||||
| func executeData(ctx context.Context, input, output interfaces.DumpIO) error { | func executeData(ctx context.Context, input, output interfaces.DumpIO) error { | ||||||
| 	var ( | 	var ( | ||||||
| 		err   error | 		err   error | ||||||
| 		lines   []*interfaces.ESSource | 		ch    = make(chan []*interfaces.ESSource, 1) | ||||||
| 		succeed int | 		errCh = make(chan error) | ||||||
| 		total   int |  | ||||||
| 	) | 	) | ||||||
|  |  | ||||||
|  | 	// write goroutine | ||||||
|  | 	go func(c context.Context) { | ||||||
|  | 		var ( | ||||||
|  | 			lines []*interfaces.ESSource | ||||||
|  | 		) | ||||||
|  |  | ||||||
|  | 		defer func() { | ||||||
|  | 			close(ch) | ||||||
|  | 		}() | ||||||
|  |  | ||||||
| 		for { | 		for { | ||||||
|  | 			select { | ||||||
| 		if lines, err = input.ReadData(ctx, f_limit); err != nil { | 			case <-c.Done(): | ||||||
| 			if errors.Is(err, io.EOF) { | 				return | ||||||
| 				return nil | 			default: | ||||||
| 			} | 				if lines, err = input.ReadData(c, f_limit); err != nil { | ||||||
|  | 					errCh <- err | ||||||
| 			return err | 					return | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				if len(lines) == 0 { | 				if len(lines) == 0 { | ||||||
| 			return nil | 					ch <- lines | ||||||
|  | 					return | ||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 		if succeed, err = output.WriteData(ctx, lines); err != nil { | 				ch <- lines | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}(ctx) | ||||||
|  |  | ||||||
|  | 	var ( | ||||||
|  | 		succeed int | ||||||
|  | 		total   int | ||||||
|  | 		docs    []*interfaces.ESSource | ||||||
|  | 		ok      bool | ||||||
|  | 	) | ||||||
|  |  | ||||||
|  | 	for { | ||||||
|  | 		select { | ||||||
|  | 		case <-ctx.Done(): | ||||||
|  | 		case err = <-errCh: | ||||||
|  | 			return err | ||||||
|  | 		case docs, ok = <-ch: | ||||||
|  | 			if !ok { | ||||||
| 				return err | 				return err | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 		if succeed != len(lines) { | 			if len(docs) == 0 { | ||||||
| 			return fmt.Errorf("cmd.run: got lines=%d, only succeed=%d", len(lines), succeed) | 				return nil | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if succeed, err = output.WriteData(ctx, docs); err != nil { | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if succeed != len(docs) { | ||||||
|  | 				return fmt.Errorf("cmd.run: got lines=%d, only succeed=%d", len(docs), succeed) | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			total += succeed | 			total += succeed | ||||||
|  |  | ||||||
| 			logrus.Infof("Dump: succeed=%d total=%d docs succeed!!!", succeed, total) | 			logrus.Infof("Dump: succeed=%d total=%d docs succeed!!!", succeed, total) | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func newIO(source string, ioType interfaces.IO) (interfaces.DumpIO, error) { | func newIO(source string, ioType interfaces.IO) (interfaces.DumpIO, error) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user