Go 语言是一种非常流行的编程语言,它可以用来开发各种应用,包括 Web 服务器。Go 语言提供了一个非常强大的 Web 框架,可以快速构建出功能强大的 Web 服务器。
Go 语言的 Web 服务器有很多优点,其中最重要的是性能。Go 语言使用了 Go 协程来处理并发请求,这样就可以在单个机器上处理大量请求。此外,Go 语言还使用了内存映射文件来存储静态文件,这样就可以大大减少内存占用。
Go 语言的 Web 服务器也很容易上手。它使用了一个非常直观的 API 来处理 HTTP 请求,开发者只需要定义一个函数来处理请求即可。此外,Go 还提供了一个标准库来处理常见的 HTTP 任务,如 Cookie 管理、文件上传、表单数据等。
func handler(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "Hello World!") }
此外,Go 还有一个强大的中间件框架 Gin ,它允许开发者快速地创建 RESTful API 和 Web 应用程序。Gin 使用了 Go 的标准库来实现 HTTP 处理流程,并提供了一套方便易用的 API 来创建中间件、Router 和 Handler 等。
GoFrame
框架的WebServer
配置管理非常方便,支持多种配置方式以及若干配置方法。
配置对象定义: https://pkg.go.dev/github.com/gogf/gf/v2/net/ghttp#ServerConfig
方法列表: https://pkg.go.dev/github.com/gogf/gf/v2/net/ghttp#Server
简要说明:
SetConfig
及SetConfigWithMap
来设置。
Server
对象的Set*
/Enable*
方法进行特定配置的设置。
Server
执行Start
之后便不能再修改,防止产生并发安全问题。我们可以使用SetConfigWithMap
方法通过Key-Value
键值对来设置/修改Server
的特定配置,其余的配置使用默认配置即可。其中Key
的名称即是ServerConfig
这个struct
中的属性名称,并且不区分大小写,单词间也支持使用-
/_
/空格符号连接。
简单示例:
s := g.Server()
s.SetConfigWithMap(g.Map{
"Address": ":80",
"ServerRoot": "/var/www/MyServerRoot",
})
s.Run()
其中ServerRoot
的键名也可以使用serverRoot
, server-root
, server_root
, server root
,其他配置属性以此类推。
一个比较完整的示例:
s := g.Server()
s.SetConfigWithMap(g.Map{
"address": ":80",
"serverRoot": "/var/www/Server",
"indexFiles": g.Slice{"index.html", "main.html"},
"accessLogEnabled": true,
"errorLogEnabled": true,
"pprofEnabled": true,
"logPath": "/var/log/ServerLog",
"sessionIdName": "MySessionId",
"sessionPath": "/tmp/MySessionStoragePath",
"sessionMaxAge": 24 * time.Hour,
"dumpRouterMap": false,
})
s.Run()
Server
对象也支持通过配置文件进行便捷的配置。支持的配置选项以及配置说明请查看接口文档说明,文档中有详细说明,以下章节不会对配置选项作介绍。
当使用g.Server
(单例名称)获取Server
单例对象时,将会自动通过默认的配置管理对象获取对应的Server
配置。默认情况下会读取server
.单例名称配置项,当该配置项不存在时,将会读取server
配置项。
支持的配置文件配置项请参考Server
配置管理对象属性:https://pkg.go.dev/github.com/gogf/gf/v2/net/ghttp#ServerConfig
[server]
address = ":80"
serverRoot = "/var/www/Server"
随后可以使用g.Server()
获取默认的单例对象时自动获取并设置该配置。
多个Server
的配置示例:
[server]
address = ":80"
serverRoot = "/var/www/Server"
[server.server1]
address = ":8080"
serverRoot = "/var/www/Server1"
[server.server2]
address = ":8088"
serverRoot = "/var/www/Server2"
我们可以通过单例对象名称获取对应配置的Server
单例对象:
// 对应 server.server1 配置项
s1 := g.Server("server1")
// 对应 server.server2 配置项
s2 := g.Server("server2")
// 对应默认配置项 server
s3 := g.Server("none")
// 对应默认配置项 server
s4 := g.Server()
比如上一个章节的示例,对应的配置文件如下:
[server]
address = ":8199"
serverRoot = "/var/www/Server"
indexFiles = ["index.html", "main.html"]
accessLogEnabled = true
errorLogEnabled = true
pprofEnabled = true
logPath = "/var/log/ServerLog"
sessionIdName = "MySessionId"
sessionPath = "/tmp/MySessionStoragePath"
sessionMaxAge = "24h"
dumpRouterMap = false
同理,配置属性项的名称也不区分大小写,单词间也支持使用-
/_
符号连接。也就是说以下配置文件效果和上面的配置文件一致:
[server]
address = ":8199"
serverRoot = "/var/www/Server"
indexFiles = ["index.html", "main.html"]
accessLogEnabled = true
errorLogEnabled = true
pprofEnabled = true
log-path = "/var/log/ServerLog"
session_Id_Name = "MySessionId"
Session-path = "/tmp/MySessionStoragePath"
session_MaxAge = "24h"
DumpRouterMap = false
我们推荐配置文件中的配置项名称统一使用小驼峰的格式。
Server
对于客户端提交的数据是由大小限制的,主要有两个配置参数控制:
MaxHeaderBytes
:请求头大小限制,请求头包括客户端提交的Cookie
数据,默认设置为10KB。
ClientMaxBodySize
:客户端提交的Body
大小限制,同时也影响文件上传大小,默认设置为8MB。由于安全性的考虑,默认的上传限制都不是很高,特别是ClientMaxBodySize
的大小限制,在需要文件上传的场景可适当考虑调整,通过配置文件配置即可,例如:
[server]
maxHeaderBytes = "20KB"
clientMaxBodySize = "200MB"
这样便修改请求头大小限制为20KB
,文件上传大小限制为200MB
。如果不想做上传大小做任何限制,那么将clientMaxBodySize
设置为0即可。
从v2版本开始,Server
增加了对配置文件中Logger
的配置项支持,主要是为了统一日志组件配置、并解决日志滚动切分的问题。配置示例:
[server]
address = ":8080"
[server.logger]
path = "/var/log/server"
file = "{Y-m-d}.log"
stdoutPrint = false
rotateSize = "100M"
rotateBackupLimit = 10
rotateBackupExpire = "60d"
rotateBackupCompress = 9
rotateCheckInterval = "24h"
所有的配置项请参考ServerConfig
对象属性: https://pkg.go.dev/github.com/gogf/gf/v2/net/ghttp#ServerConfig
以下为配置示例文件:
[server]
# 基本配置
address = ":80" # 本地监听地址。默认":80"
httpsAddr = ":443" # TLS/HTTPS配置,同时需要配置证书和密钥。默认关闭
httpsCertPath = "" # TLS/HTTPS证书文件本地路径,建议使用绝对路径。默认关闭
httpsKeyPath = "" # TLS/HTTPS密钥文件本地路径,建议使用绝对路径。默认关闭
readTimeout = "60s" # 请求读取超时时间,一般不需要配置。默认为60秒
writeTimeout = "0" # 数据返回写入超时时间,一般不需要配置。默认不超时(0)
idleTimeout = "60s" # 仅当Keep-Alive开启时有效,请求闲置时间。默认为60秒
maxHeaderBytes = "10240" # 请求Header大小限制(Byte)。默认为10KB
keepAlive = true # 是否开启Keep-Alive功能。默认true
serverAgent = "GoFrame HTTP Server" # 服务端Agent信息。默认为"GoFrame HTTP Server"
# 静态服务配置
indexFiles = ["index.html","index.htm"] # 自动首页静态文件检索。默认为["index.html", "index.htm"]
indexFolder = false # 当访问静态文件目录时,是否展示目录下的文件列表。默认关闭,那么请求将返回403
serverRoot = "/var/www" # 静态文件服务的目录根路径,配置时自动开启静态文件服务。默认关闭
searchPaths = ["/home/www","/var/lib/www"] # 提供静态文件服务时额外的文件搜索路径,当根路径找不到时则按照顺序在搜索目录查找。默认关闭
fileServerEnabled = false # 静态文件服务总开关。默认false
# Cookie配置
cookieMaxAge = "365d" # Cookie有效期。默认为365天
cookiePath = "/" # Cookie有效路径。默认为"/"表示全站所有路径下有效
cookieDomain = "" # Cookie有效域名。默认为当前配置Cookie时的域名
# Sessions配置
sessionMaxAge = "24h" # Session有效期。默认为24小时
sessionIdName = "gfsessionid" # SessionId的键名名称。默认为gfsessionid
sessionCookieOutput = true # Session特性开启时,是否将SessionId返回到Cookie中。默认true
sessionPath = "/tmp/gsessions" # Session存储的文件目录路径。默认为当前系统临时目录下的gsessions目录
# Logging配置
logPath = "" # 日志文件存储目录路径,建议使用绝对路径。默认为空,表示关闭
logStdout = true # 日志是否输出到终端。默认为true
errorStack = true # 当Server捕获到异常时是否记录堆栈信息到日志中。默认为true
errorLogEnabled = true # 是否记录异常日志信息到日志中。默认为true
errorLogPattern = "error-{Ymd}.log" # 异常错误日志文件格式。默认为"error-{Ymd}.log"
accessLogEnabled = false # 是否记录访问日志。默认为false
accessLogPattern = "access-{Ymd}.log" # 访问日志文件格式。默认为"access-{Ymd}.log"
# PProf配置
pprofEnabled = false # 是否开启PProf性能调试特性。默认为false
pprofPattern = "" # 开启PProf时有效,表示PProf特性的页面访问路径,对当前Server绑定的所有域名有效。
# 其他配置
clientMaxBodySize = 810241024 # 客户端最大Body上传限制大小,影响文件上传大小(Byte)。默认为8*1024*1024=8MB
formParsingMemory = 1048576 # 解析表单时的缓冲区大小(Byte),一般不需要配置。默认为1024*1024=1MB
nameToUriType = 0 # 路由注册中使用对象注册时的路由生成规则。默认为0
routeOverWrite = false # 当遇到重复路由注册时是否强制覆盖。默认为false,重复路由存在时将会在启动时报错退出
dumpRouterMap = true # 是否在Server启动时打印所有的路由列表。默认为true
graceful = false # 是否开启平滑重启特性,开启时将会在本地增加10000的本地TCP端口用于进程间通信。默认false
gracefulTimeout = 2 # 父进程在平滑重启后多少秒退出,默认2秒。若请求耗时大于该值,可能会导致请求中断<br />
Tornado提供了一个具有异步功能的简单Web框架,允许它扩展到大量打开的连接,使其成为长轮询的理想选择。这是一个简单的“Hello,...
在深入研究依赖注入系统之前,让我们升级前面的例子。来自上一个示例的一个字典在前面的示例中,我们dict从我们的依赖项(“可靠...
除了改变数据库架构外,你还可以使用迁移来改变数据库本身的数据,如果你想的话,还可以结合架构来改变。更改数据的迁移通常称为...
当使用 unique() 或 db_index 的列来检索单个对象时,有两个原因。首先,由于底层数据库索引的存在,查询的速度会更快。...
添加额外的 Manager 方法一般是为模型添加 “表级” 功能的更好方法。(对于 “行级” 功能 —— 即,只操作单个模型对象 —...
自动导入 MyBatis-Plus 测试所需相关配置,通过 @MybatisPlusTest 注解快速配置测试类。添加测试依赖Maven:dependencygroup...
MyBatis-Plus 条件构造器-AbstractWrapperbetween(R column, Object val1, Object val2)between(boolean condition, R column, O...
c:redirect 标签c:redirect标签通过自动重写URL来将浏览器重定向至一个新的URL,它提供内容相关的URL,并且支持c:param标签。语...