nezha/cmd/playground/main.go

158 lines
3.6 KiB
Go
Raw Normal View History

2019-12-02 09:57:14 -05:00
package main
import (
2021-06-22 02:04:07 -04:00
"context"
2021-01-16 01:11:51 -05:00
"crypto/tls"
"fmt"
2019-12-02 09:57:14 -05:00
"log"
"net"
2021-01-16 01:11:51 -05:00
"net/http"
"os"
2019-12-02 09:57:14 -05:00
"os/exec"
2021-06-22 02:04:07 -04:00
"strings"
"time"
2019-12-11 08:50:49 -05:00
"github.com/genkiroid/cert"
"github.com/go-ping/ping"
2021-02-27 06:24:19 -05:00
"github.com/shirou/gopsutil/v3/cpu"
"github.com/shirou/gopsutil/v3/disk"
2021-02-27 06:24:19 -05:00
"github.com/shirou/gopsutil/v3/host"
2021-06-22 02:04:07 -04:00
"github.com/naiba/nezha/pkg/utils"
2019-12-02 09:57:14 -05:00
)
func main() {
// icmp()
// tcpping()
2021-06-22 02:04:07 -04:00
// httpWithSSLInfo()
// sysinfo()
2021-02-27 06:24:19 -05:00
// cmdExec()
2021-06-22 02:04:07 -04:00
resolveIP("ipapi.co", true)
resolveIP("ipapi.co", false)
}
func resolveIP(addr string, ipv6 bool) {
url := strings.Split(addr, ":")
dnsServers := []string{"2606:4700:4700::1001", "2001:4860:4860::8844", "2400:3200::1", "2400:3200:baba::1"}
if !ipv6 {
dnsServers = []string{"1.0.0.1", "8.8.4.4", "223.5.5.5", "223.6.6.6"}
}
log.Println(net.LookupIP(url[0]))
for i := 0; i < len(dnsServers); i++ {
dnsServer := dnsServers[i]
if ipv6 {
dnsServer = "[" + dnsServer + "]"
}
r := &net.Resolver{
PreferGo: true,
Dial: func(ctx context.Context, network, address string) (net.Conn, error) {
d := net.Dialer{
Timeout: time.Second * 10,
}
return d.DialContext(ctx, "udp", dnsServer+":53")
},
}
log.Println(r.LookupIP(context.Background(), "ip", url[0]))
}
}
func tcpping() {
start := time.Now()
conn, err := net.DialTimeout("tcp", "example.com:80", time.Second*10)
if err != nil {
panic(err)
}
conn.Write([]byte("ping\n"))
conn.Close()
fmt.Println(time.Since(start).Microseconds(), float32(time.Since(start).Microseconds())/1000.0)
}
2021-02-27 06:24:19 -05:00
func sysinfo() {
hi, _ := host.Info()
var cpuType string
if hi.VirtualizationSystem != "" {
cpuType = "Virtual"
} else {
cpuType = "Physical"
}
cpuModelCount := make(map[string]int)
ci, _ := cpu.Info()
for i := 0; i < len(ci); i++ {
cpuModelCount[ci[i].ModelName]++
}
var cpus []string
for model, count := range cpuModelCount {
cpus = append(cpus, fmt.Sprintf("%s %d %s Core", model, count, cpuType))
}
os.Exit(0)
// 硬盘信息,不使用的原因是会重复统计 Linux、Mac
dparts, _ := disk.Partitions(false)
for _, part := range dparts {
u, _ := disk.Usage(part.Mountpoint)
if u != nil {
log.Printf("%s %d %d", part.Device, u.Total, u.Used)
}
}
}
func httpWithSSLInfo() {
2021-01-16 01:11:51 -05:00
// 跳过 SSL 检查
transCfg := &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
httpClient := &http.Client{Transport: transCfg, CheckRedirect: func(req *http.Request, via []*http.Request) error {
return http.ErrUseLastResponse
}}
url := "https://ops.naibahq.com"
resp, err := httpClient.Get(url)
fmt.Println(err, resp)
2021-01-16 01:11:51 -05:00
// SSL 证书信息获取
c := cert.NewCert(url[8:])
fmt.Println(c.Error)
}
func icmp() {
pinger, err := ping.NewPinger("10.10.10.2")
if err != nil {
panic(err) // Blocks until finished.
}
pinger.Count = 3000
pinger.Timeout = 10 * time.Second
if err = pinger.Run(); err != nil {
panic(err)
}
fmt.Println(pinger.PacketsRecv, float32(pinger.Statistics().AvgRtt.Microseconds())/1000.0)
2019-12-02 09:57:14 -05:00
}
func cmdExec() {
execFrom, err := os.Getwd()
if err != nil {
panic(err)
}
var cmd *exec.Cmd
2021-01-28 22:59:35 -05:00
pg, err := utils.NewProcessExitGroup()
if err != nil {
panic(err)
}
if utils.IsWindows() {
2021-01-29 01:29:31 -05:00
cmd = exec.Command("cmd", "/c", os.Args[1])
// cmd = exec.Command("cmd", "/c", execFrom+"/cmd/playground/example.sh hello asd")
} else {
cmd = exec.Command("sh", "-c", execFrom+`/cmd/playground/example.sh hello && \
2021-01-28 22:59:35 -05:00
echo world!`)
}
2021-01-28 22:59:35 -05:00
pg.AddProcess(cmd)
2021-01-28 21:40:57 -05:00
go func() {
2021-01-29 01:29:31 -05:00
time.Sleep(time.Second * 10)
2021-01-28 22:59:35 -05:00
if err = pg.Dispose(); err != nil {
panic(err)
2021-01-28 21:40:57 -05:00
}
2021-01-28 22:59:35 -05:00
fmt.Println("killed")
2021-01-28 21:40:57 -05:00
}()
2021-01-28 22:59:35 -05:00
output, err := cmd.Output()
log.Println("output:", string(output))
log.Println("err:", err)
2019-12-02 09:57:14 -05:00
}