在beego的配置文件中app.conf配置HTTP和HTTPS的相关配置
appname = ebsServer
autorender = false
httpport = 8094
runmode = dev
EnableHTTPS=true
EnableHttpTLS = true
HttpsPort = 9092
HTTPSCertFile = "server.crt"
HTTPSKeyFile = "server_no_passwd.key"
有时会出现 https端口占用问题,网上分析的问题原因: 初步判断为http监听地址和https监听地址有一定几率互相覆盖导致, 所以加一个睡眠时间, 让两个协程执行时间错开.
在beego的app.go文件中, 找到
// run normal mode
if BConfig.Listen.EnableHTTPS {
go func() {
time.Sleep(1000 * time.Microsecond) //这里是我修改后的代码, 原本只是睡眠了 20 * Microsecond,我这里改到了1000, 可以继续往大改
if BConfig.Listen.HTTPSPort != 0 {
app.Server.Addr = fmt.Sprintf("%s:%d", BConfig.Listen.HTTPSAddr, BConfig.Listen.HTTPSPort)
} else if BConfig.Listen.EnableHTTP {
BeeLogger.Info("Start https server error, confict with http.Please reset https port")
return
}
logs.Info("https server Running on https://%s", app.Server.Addr)
if err := app.Server.ListenAndServeTLS(BConfig.Listen.HTTPSCertFile, BConfig.Listen.HTTPSKeyFile); err != nil {
logs.Critical("ListenAndServeTLS: ", err)
time.Sleep(100 * time.Microsecond)
endRunning <- true
}
}()
}
但是我没有成功。
最后成功的解决方案是将https监听端口不使用配置文件,使用代码实现
beego.BConfig.Listen.EnableHTTPS = true
beego.BConfig.Listen.Graceful = true
beego.BConfig.Listen.HTTPSPort = 9999
beego.BConfig.Listen.HTTPSCertFile = "server.crt"
beego.BConfig.Listen.HTTPSKeyFile = "server_no_passwd.key"
在beego的配置文件中app.conf改为
appname = ebsServer
autorender = false
httpport = 8094
runmode = dev