go语言实现调用阿里云api,获取hostname和ip字段值,输出exl表

简介: go语言实现调用阿里云api,获取hostname和ip字段值,输出exl表

效果


调用阿里云EMR服务API,获取集群中的主机名和ip地址,输出到exl表中

1675239813314.jpg


实现过程


例子:调用阿里云EMR服务的api,获取集群主机名和ip,输出到exl表

1、去阿里云api文档,查找接口文档

我这里只想获取集群的hostname和ip信息,所以我这里选择的是【查询集群主机列表】即可满足我的需求

1675239840439.jpg

1675239845060.jpg2、把上图右侧代码复制到自己电脑中编辑

1)使用go mod init emr初始化mod仓库

2)直接get下远程仓库代码,使用go mod tidy 自动获取依赖文件

go get github.com/alibabacloud-go/emr-20160408
go get github.com/thedevsaddam/gojsonq
• 1
• 2
go mod tidy

3)修改代码

调用阿里云api,默认返回json格式值,把它转化成字符串,在函数中_main中添加_string返回字符串类型值,得到字符串返回值赋值给HostNameIp字符串变量,gojsonq包调用这个字符串变量,截取字段值,清空覆盖输出到exl表格中

// This file is auto-generated, don't edit it. Thanks.
package main
import (
  "fmt"
  openapi "github.com/alibabacloud-go/darabonba-openapi/client"
  emr20160408 "github.com/alibabacloud-go/emr-20160408/client"
  "github.com/alibabacloud-go/tea/tea"
  "github.com/tealeg/xlsx"
  "github.com/thedevsaddam/gojsonq"
  "os"
)
var HostNameIp string
func CreateClient(accessKeyId *string, accessKeySecret *string) (_result *emr20160408.Client, _err error) {
  config := &openapi.Config{
    // 您的AccessKey ID
    AccessKeyId: accessKeyId,
    // 您的AccessKey Secret
    AccessKeySecret: accessKeySecret,
  }
  // 访问的域名
  config.Endpoint = tea.String("emr.cn-zhangjiakou.aliyuncs.com")
  _result = &emr20160408.Client{}
  _result, _err = emr20160408.NewClient(config)
  return _result, _err
}
func _main(args []*string) (_err error, _string string) {
  client, _err := CreateClient(tea.String("LTxxxxxxD95t"), tea.String("VKrUZeSH5xxxxxxxxxxxxxxxxxvAqM"))//填写AccessKey ID和AccessKey Secret
  if _err != nil {
    return _err, "登录失败"
  }
  listClusterHostRequest := &emr20160408.ListClusterHostRequest{
      StatusList: []*string{tea.String("NORMAL")}, //主机状态
    PageNumber: tea.Int32(1), //分页数
    PageSize: tea.Int32(10), //分页主机数量
    RegionId:  tea.String("cn-zhangjiakou"), //阿里云区域
    ClusterId: tea.String("C-FD39C77B200AEB73"), //集群id
  }
  // 复制代码运行请自行打印 API 的返回值
  List, _err := client.ListClusterHost(listClusterHostRequest)
  if _err != nil {
    return _err, "获取失败"
  }
  ListHostnameip := fmt.Sprint(*List)//把指针类型的值转化成字符串
  fmt.Printf("list的类型是%T", ListHostnameip)
  return _err, ListHostnameip //把得到的json格式值用string类型返回
}
func stdout() {
  jq := gojsonq.New().FromString(HostNameIp).From("body.HostList.Host").Select("HostName", "PrivateIp")//定义字段,在body下的hostlist下的host中截取hostname和privateip值
  deviceInfoList, ok := jq.Get().([]interface{})
  if !ok {
    fmt.Println("Convert deviceInfoList error")
  }
  xlsxFile := xlsx.NewFile()
  sheet, err := xlsxFile.AddSheet("Sheet 1")
  if err != nil {
    fmt.Println(err)
    os.Exit(1)
  }
  sheet.AddRow().WriteSlice(&[]string{"主机名", "IP"}, 3)
  for _, deviceInfo := range deviceInfoList {
    deviceInfoMap, ok := deviceInfo.(map[string]interface{})
    if !ok {
      fmt.Println("Convert deviceInfoMap error")
    }
    row := sheet.AddRow()
    row.AddCell().SetValue(deviceInfoMap["HostName"])
    row.AddCell().SetValue(deviceInfoMap["PrivateIp"])
  }
  xlsxFile.Save("./result.xlsx")
}
func main() {
  err, Hostnameip := _main(tea.StringSlice(os.Args[1:]))
  if err != nil {
    panic(err)
  }
  HostNameIp = fmt.Sprint(Hostnameip)
  stdout()
  //fmt.Println(HostNameIp)
}

上一段代码运行完成后会发现,出现了很多不存在的主机也被输出到xls表格中,根据阿里云提供的api字段修改,可以解决这个问题,指定主机状态和页数

1675239896181.jpg

// This file is auto-generated, don't edit it. Thanks.
package main
import (
  "fmt"
  openapi "github.com/alibabacloud-go/darabonba-openapi/client"
  emr20160408 "github.com/alibabacloud-go/emr-20160408/client"
  "github.com/alibabacloud-go/tea/tea"
  "github.com/tealeg/xlsx"
  "github.com/thedevsaddam/gojsonq"
  "os"
)
var HostNameIp string
func CreateClient(accessKeyId *string, accessKeySecret *string) (_result *emr20160408.Client, _err error) {
  config := &openapi.Config{
    // 您的AccessKey ID
    AccessKeyId: accessKeyId,
    // 您的AccessKey Secret
    AccessKeySecret: accessKeySecret,
  }
  // 访问的域名
  config.Endpoint = tea.String("emr.cn-zhangjiakou.aliyuncs.com")
  _result = &emr20160408.Client{}
  _result, _err = emr20160408.NewClient(config)
  return _result, _err
}
func _main(args []*string) (_err error, _string string) {
  client, _err := CreateClient(tea.String("LTxxxxxxxxxxxxxxxxxxt"), tea.String("VKrUZeS9oDxxxxxxxxxxxxxxxxxxM"))//填写AccessKey ID和AccessKey Secret
  if _err != nil {
    return _err, "登录失败"
  }
  listClusterHostRequest := &emr20160408.ListClusterHostRequest{
    RegionId:  tea.String("cn-zhangjiakou"), //阿里云区域
    ClusterId: tea.String("C-FD39C77B200AEB73"), //集群id
    PageNumber: tea.Int32(1),
    PageSize: tea.Int32(10),
    // Array, 可选, 主机状态列表:  - NORMAL:正常  - ABNORMAL:异常  - RESIZING:配置中  - INITIALIZING:初始化中  - RELEASED:已释放
    StatusList: []*string{tea.String("NORMAL")},
  }
  // 复制代码运行请自行打印 API 的返回值
  List, _err := client.ListClusterHost(listClusterHostRequest)
  if _err != nil {
    return _err, "获取失败"
  }
  ListHostnameip := fmt.Sprint(*List)//把指针类型的值转化成字符串
  fmt.Printf("list的类型是%T", ListHostnameip)
  return _err, ListHostnameip //把得到的json格式值用string类型返回
}
func stdout() {
  jq := gojsonq.New().FromString(HostNameIp).From("body.HostList.Host").Select("HostName", "PrivateIp")//定义字段,在body下的hostlist下的host中截取hostname和privateip值
  deviceInfoList, ok := jq.Get().([]interface{})
  if !ok {
    fmt.Println("Convert deviceInfoList error")
  }
  xlsxFile := xlsx.NewFile()
  sheet, err := xlsxFile.AddSheet("Sheet 1")
  if err != nil {
    fmt.Println(err)
    os.Exit(1)
  }
  sheet.AddRow().WriteSlice(&[]string{"主机名", "IP"}, 3)
  for _, deviceInfo := range deviceInfoList {
    deviceInfoMap, ok := deviceInfo.(map[string]interface{})
    if !ok {
      fmt.Println("Convert deviceInfoMap error")
    }
    row := sheet.AddRow()
    row.AddCell().SetValue(deviceInfoMap["HostName"])
    row.AddCell().SetValue(deviceInfoMap["PrivateIp"])
  }
  xlsxFile.Save("./result.xlsx")
}
func main() {
  err, Hostnameip := _main(tea.StringSlice(os.Args[1:]))
  if err != nil {
    panic(err)
  }
  HostNameIp = fmt.Sprint(Hostnameip)
  stdout()
  //fmt.Println(HostNameIp)
}

再次打开xls表格,会发现与现有集群信息一致

1675239922177.jpg


相关文章
|
5天前
|
存储 Go
Go 语言入门指南:切片
Golang中的切片(Slice)是基于数组的动态序列,支持变长操作。它由指针、长度和容量三部分组成,底层引用一个连续的数组片段。切片提供灵活的增减元素功能,语法形式为`[]T`,其中T为元素类型。相比固定长度的数组,切片更常用,允许动态调整大小,并且多个切片可以共享同一底层数组。通过内置的`make`函数可创建指定长度和容量的切片。需要注意的是,切片不能直接比较,只能与`nil`比较,且空切片的长度为0。
Go 语言入门指南:切片
|
4天前
|
开发框架 前端开发 Go
eino — 基于go语言的大模型应用开发框架(二)
本文介绍了如何使用Eino框架实现一个基本的LLM(大语言模型)应用。Eino中的`ChatModel`接口提供了与不同大模型服务(如OpenAI、Ollama等)交互的统一方式,支持生成完整响应、流式响应和绑定工具等功能。`Generate`方法用于生成完整的模型响应,`Stream`方法以流式方式返回结果,`BindTools`方法为模型绑定工具。此外,还介绍了通过`Option`模式配置模型参数及模板功能,支持基于前端和用户自定义的角色及Prompt。目前主要聚焦于`ChatModel`的`Generate`方法,后续将继续深入学习。
89 6
|
5天前
|
存储 开发框架 Devops
eino — 基于go语言的大模型应用开发框架(一)
Eino 是一个受开源社区优秀LLM应用开发框架(如LangChain和LlamaIndex)启发的Go语言框架,强调简洁性、可扩展性和可靠性。它提供了易于复用的组件、强大的编排框架、简洁明了的API、最佳实践集合及实用的DevOps工具,支持快速构建和部署LLM应用。Eino不仅兼容多种模型库(如OpenAI、Ollama、Ark),还提供详细的官方文档和活跃的社区支持,便于开发者上手使用。
61 8
|
5天前
|
存储 算法 Go
Go语言实战:错误处理和panic_recover之自定义错误类型
本文深入探讨了Go语言中的错误处理和panic/recover机制,涵盖错误处理的基本概念、自定义错误类型的定义、panic和recover的工作原理及应用场景。通过具体代码示例介绍了如何定义自定义错误类型、检查和处理错误值,并使用panic和recover处理运行时错误。文章还讨论了错误处理在实际开发中的应用,如网络编程、文件操作和并发编程,并推荐了一些学习资源。最后展望了未来Go语言在错误处理方面的优化方向。
|
5天前
|
网络协议 算法 安全
Go语言的网络编程与TCP_UDP
Go语言由Google开发,旨在简单、高效和可扩展。本文深入探讨Go语言的网络编程,涵盖TCP/UDP的基本概念、核心算法(如滑动窗口、流量控制等)、最佳实践及应用场景。通过代码示例展示了TCP和UDP的实现,并讨论了其在HTTP、DNS等协议中的应用。最后,总结了Go语言网络编程的未来发展趋势与挑战,推荐了相关工具和资源。
|
1天前
|
SQL 安全 Java
阿里双十一背后的Go语言实践:百万QPS网关的设计与实现
解析阿里核心网关如何利用Go协程池、RingBuffer、零拷贝技术支撑亿级流量。 重点分享: ① 如何用gRPC拦截器实现熔断限流; ② Sync.Map在高并发读写中的取舍。
|
2天前
|
存储 算法 安全
基于 Go 语言的公司内网管理软件哈希表算法深度解析与研究
在数字化办公中,公司内网管理软件通过哈希表算法保障信息安全与高效管理。哈希表基于键值对存储和查找,如用户登录验证、设备信息管理和文件权限控制等场景,Go语言实现的哈希表能快速验证用户信息,提升管理效率,确保网络稳定运行。
12 0
|
8天前
|
算法 安全 Go
公司局域网管理系统里的 Go 语言 Bloom Filter 算法,太值得深挖了
本文探讨了如何利用 Go 语言中的 Bloom Filter 算法提升公司局域网管理系统的性能。Bloom Filter 是一种高效的空间节省型数据结构,适用于快速判断元素是否存在于集合中。文中通过具体代码示例展示了如何在 Go 中实现 Bloom Filter,并应用于局域网的 IP 访问控制,显著提高系统响应速度和安全性。随着网络规模扩大和技术进步,持续优化算法和结合其他安全技术将是企业维持网络竞争力的关键。
24 2
公司局域网管理系统里的 Go 语言 Bloom Filter 算法,太值得深挖了
|
15天前
|
监控 Linux PHP
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
65 20
|
21天前
|
Go C语言
Go语言入门:分支结构
本文介绍了Go语言中的条件语句,包括`if...else`、`if...else if`和`switch`结构,并通过多个练习详细解释了它们的用法。`if...else`用于简单的条件判断;`if...else if`处理多条件分支;`switch`则适用于基于不同值的选择逻辑。特别地,文章还介绍了`fallthrough`关键字,用于优化重复代码。通过实例如判断年龄、奇偶数、公交乘车及成绩等级等,帮助读者更好地理解和应用这些结构。
37 15

热门文章

最新文章