Categorygithub.com/x-mod/routine
modulepackage
1.4.0
Repository: https://github.com/x-mod/routine.git
Documentation: pkg.go.dev

# README

routine

GoDoc Go Report Card Build Status Version Coverage Status

Routine Architecture

Quick Start

package main

import (
	"log"
	"context"

	"github.com/x-mod/routine"
)

func main(){
	if err := routine.Main(
		context.TODO(),
		routine.Command("echo", routine.ARG("hello routine!")),
	); err != nil {
		log.Fatal(err)
	}
}

Or you can just clone the repo, then running go run quickstart/main.go.

Main Routine

The most functional feature is providing the Main function abstraction, you can use the routine.Main to wrap your main function logic very quickly.

package main

import (
	"context"
	"github.com/x-mod/routine"
)

func MainGo(ctx context.Context) error {
	log.Println("this is the Main Go func")
	return nil
}
func ChildGo(ctx context.Context) error {
	log.Println("this is the Child Go func")
	return nil
}
func prepareGo(ctx context.Context) error {
	log.Println("this is the prepare Go func")
	return nil
}
func cleanupGo(ctx context.Context) error {
	log.Println("this is the Clean Go func")
	return nil
}

func main(){
	log.Println(
		routine.Main(
			context.TODO(),
			//main Go
			routine.ExecutorFunc(MainGo),
			//prpare Go
			routine.Prepare(routine.ExecutorFunc(prepareGo)),
			//cleanup Go
			routine.Cleanup(routine.ExecutorFunc(cleanupGo)),
			routine.Go(routine.ExecutorFunc(ChildGo)),//child Go
			routine.Go(routine.ExecutorFunc(ChildGo)),
			routine.Go(routine.ExecutorFunc(ChildGo)),
			//signals
			routine.Signal(syscall.SIGINT, routine.SigHandler(func() {
				os.Exit(1)
			})),
		),
	)
}

Routine

create and control your own routine by routine.New.


import "github.com/x-mod/routine"

err := routine.New(opts...).Execute(ctx)

Executors

The package provides many useful executor adapters for you:

  • guarantee
  • timeout & deadline
  • retry & repeat
  • concurrent
  • crontab
  • parallel & sequence
  • command
  • profiling

with these executor adapters, you can building the most complex goroutine logic.


import "github.com/x-mod/routine"

//timeout
timeout := routine.Timeout(time.Minute, exec)

//retry
retry := routine.Retry(3, exec)

//repeat
repeat := routine.Repeat(10, time.Second, exec)

//concurrent
concurrent := routine.Concurrent(4, exec)

//schedule executor
crontab := routine.Crontab("* * * * *", exec)

//command
command := routine.Command("echo", routine.ARG("hello routine!"))

//parallel
parallel := routine.Parallel(exec1, exec2, exec3, ...)

//sequence
sequece := routine.Append(exec1, exec2, exec3, ...)

Enjoy

More details, please check the example and trace it.

$: go run example/main.go

# trace go routine & tasks
$: go tool trace  trace.out

Then you can check the tasks like this:

# Packages

No description provided by the author
No description provided by the author

# Functions

Append new.
No description provided by the author
Arguments Opt for Main.
ArgumentsFrom extract from context.
CancelSignals Opt for Main.
No description provided by the author
Cleanup Opt for Main.
Command new.
Concurrent new.
Crontab new.
Deadline new.
No description provided by the author
FromCrontab current crontab time.
FromRepeat current repeated times.
FromRetry current retied times.
Execute Opt for Main.
Guarantee insure exec NEVER PANIC.
No description provided by the author
New a routine instance.
Parallel new.
No description provided by the author
Prepare Opt for Main.
No description provided by the author
Repeat new.
Retry new.
Signal Opt for Main.
No description provided by the author
No description provided by the author
No description provided by the author
Timeout new.
Trace support.
UseExecutorMiddleware wraps a Executor in one or more middleware.
WithArgments inject into context.
No description provided by the author

# Variables

ErrNoneContext error.
ErrNoneExecutor error.
ErrNonePlan error.

# Structs

AppendExecutor.
CommandExecutor struct.
ConcurrentExecutor struct.
CrontabExecutor struct.
No description provided by the author
DeadlineExecutor struct.
GuaranteeExecutor struct, make sure of none error return.
ParallelExecutor.
Profiling.
RepeatExecutor struct.
RetryExecutor struct.
Routine Definition.
No description provided by the author
TimeoutExecutor struct.

# Interfaces

Executor interface definition.

# Type aliases

No description provided by the author
ExecutorFunc definition.
ExecutorMiddleware is a function that middlewares can implement to be able to chain.
Opt interface.
No description provided by the author