Skip to content
This repository has been archived by the owner on Nov 12, 2024. It is now read-only.

Commit

Permalink
feat - mysql top
Browse files Browse the repository at this point in the history
  • Loading branch information
Nicola Strappazzon C committed Nov 19, 2023
1 parent 58ed637 commit bf3ff00
Show file tree
Hide file tree
Showing 9 changed files with 130 additions and 11 deletions.
5 changes: 3 additions & 2 deletions aws/database/describe/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,9 @@ func NewCommand() *cobra.Command {
return
}

tbl := table.New("ATTRIBUTE", "VALUE")
tbl.Column(0, table.Column{Alignment: table.Right})
tbl := table.New()
tbl.Column(0, table.Column{Name: "ATTRIBUTE", Alignment: table.Right})
tbl.Column(1, table.Column{Name: "VALUE"})
for k, v := range instance.JSON() {
tbl.Add(k, v)
}
Expand Down
4 changes: 3 additions & 1 deletion aws/database/logs/list/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,9 @@ func NewCommand() *cobra.Command {
logs.SortBySize()
}

tbl := table.New("FILE", "SIZE")
tbl := table.New()
tbl.Column(0, table.Column{Name: "File"})
tbl.Column(1, table.Column{Name: "Size"})
for _, log := range logs {
tbl.Add(log.FileName, log.Size)
}
Expand Down
7 changes: 6 additions & 1 deletion aws/database/parameters/describe/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,12 @@ func NewCommand() *cobra.Command {
return
}

tbl := table.New("NAME", "VALUES", "APPLY METHOD", "APPLY TYPE", "MODIFIABLE")
tbl := table.New()
tbl.Column(0, table.Column{Name: "NAME"})
tbl.Column(1, table.Column{Name: "VALUES"})
tbl.Column(2, table.Column{Name: "APPLY METHOD"})
tbl.Column(3, table.Column{Name: "APPLY TYPE"})
tbl.Column(4, table.Column{Name: "MODIFIABLE"})
for _, parameter := range parameters {
tbl.Add(parameter.Name, parameter.Value, parameter.ApplyMethod, parameter.ApplyType, parameter.IsModifiable)
}
Expand Down
5 changes: 4 additions & 1 deletion aws/database/parameters/list/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,10 @@ func NewCommand() *cobra.Command {
return
}

tbl := table.New("NAME", "DESCRIPTION", "FAMILY")
tbl := table.New()
tbl.Column(0, table.Column{Name: "NAME"})
tbl.Column(1, table.Column{Name: "DESCRIPTION"})
tbl.Column(2, table.Column{Name: "FAMILY"})
for _, parameter := range parameters {
tbl.Add(parameter.Name, parameter.Description, parameter.Family)
}
Expand Down
7 changes: 6 additions & 1 deletion aws/databases/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,12 @@ func NewCommand() *cobra.Command {

instances := r.List()

tbl := table.New("ENGINE", "VERSION", "IDENTIFIER", "CLASS", "STATUS")
tbl := table.New()
tbl.Column(0, table.Column{Name: "ENGINE"})
tbl.Column(1, table.Column{Name: "VERSION"})
tbl.Column(2, table.Column{Name: "IDENTIFIER"})
tbl.Column(3, table.Column{Name: "CLASS"})
tbl.Column(4, table.Column{Name: "STATUS"})
for _, instance := range instances {
tbl.Add(instance.Engine, instance.Version, instance.Identifier, instance.Class, instance.Status)
}
Expand Down
2 changes: 2 additions & 0 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -39,3 +39,5 @@ require (
golang.org/x/sys v0.14.0 // indirect
golang.org/x/text v0.14.0 // indirect
)

replace github.com/debeando/go-common => /Users/nsc/go/src/github.com/debeando/go-common
13 changes: 8 additions & 5 deletions mysql/digest/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,14 @@ func NewCommand() *cobra.Command {
queries.Analyzed(),
queries.Unique()))

tbl := table.New(
"DIGEST ID", "SCORE", "COUNT", "Q. TIME",
"L. TIME", "R. SENT", "R. EXAMINED",
)

tbl := table.New()
tbl.Column(0, table.Column{Name: "DIGEST ID"})
tbl.Column(1, table.Column{Name: "SCORE"})
tbl.Column(2, table.Column{Name: "COUNT"})
tbl.Column(3, table.Column{Name: "Q. TIME"})
tbl.Column(4, table.Column{Name: "L. TIME"})
tbl.Column(5, table.Column{Name: "R. SENT"})
tbl.Column(6, table.Column{Name: "R. EXAMINED"})
queries.Clean()
queries.SortByScore()

Expand Down
2 changes: 2 additions & 0 deletions mysql/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package mysql

import (
"zenit/mysql/digest"
"zenit/mysql/top"

"github.com/spf13/cobra"
)
Expand All @@ -16,6 +17,7 @@ func NewCommand() *cobra.Command {
}

cmd.AddCommand(digest.NewCommand())
cmd.AddCommand(top.NewCommand())

return cmd
}
96 changes: 96 additions & 0 deletions mysql/top/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
package top

import (
"fmt"
"time"

"github.com/debeando/go-common/aws/rds"
"github.com/debeando/go-common/log"
"github.com/debeando/go-common/mysql"
"github.com/debeando/go-common/table"
"github.com/debeando/go-common/terminal"

"github.com/spf13/cobra"
)

func NewCommand() *cobra.Command {
defer terminal.Show()

var cmd = &cobra.Command{
Use: "top [IDENTIFIER]",
Short: "Display MySQL server performance info like 'top'.",
Run: func(cmd *cobra.Command, args []string) {
if len(args) != 1 {
cmd.Help()
return
}

r := rds.RDS{}

if err := r.Init(); err != nil {
log.Error(err.Error())
return
}

instance, err := r.Describe(args[0])
if err != nil {
fmt.Println(err)
return
}

fmt.Printf("Connecting to %s:%d ...\n", instance.Endpoint, instance.Port)

m := mysql.New("", fmt.Sprintf("monitor:monitor@tcp(%s:%d)/information_schema?timeout=3s", instance.Endpoint, instance.Port))
m.Connect()

terminal.Reset()
terminal.Clear()
terminal.Flush()
terminal.Hide()

for i := 0; i < 100; i++ {
// terminal.Reset()
// terminal.Clear()
// terminal.Flush()
// Save the cursor position
fmt.Print("\x1B7") // Save the cursor position
fmt.Print("\x1B[2K") // Erase the entire line
fmt.Print("\x1B[0J") // Erase from cursor to end of screen
fmt.Print("\x1B[?47h") // Save screen
fmt.Print("\x1B[1J") // Erase from cursor to beginning of screen
fmt.Print("\x1B[?47l") // Restore screen
defer fmt.Print("\x1B8") // Restore the cursor position util new size is calculated

terminal.Cursor(0,0)
// terminal.Refresh(func() {
// ocultar la query de exploracion.
processlist, _ := m.Query("SELECT id, user, host, db, command, time, state, info FROM information_schema.processlist WHERE id <> connection_id() AND length(info) > 0 AND command NOT IN ('Daemon', 'Sleep') AND user NOT IN ('rdsadmin');")

tbl := table.New()
tbl.Title("Process List")
tbl.Column(0, table.Column{Name: "Time"})
tbl.Column(1, table.Column{Name: "Query", Truncate: 80, Width: 80})
for _, row := range processlist {
tbl.Add(row["time"], row["info"])
}
tbl.Print()
time.Sleep(100 * time.Millisecond)
}

terminal.Show()

// busca user y pass en config.
// si existe las usa.
// sino existen, usa las definidas en el env var.
// poner sobre las env var en la help.

// cnf := config.GetInstance()
// cnf.Load()
// for host := range cnf.Inputs.MySQL {
// fmt.Println(cnf.Inputs.MySQL[host])
// }
},
}

return cmd
}

0 comments on commit bf3ff00

Please sign in to comment.