Golang语言 Gin框架环境配置、报错处理、接口调用、配置和日志管理|Go主题月

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Gin框架环境配置、报错处理、接口调用、配置和日志管理

安装:
下载并安装


go get -u github.com/gin-gonic/gin


安装失败的话,直接打开 github.com/gin-gonic/gin,下载压缩包,并在GOPATH路径的src目录下面建立github.com,解压到这个目录下面;




遇到的报错信息:

Go 项目编译:cannot find package "." in:***

将缺少依赖的包重新安装一次即可解决问题。

go: inconsistent vendoring in xxx报错



修改GOPAHT,改到非GOROOT路径。GOROOT是GO语言安装路径,GOPATH是GO语言编译环境所需路径,因此二者不能为同一路径




新建项目



在GOPATH目录下面的src下面新建一个文件夹app,使用命令

go mod init


新建 main.go,写出我们的第一个程序

package main
import "github.com/gin-gonic/gin"
func main() {
  r := gin.Default()
  r.GET("/", func(c *gin.Context) {
    c.JSON(200, gin.H{
      "name": "叫我詹躲躲",
      "gend": "男",
    })
  })
  r.Run(":8080")
}


运行程序



go run main.go



浏览器运行:


生成JSON




func AsciiJSON() {
  r := gin.Default()
  r.GET("/", func(c *gin.Context) {
    c.JSON(200, gin.H{
      "name": "叫我詹躲躲",
      "gend": "男",
    })
  })
  r.Run(":8080")
}


调用


package main
import (
  "app/function"
  "github.com/gin-gonic/gin"
)
func main() {
  //使用AsciiJSON生成带有转义的非ASCII字符的纯ASCII JSON。
  function.AsciiJSON()
}



测试get请求

绑定表单数据请求与自定义结构

//绑定表单数据请求与自定义结构
type StructA struct {
  FieldA string `form:"field_a"`
}
type StructB struct {
  NestedStruct StructA
  FieldB       string `form:"field_b"`
}
//get请求
func GetFormData(c *gin.Context) {
  var b StructB
  c.Bind(&b)
  c.JSON(200, gin.H{
    "a": b.NestedStruct,
    "b": b.FieldB,
  })
}


调用

package main
import (
  "app/function"
  "github.com/gin-gonic/gin"
)
func main() {
  //将表单数据请求与自定义结构绑定
  r := gin.Default()
  //测试get请求
  r.GET("/getFormData", function.GetFormData)
  r.Run()
}




查询返回信息

//绑定查询字符串或发布数据
type PersonInfo struct {
  Name    string `form:"name"`
  Address string `form:"address"`
  Memo    string `form:"memo"`
}
//返回信息
func QueryInfo(c *gin.Context) {
  var person PersonInfo
  if c.ShouldBind(&person) == nil {
    log.Println(person.Name)
    log.Println(person.Address)
    log.Println(person.Memo)
  }
  c.String(200, "Success")
}


调用

 
         




自定义HTTP配置

http.ListenAndServe(":8080", router)


或者

s := &http.Server{
  Addr:           ":8080",
  Handler:        router,
  ReadTimeout:    10 * time.Second,
  WriteTimeout:   10 * time.Second,
  MaxHeaderBytes: 1 << 20,
}
s.ListenAndServe()


自定义日志文件

router := gin.New()
router.Use(gin.LoggerWithFormatter(func(param gin.LogFormatterParams) string {
  return fmt.Sprintf("%s - [%s] \"%s %s %s %d %s \"%s\" %s\"\n",
      param.ClientIP,
      param.TimeStamp.Format(time.RFC1123),
      param.Method,
      param.Path,
      param.Request.Proto,
      param.StatusCode,
      param.Latency,
      param.Request.UserAgent(),
      param.ErrorMessage,
  )
}))
router.Use(gin.Recovery())
router.GET("/ping", func(c *gin.Context) {
  c.String(200, "pong")
})
router.Run(":8080
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
13天前
|
Prometheus Cloud Native Go
Golang语言之Prometheus的日志模块使用案例
这篇文章是关于如何在Golang语言项目中使用Prometheus的日志模块的案例,包括源代码编写、编译和测试步骤。
20 3
Golang语言之Prometheus的日志模块使用案例
|
5天前
|
Java
日志框架log4j打印异常堆栈信息携带traceId,方便接口异常排查
日常项目运行日志,异常栈打印是不带traceId,导致排查问题查找异常栈很麻烦。
|
7天前
|
运维 NoSQL Java
SpringBoot接入轻量级分布式日志框架GrayLog技术分享
在当今的软件开发环境中,日志管理扮演着至关重要的角色,尤其是在微服务架构下,分布式日志的统一收集、分析和展示成为了开发者和运维人员必须面对的问题。GrayLog作为一个轻量级的分布式日志框架,以其简洁、高效和易部署的特性,逐渐受到广大开发者的青睐。本文将详细介绍如何在SpringBoot项目中接入GrayLog,以实现日志的集中管理和分析。
37 1
|
22天前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
|
22天前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
|
17天前
|
人工智能 Java Spring
Spring框架下,如何让你的日志管理像‘AI’一样智能,提升开发效率的秘密武器!
【8月更文挑战第31天】日志管理在软件开发中至关重要,不仅能帮助开发者追踪问题和调试程序,还是系统监控和运维的重要工具。在Spring框架下,通过合理配置Logback等日志框架,可大幅提升日志管理效率。本文将介绍如何引入日志框架、配置日志级别、在代码中使用Logger,以及利用ELK等工具进行日志聚合和分析,帮助你构建高效、可靠的日志管理系统,为开发和运维提供支持。
26 0
|
17天前
|
监控 Go 开发者
掌握Go语言中的日志管理
【8月更文挑战第31天】
10 0
|
24天前
|
存储 容器
【Azure 事件中心】为应用程序网关(Application Gateway with WAF) 配置诊断日志,发送到事件中心
【Azure 事件中心】为应用程序网关(Application Gateway with WAF) 配置诊断日志,发送到事件中心
|
25天前
|
人工智能
【Azure Application Insights】在Azure Function中启用Application Insights后,如何配置不输出某些日志到AI 的Trace中
【Azure Application Insights】在Azure Function中启用Application Insights后,如何配置不输出某些日志到AI 的Trace中
|
13天前
|
Go
Golang语言之管道channel快速入门篇
这篇文章是关于Go语言中管道(channel)的快速入门教程,涵盖了管道的基本使用、有缓冲和无缓冲管道的区别、管道的关闭、遍历、协程和管道的协同工作、单向通道的使用以及select多路复用的详细案例和解释。
43 4
Golang语言之管道channel快速入门篇