2014-08-18 08:41:43 +00:00
|
|
|
// Copyright 2014 beego Author. All Rights Reserved.
|
2014-07-03 15:40:21 +00:00
|
|
|
//
|
2014-08-18 08:41:43 +00:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
2014-07-03 15:40:21 +00:00
|
|
|
//
|
2014-08-18 08:41:43 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2014-07-03 15:40:21 +00:00
|
|
|
//
|
2014-08-18 08:41:43 +00:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2013-09-09 16:00:11 +00:00
|
|
|
package beego
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net"
|
|
|
|
"net/http"
|
|
|
|
"net/http/fcgi"
|
2015-02-27 14:21:58 +00:00
|
|
|
"os"
|
2013-09-09 16:00:11 +00:00
|
|
|
"time"
|
2015-02-27 14:21:58 +00:00
|
|
|
|
2015-05-13 13:17:47 +00:00
|
|
|
"github.com/astaxie/beego/grace"
|
2015-02-27 14:21:58 +00:00
|
|
|
"github.com/astaxie/beego/utils"
|
2013-09-09 16:00:11 +00:00
|
|
|
)
|
|
|
|
|
2013-12-20 11:20:13 +00:00
|
|
|
// App defines beego application with a new PatternServeMux.
|
2013-09-09 16:00:11 +00:00
|
|
|
type App struct {
|
2015-07-27 00:44:58 +00:00
|
|
|
Handlers *ControllerRegister
|
2014-05-20 09:28:06 +00:00
|
|
|
Server *http.Server
|
2013-09-09 16:00:11 +00:00
|
|
|
}
|
|
|
|
|
2013-12-20 11:20:13 +00:00
|
|
|
// NewApp returns a new beego application.
|
2013-09-09 16:00:11 +00:00
|
|
|
func NewApp() *App {
|
2014-06-10 12:12:57 +00:00
|
|
|
cr := NewControllerRegister()
|
2014-05-20 09:28:06 +00:00
|
|
|
app := &App{Handlers: cr, Server: &http.Server{}}
|
2013-09-09 16:00:11 +00:00
|
|
|
return app
|
|
|
|
}
|
|
|
|
|
2013-12-20 11:20:13 +00:00
|
|
|
// Run beego application.
|
2013-09-09 16:00:11 +00:00
|
|
|
func (app *App) Run() {
|
|
|
|
addr := HttpAddr
|
|
|
|
|
|
|
|
if HttpPort != 0 {
|
|
|
|
addr = fmt.Sprintf("%s:%d", HttpAddr, HttpPort)
|
|
|
|
}
|
2013-11-26 07:30:59 +00:00
|
|
|
|
2013-09-09 16:00:11 +00:00
|
|
|
var (
|
|
|
|
err error
|
|
|
|
l net.Listener
|
|
|
|
)
|
2014-05-20 08:41:39 +00:00
|
|
|
endRunning := make(chan bool, 1)
|
2013-11-26 07:30:59 +00:00
|
|
|
|
2013-09-09 16:00:11 +00:00
|
|
|
if UseFcgi {
|
2014-10-13 11:47:44 +00:00
|
|
|
if UseStdIo {
|
|
|
|
err = fcgi.Serve(nil, app.Handlers) // standard I/O
|
|
|
|
if err == nil {
|
|
|
|
BeeLogger.Info("Use FCGI via standard I/O")
|
|
|
|
} else {
|
|
|
|
BeeLogger.Info("Cannot use FCGI via standard I/O", err)
|
|
|
|
}
|
2013-09-09 16:00:11 +00:00
|
|
|
} else {
|
2014-10-13 11:47:44 +00:00
|
|
|
if HttpPort == 0 {
|
2015-02-27 14:21:58 +00:00
|
|
|
// remove the Socket file before start
|
|
|
|
if utils.FileExists(addr) {
|
|
|
|
os.Remove(addr)
|
|
|
|
}
|
2014-10-13 11:47:44 +00:00
|
|
|
l, err = net.Listen("unix", addr)
|
|
|
|
} else {
|
|
|
|
l, err = net.Listen("tcp", addr)
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("Listen: ", err)
|
|
|
|
}
|
|
|
|
err = fcgi.Serve(l, app.Handlers)
|
2013-09-09 16:00:11 +00:00
|
|
|
}
|
|
|
|
} else {
|
2015-05-13 13:17:47 +00:00
|
|
|
if Graceful {
|
2015-05-20 03:07:23 +00:00
|
|
|
app.Server.Addr = addr
|
|
|
|
app.Server.Handler = app.Handlers
|
|
|
|
app.Server.ReadTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
|
|
|
app.Server.WriteTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
2015-05-13 13:17:47 +00:00
|
|
|
if EnableHttpTLS {
|
|
|
|
go func() {
|
|
|
|
time.Sleep(20 * time.Microsecond)
|
|
|
|
if HttpsPort != 0 {
|
|
|
|
addr = fmt.Sprintf("%s:%d", HttpAddr, HttpsPort)
|
2015-05-20 03:07:23 +00:00
|
|
|
app.Server.Addr = addr
|
2015-05-13 13:17:47 +00:00
|
|
|
}
|
|
|
|
server := grace.NewServer(addr, app.Handlers)
|
2015-05-20 03:07:23 +00:00
|
|
|
server.Server = app.Server
|
2015-05-13 13:17:47 +00:00
|
|
|
err := server.ListenAndServeTLS(HttpCertFile, HttpKeyFile)
|
2014-11-03 07:06:25 +00:00
|
|
|
if err != nil {
|
2015-05-20 03:09:30 +00:00
|
|
|
BeeLogger.Critical("ListenAndServeTLS: ", err, fmt.Sprintf("%d", os.Getpid()))
|
2014-11-03 07:06:25 +00:00
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
2015-05-13 13:17:47 +00:00
|
|
|
}()
|
|
|
|
}
|
|
|
|
if EnableHttpListen {
|
|
|
|
go func() {
|
|
|
|
server := grace.NewServer(addr, app.Handlers)
|
2015-05-20 03:07:23 +00:00
|
|
|
server.Server = app.Server
|
2015-05-13 13:17:47 +00:00
|
|
|
if ListenTCP4 && HttpAddr == "" {
|
|
|
|
server.Network = "tcp4"
|
|
|
|
}
|
|
|
|
err := server.ListenAndServe()
|
2014-11-03 07:06:25 +00:00
|
|
|
if err != nil {
|
2015-05-20 03:09:30 +00:00
|
|
|
BeeLogger.Critical("ListenAndServe: ", err, fmt.Sprintf("%d", os.Getpid()))
|
2014-11-03 07:06:25 +00:00
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
2015-05-13 13:17:47 +00:00
|
|
|
}()
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
app.Server.Addr = addr
|
|
|
|
app.Server.Handler = app.Handlers
|
|
|
|
app.Server.ReadTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
|
|
|
app.Server.WriteTimeout = time.Duration(HttpServerTimeOut) * time.Second
|
|
|
|
|
|
|
|
if EnableHttpTLS {
|
|
|
|
go func() {
|
|
|
|
time.Sleep(20 * time.Microsecond)
|
|
|
|
if HttpsPort != 0 {
|
|
|
|
app.Server.Addr = fmt.Sprintf("%s:%d", HttpAddr, HttpsPort)
|
|
|
|
}
|
|
|
|
BeeLogger.Info("https server Running on %s", app.Server.Addr)
|
|
|
|
err := app.Server.ListenAndServeTLS(HttpCertFile, HttpKeyFile)
|
2014-11-03 07:06:25 +00:00
|
|
|
if err != nil {
|
2015-05-13 13:17:47 +00:00
|
|
|
BeeLogger.Critical("ListenAndServeTLS: ", err)
|
2014-11-03 07:06:25 +00:00
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
2015-05-13 13:17:47 +00:00
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
|
|
|
if EnableHttpListen {
|
|
|
|
go func() {
|
|
|
|
app.Server.Addr = addr
|
|
|
|
BeeLogger.Info("http server Running on %s", app.Server.Addr)
|
|
|
|
if ListenTCP4 && HttpAddr == "" {
|
|
|
|
ln, err := net.Listen("tcp4", app.Server.Addr)
|
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("ListenAndServe: ", err)
|
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
return
|
|
|
|
}
|
|
|
|
err = app.Server.Serve(ln)
|
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("ListenAndServe: ", err)
|
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
return
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
err := app.Server.ListenAndServe()
|
|
|
|
if err != nil {
|
|
|
|
BeeLogger.Critical("ListenAndServe: ", err)
|
|
|
|
time.Sleep(100 * time.Microsecond)
|
|
|
|
endRunning <- true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
2013-09-09 16:00:11 +00:00
|
|
|
}
|
2013-11-26 07:30:59 +00:00
|
|
|
|
2015-05-13 13:17:47 +00:00
|
|
|
}
|
2014-05-20 07:30:17 +00:00
|
|
|
<-endRunning
|
2013-09-09 16:00:11 +00:00
|
|
|
}
|