seaweedfs/weed/server/filer_server.go

137 lines
3.6 KiB
Go
Raw Normal View History

2014-03-30 18:28:04 +00:00
package weed_server
import (
"math/rand"
2014-03-30 18:28:04 +00:00
"net/http"
2014-03-31 03:57:25 +00:00
"strconv"
"sync"
"time"
2018-05-14 06:56:16 +00:00
"github.com/chrislusf/seaweedfs/weed/filer2"
2018-05-27 07:01:15 +00:00
_ "github.com/chrislusf/seaweedfs/weed/filer2/cassandra"
_ "github.com/chrislusf/seaweedfs/weed/filer2/leveldb"
2018-05-26 12:32:15 +00:00
_ "github.com/chrislusf/seaweedfs/weed/filer2/memdb"
_ "github.com/chrislusf/seaweedfs/weed/filer2/mysql"
2018-05-27 05:02:49 +00:00
_ "github.com/chrislusf/seaweedfs/weed/filer2/postgres"
2018-05-27 18:14:29 +00:00
_ "github.com/chrislusf/seaweedfs/weed/filer2/redis"
2018-05-27 18:52:26 +00:00
"github.com/chrislusf/seaweedfs/weed/glog"
"github.com/chrislusf/seaweedfs/weed/security"
"github.com/chrislusf/seaweedfs/weed/storage"
"github.com/chrislusf/seaweedfs/weed/util"
2014-03-30 18:28:04 +00:00
)
type FilerServer struct {
port string
master string
mnLock sync.RWMutex
collection string
defaultReplication string
redirectOnRead bool
2015-04-14 06:38:46 +00:00
disableDirListing bool
2015-02-07 23:35:28 +00:00
secret security.Secret
2018-05-14 06:56:16 +00:00
filer *filer2.Filer
2016-08-31 03:32:30 +00:00
maxMB int
masterNodes *storage.MasterNodes
2014-03-30 18:28:04 +00:00
}
func NewFilerServer(defaultMux, readonlyMux *http.ServeMux, ip string, port int, master string, collection string,
2015-04-14 06:38:46 +00:00
replication string, redirectOnRead bool, disableDirListing bool,
maxMB int,
2015-02-07 23:35:28 +00:00
secret string,
) (fs *FilerServer, err error) {
2014-03-30 18:28:04 +00:00
fs = &FilerServer{
master: master,
collection: collection,
defaultReplication: replication,
redirectOnRead: redirectOnRead,
2015-04-14 06:38:46 +00:00
disableDirListing: disableDirListing,
2016-08-31 03:32:30 +00:00
maxMB: maxMB,
port: ip + ":" + strconv.Itoa(port),
2014-03-30 18:28:04 +00:00
}
2018-05-14 06:56:16 +00:00
fs.filer = filer2.NewFiler(master)
fs.filer.LoadConfiguration()
2018-05-14 06:56:16 +00:00
defaultMux.HandleFunc("/admin/register", fs.registerHandler)
2018-05-28 09:35:58 +00:00
defaultMux.HandleFunc("/favicon.ico", faviconHandler)
2017-05-28 01:11:18 +00:00
defaultMux.HandleFunc("/", fs.filerHandler)
2017-05-28 03:14:22 +00:00
if defaultMux != readonlyMux {
readonlyMux.HandleFunc("/", fs.readonlyFilerHandler)
}
2014-03-30 18:28:04 +00:00
go func() {
connected := true
fs.masterNodes = storage.NewMasterNodes(fs.master)
glog.V(0).Infof("Filer server bootstraps with master %s", fs.getMasterNode())
for {
glog.V(4).Infof("Filer server sending to master %s", fs.getMasterNode())
master, err := fs.detectHealthyMaster(fs.getMasterNode())
if err == nil {
if !connected {
connected = true
if fs.getMasterNode() != master {
fs.setMasterNode(master)
}
glog.V(0).Infoln("Filer Server Connected with master at", master)
}
} else {
glog.V(1).Infof("Filer Server Failed to talk with master %s: %v", fs.getMasterNode(), err)
if connected {
connected = false
}
}
if connected {
time.Sleep(time.Duration(float32(10*1e3)*(1+rand.Float32())) * time.Millisecond)
} else {
time.Sleep(time.Duration(float32(10*1e3)*0.25) * time.Millisecond)
}
}
}()
2014-03-30 18:28:04 +00:00
return fs, nil
}
2015-02-07 23:35:28 +00:00
func (fs *FilerServer) jwt(fileId string) security.EncodedJwt {
return security.GenJwt(fs.secret, fileId)
}
func (fs *FilerServer) getMasterNode() string {
fs.mnLock.RLock()
defer fs.mnLock.RUnlock()
return fs.master
}
func (fs *FilerServer) setMasterNode(masterNode string) {
fs.mnLock.Lock()
defer fs.mnLock.Unlock()
fs.master = masterNode
}
func (fs *FilerServer) detectHealthyMaster(masterNode string) (master string, e error) {
2016-06-07 06:50:27 +00:00
if e = checkMaster(masterNode); e != nil {
fs.masterNodes.Reset()
for i := 0; i <= 3; i++ {
master, e = fs.masterNodes.FindMaster()
if e != nil {
continue
} else {
if e = checkMaster(master); e == nil {
break
}
}
}
} else {
master = masterNode
}
return
}
2016-06-07 06:50:27 +00:00
func checkMaster(masterNode string) error {
2018-05-07 07:37:33 +00:00
statUrl := "http://" + masterNode + "/stats/health"
2016-06-07 06:50:27 +00:00
glog.V(4).Infof("Connecting to %s ...", statUrl)
_, e := util.Get(statUrl)
return e
}