summaryrefslogtreecommitdiff
path: root/cmd/cli
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2020-12-23 23:35:44 +0300
committerValery Piashchynski <[email protected]>2020-12-23 23:35:44 +0300
commite78c13d93a729a9008f283aa3db6910f3e833165 (patch)
treee633604841b80c42b195388429dc12349e4b9d1f /cmd/cli
parentc21fe8e2f99c3cb8e3c1482e35f2efa0e914c337 (diff)
Initial implementation of serve, reset, workers commands for the RR2
Diffstat (limited to 'cmd/cli')
-rw-r--r--cmd/cli/reset.go19
-rw-r--r--cmd/cli/root.go45
-rw-r--r--cmd/cli/serve.go19
-rw-r--r--cmd/cli/workers.go29
4 files changed, 38 insertions, 74 deletions
diff --git a/cmd/cli/reset.go b/cmd/cli/reset.go
index 82cf8590..03b470e5 100644
--- a/cmd/cli/reset.go
+++ b/cmd/cli/reset.go
@@ -7,10 +7,14 @@ import (
"github.com/fatih/color"
"github.com/mattn/go-runewidth"
"github.com/spf13/cobra"
+ "github.com/spiral/errors"
"github.com/vbauerster/mpb/v5"
"github.com/vbauerster/mpb/v5/decor"
)
+const List string = "resetter.List"
+const Reset string = "resetter.Reset"
+
func init() {
root.AddCommand(&cobra.Command{
Use: "reset",
@@ -20,19 +24,22 @@ func init() {
}
func resetHandler(cmd *cobra.Command, args []string) error {
+ const op = errors.Op("reset handler")
client, err := RPCClient()
if err != nil {
return err
}
- defer client.Close()
+ defer func() {
+ _ = client.Close()
+ }()
var services []string
if len(args) != 0 {
services = args
} else {
- err = client.Call("resetter.List", true, &services)
+ err = client.Call(List, true, &services)
if err != nil {
- return err
+ return errors.E(op, err)
}
}
@@ -43,7 +50,7 @@ func resetHandler(cmd *cobra.Command, args []string) error {
for _, service := range services {
var (
bar *mpb.Bar
- name = runewidth.FillRight(fmt.Sprintf("Reset [%s]", color.HiYellowString(service)), 27)
+ name = runewidth.FillRight(fmt.Sprintf("Resetting plugin: [%s]", color.HiYellowString(service)), 27)
result = make(chan interface{})
)
@@ -61,9 +68,9 @@ func resetHandler(cmd *cobra.Command, args []string) error {
defer bar.Increment()
var done bool
- err = client.Call("resetter.Reset", service, &done)
+ err = client.Call(Reset, service, &done)
if err != nil {
- result <- err
+ result <- errors.E(op, err)
return
}
result <- nil
diff --git a/cmd/cli/root.go b/cmd/cli/root.go
index 00d192f6..febe410b 100644
--- a/cmd/cli/root.go
+++ b/cmd/cli/root.go
@@ -8,12 +8,9 @@ import (
"github.com/spiral/errors"
goridgeRpc "github.com/spiral/goridge/v3/pkg/rpc"
- "github.com/spiral/roadrunner-plugins/logger"
rpcPlugin "github.com/spiral/roadrunner-plugins/rpc"
"github.com/spiral/roadrunner-plugins/config"
- "go.uber.org/zap"
- "go.uber.org/zap/zapcore"
"github.com/spf13/cobra"
"github.com/spiral/endure"
@@ -23,7 +20,6 @@ var (
WorkDir string
CfgFile string
Container *endure.Endure
- Logger *zap.Logger
cfg *config.Viper
root = &cobra.Command{
Use: "rr",
@@ -43,10 +39,6 @@ func init() {
root.PersistentFlags().StringVarP(&CfgFile, "config", "c", ".rr.yaml", "config file (default is .rr.yaml)")
root.PersistentFlags().StringVarP(&WorkDir, "WorkDir", "w", "", "work directory")
- // todo: properly handle debug level
- Logger = initLogger()
- // endureLogger := logger.NewZapAdapter(Logger)
-
cobra.OnInitialize(func() {
if CfgFile != "" {
if absPath, err := filepath.Abs(CfgFile); err == nil {
@@ -65,24 +57,19 @@ func init() {
}
}
- // todo: config is global, not only for serve
cfg = &config.Viper{}
cfg.Path = CfgFile
cfg.Prefix = "rr"
+ // register config
err := Container.Register(cfg)
if err != nil {
panic(err)
}
-
- err = Container.Register(&logger.ZapLogger{})
- if err != nil {
- panic(err)
- }
})
}
-// todo: improve
+// RPCClient is using to make a requests to the ./rr reset, ./rr workers
func RPCClient() (*rpc.Client, error) {
rpcConfig := &rpcPlugin.Config{}
@@ -108,31 +95,3 @@ func RPCClient() (*rpc.Client, error) {
return rpc.NewClientWithCodec(goridgeRpc.NewClientCodec(conn)), nil
}
-
-func initLogger() *zap.Logger {
- // todo: we do not need it
- cfg := zap.Config{
- Level: zap.NewAtomicLevelAt(zap.ErrorLevel),
- Encoding: "console",
- EncoderConfig: zapcore.EncoderConfig{
- MessageKey: "message",
- LevelKey: "level",
- TimeKey: "time",
- CallerKey: "caller",
- NameKey: "name",
- StacktraceKey: "stack",
- EncodeLevel: zapcore.CapitalLevelEncoder,
- EncodeTime: zapcore.ISO8601TimeEncoder,
- EncodeCaller: zapcore.ShortCallerEncoder,
- },
- OutputPaths: []string{"stderr"},
- ErrorOutputPaths: []string{"stderr"},
- }
-
- l, err := cfg.Build(zap.AddCaller())
- if err != nil {
- panic(err)
- }
-
- return l
-}
diff --git a/cmd/cli/serve.go b/cmd/cli/serve.go
index ace239fc..2fe54932 100644
--- a/cmd/cli/serve.go
+++ b/cmd/cli/serve.go
@@ -1,20 +1,20 @@
package cli
import (
+ "log"
"os"
"os/signal"
"syscall"
- "github.com/spiral/errors"
- "go.uber.org/zap"
-
"github.com/spf13/cobra"
+ "github.com/spiral/errors"
+ "go.uber.org/multierr"
)
func init() {
root.AddCommand(&cobra.Command{
Use: "serve",
- Short: "Start RoadRunner Temporal service(s)",
+ Short: "Start RoadRunner server",
RunE: handler,
})
}
@@ -25,6 +25,7 @@ func handler(cmd *cobra.Command, args []string) error {
We need to have path to the config at the RegisterTarget stage
But after cobra.Execute, because cobra fills up cli variables on this stage
*/
+
err := Container.Init()
if err != nil {
return errors.E(op, err)
@@ -43,14 +44,14 @@ func handler(cmd *cobra.Command, args []string) error {
for {
select {
case e := <-errCh:
- Logger.Error(e.Error.Error(), zap.String("service", e.VertexID))
+ err = multierr.Append(err, e.Error)
+ log.Printf("error occurred: %v, service: %s", e.Error.Error(), e.VertexID)
er := Container.Stop()
if er != nil {
- Logger.Error(e.Error.Error(), zap.String("service", e.VertexID))
- if er != nil {
- return errors.E(op, er)
- }
+ err = multierr.Append(err, er)
+ return errors.E(op, err)
}
+ return errors.E(op, err)
case <-c:
err = Container.Stop()
if err != nil {
diff --git a/cmd/cli/workers.go b/cmd/cli/workers.go
index e9c8ab2c..4bcbbdbd 100644
--- a/cmd/cli/workers.go
+++ b/cmd/cli/workers.go
@@ -2,27 +2,25 @@ package cli
import (
"fmt"
+ "log"
"net/rpc"
"os"
- "os/signal"
- "syscall"
"time"
tm "github.com/buger/goterm"
- "github.com/spiral/errors"
- "github.com/spiral/roadrunner/v2/tools"
- "go.uber.org/zap"
-
"github.com/fatih/color"
"github.com/spf13/cobra"
+ "github.com/spiral/errors"
"github.com/spiral/roadrunner-plugins/informer"
+ "github.com/spiral/roadrunner/v2/tools"
)
var (
interactive bool
- stopSignal = make(chan os.Signal, 1)
)
+const InformerList string = "informer.List"
+
func init() {
workersCommand := &cobra.Command{
Use: "workers",
@@ -39,13 +37,11 @@ func init() {
)
root.AddCommand(workersCommand)
-
- signal.Notify(stopSignal, syscall.SIGTERM)
- signal.Notify(stopSignal, syscall.SIGINT)
}
func workersHandler(cmd *cobra.Command, args []string) error {
const op = errors.Op("workers handler")
+ // get RPC client
client, err := RPCClient()
if err != nil {
return err
@@ -53,17 +49,18 @@ func workersHandler(cmd *cobra.Command, args []string) error {
defer func() {
err := client.Close()
if err != nil {
- Logger.Error("error when closing RPCClient", zap.Error(err))
+ log.Printf("error when closing RPCClient: error %v", err)
}
}()
var plugins []string
+ // assume user wants to show workers from particular plugin
if len(args) != 0 {
plugins = args
} else {
- err = client.Call("informer.List", true, &plugins)
+ err = client.Call(InformerList, true, &plugins)
if err != nil {
- return err
+ return errors.E(op, err)
}
}
@@ -72,11 +69,11 @@ func workersHandler(cmd *cobra.Command, args []string) error {
}
tm.Clear()
+ tt := time.NewTicker(time.Second)
+ defer tt.Stop()
for {
select {
- case <-stopSignal:
- return nil
- case <-time.NewTicker(time.Second).C:
+ case <-tt.C:
tm.MoveCursor(1, 1)
err := showWorkers(plugins, client)
if err != nil {