这篇文章主要介绍了GoWeb编程添加服务器错误和访问日志的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇GoWeb编程添加服务器错误和访问日志的方法文章都会有所收获,下面我们一起来看看吧。我们先来做一下初始化工作,在项目里初始化记录错误日志和访问日志的记录器Logger
。我们新定义一个package
在init
函数中来初始化记录器,这样服务器成功启动前就会初始化好记录器。/tmp/log
这个目免费云主机域名录要提前创建好,执行init
函数时会自动创建好access.log
和error.log
。我们创建服务器使用的net/http
包的Server
类型中,有一个ErrorLog
字段供开发者设置记录错误日志用的记录器Logger
,默认使用的是log
包默认的记录器(应该是系统的标准错误):我们之前在创建服务器的时候自己实现了Server
类型的对象,那么现在要做的就是将上面初始化好的错误日志的记录器指定给Server
的ErrorLog
字段。添加好错误日志的记录器后,我们找个路由处理函数,在里面故意制造运行时错误验证一下是否能记录到错误。在上面处理函数中,通过切片表达式越界故意制造了一个运行时错误,打开error.log
后能看到文件里已经记录到这个运行时错误及其Stack trace
和Server
对象可以设置错误日志的记录器不一样,访问日志只能是我们通过自己编写中间件的方式来实现了。在记录访问日志的中间件里我们会记录ip
,method
,path
,query
,request_body
,status
和response_body
这些个字段的内容。status
和response_body
两个字段来自请求对应的响应。响应在net/http
包里是用http.ResponseWriter
接口表示的接口本身以及net/http
提供的实现都没有让我们进行读取的方法,所以在编写的用于记录访问日志的中间件里需要对net/http
库本身实现的ResponseWriter
做一层包装。利用Go
语言结构体类型嵌套匿名类型后,结构体拥有了被嵌套类型的所有导出字段和方法的特性,我们可以很方便地对原来的ResponseWriter
做一层包装,然后只重新实现需要更改的方法即可:定义好新的类型后我们重新实现了WriteHeader
和Write
方法,在向原来的ReponseWriter
中写入后也会向ResponseWriteRecoder.statusCode和ResponseWriteRecoder.body写入对应的数据。这样我们就可以在中间件里通过这两个字段访问响应码和响应数据了。记录访问日志的中间件定义如下:在Router
上应用创建好的AccessLogging
中间件后,就可以正常的记录服务器的访问日志了。不过有两点需要注意一下这里为了演示获取响应数据记录了response_body
字段,如果是接口响应内容记录下还可以,但是如果是HTML
还是不记录的为好。初始化ResponseWithRecorder
时默认设置了statusCode
是因为,服务器正确返回响应时不会显式调用WriteHeader
方法,只有在返回NOT_FOUND
之类的错误的时候才会调用WriteHeader
方法,针对这种情况需要在初始化的时候把statusCode
的默认值设置为200
。现在再访问服务器后打开access.log
会看到刚刚的访问日志,就能看到刚刚请求的url
,method
,客户端IP等信息了。{“ip”:”……”,”level”:”info”,”method”:”GET”,”msg”:””,”path”:”/index/”,”query”:””,”request_body”:””,”response_body”:”HelloWorld1″,”status”:200,”time”:”2020-03-26T04:21:46Z”}注意:文章只为说明演示方便,获取IP的方法无法获取代理后的真实IP,请悉知。关于“GoWeb编程添加服务器错误和访问日志的方法”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“GoWeb编程添加服务器错误和访问日志的方法”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注百云主机行业资讯频道。
这篇文章主要介绍“react是Spa吗”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“react是Spa吗”文章能帮助大家解决问题。 react是Spa模式,即组件嵌套,其主要的传参方式有:1、在挂载的地方给组件传参;2…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。