本文整理匯總了Golang中github.com/gorilla/rpc.NewServer函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewServer函數的具體用法?Golang NewServer怎麽用?Golang NewServer使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewServer函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: main
func main() {
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
s.RegisterService(new(StockService), "")
http.Handle("/stock", s)
http.ListenAndServe(":8080", nil)
}
示例2: main
func main() {
//Creating stock records
var st = (new(StockRecords))
//TradeID Initialization
tradeId = 0
router := mux.NewRouter()
server := rpc.NewServer()
server.RegisterCodec(json.NewCodec(), "application/json")
server.RegisterService(st, "")
chain := alice.New(
func(h http.Handler) http.Handler {
return handlers.CombinedLoggingHandler(os.Stdout, h)
},
handlers.CompressHandler,
func(h http.Handler) http.Handler {
return recovery.Handler(os.Stderr, h, true)
})
router.Handle("/rpc", chain.Then(server))
log.Fatal(http.ListenAndServe(":1333", server))
}
示例3: Serve
//Serve adds the rpc service t to the net/http DefaultServeMux at the given path
//and allows future lookup with name.
func Serve(t interface{}, name string, path string) {
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
s.RegisterService(t, name)
http.Handle(path, s)
servers[name] = path
}
示例4: main
func main() {
flag.Parse()
session, err := r.Connect(r.ConnectOpts{
Address: *rethinkdbAddress,
Database: *rethinkdbDatabase,
})
if err != nil {
log.Fatal(err)
}
r.DB(*rethinkdbDatabase).TableCreate("scripts").Exec(session)
r.DB(*rethinkdbDatabase).TableCreate("tokens").Exec(session)
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
s.RegisterService(&service.Service{
Session: session,
}, "Rexd")
http.Handle("/rpc", s)
http.HandleFunc("/", func(w http.ResponseWriter, req *http.Request) {
w.Write([]byte("lavab/rexd 0.1.0\n"))
})
log.Printf("Binding to %s", *bindAddress)
if err := http.ListenAndServe(*bindAddress, nil); err != nil {
log.Fatal(err)
}
}
示例5: main
func main() {
//initialize the stock account
var st = (new(StockAccounts))
//initialize a tradeId with random number
tradeId = rand.Intn(10000) + 1
// //register the stock account data and start server with HTTP protocol
// rpc.Register(&st)
// rpc.HandleHTTP()
// //start listening
// err := http.ListenAndServe(":1234", nil) //nil, no need for handler
router := mux.NewRouter()
server := rpc.NewServer()
server.RegisterCodec(json.NewCodec(), "application/json")
server.RegisterService(st, "")
chain := alice.New(
func(h http.Handler) http.Handler {
return handlers.CombinedLoggingHandler(os.Stdout, h)
},
handlers.CompressHandler,
func(h http.Handler) http.Handler {
return recovery.Handler(os.Stderr, h, true)
})
router.Handle("/rpc", chain.Then(server))
log.Fatal(http.ListenAndServe(":1234", server))
// checkError(err)
}
示例6: TestService
func TestService(t *testing.T) {
s := rpc.NewServer()
s.RegisterCodec(NewCodec(), "application/json")
s.RegisterService(new(Service1), "")
var res Service1Response
if _, err := execute(t, s, "Service1.Multiply", &Service1Request{4, 2}, &res); err != nil {
t.Error("Expected err to be nil, but got:", err)
}
if res.Result != 8 {
t.Errorf("Wrong response: %v.", res.Result)
}
if res.ErrorMessage != "" {
t.Errorf("Expected error_message to be empty, but got:", res.ErrorMessage)
}
if code, err := execute(t, s, "Service1.ResponseError", &Service1Request{4, 2}, &res); err != nil || code != 500 {
t.Errorf("Expected code to be 500 and error to be nil, but got", code, err)
}
if res.ErrorMessage == "" {
t.Errorf("Expected error_message to be %q, but got %q", ErrResponseError, res.ErrorMessage)
}
if code, _ := execute(t, s, "Service1.Multiply", nil, &res); code != 400 {
t.Errorf("Expected http response code 400, but got %v", code)
}
}
示例7: Initialize
func Initialize(config *api.ApiConfig) error {
e := localdb.Initialize(config.Log, config.LocalDB)
if e != nil {
return e
}
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
service := new(EMPService)
service.Config = config
s.RegisterService(service, "EMPService")
// Register RPC Services
http.Handle("/rpc", s)
// Register JS Client
http.Handle("/", http.FileServer(http.Dir(config.HttpRoot)))
l, e := net.Listen("tcp", fmt.Sprintf(":%d", config.RPCPort))
if e != nil {
config.Log <- fmt.Sprintf("RPC Listen Error: %s", e)
return e
}
go http.Serve(l, nil)
go register(config)
portStr := fmt.Sprintf(":%d", config.RPCPort)
config.Log <- fmt.Sprintf("Started RPC Server on: %s", portStr)
return nil
}
示例8: New
//New returns a new Runner ready to be Announced and run tests on the
//heroku dyno grid.
func New(app, api string, tracker, hosted string) *Runner {
n := &Runner{
app: app,
api: api,
tcl: client.New(tracker, http.DefaultClient, client.JsonCodec),
base: hosted,
rpc: gorpc.NewServer(),
rq: rpc.NewRunnerQueue(),
mc: heroku.NewManaged(app, api, 2, 2*time.Minute),
tm: &runnerTaskMap{items: map[string]*runnerTask{}},
}
//register the run service in the rpc
if err := n.rpc.RegisterService(n.rq, ""); err != nil {
panic(err)
}
//register the pinger
if err := n.rpc.RegisterService(pinger.Pinger{}, ""); err != nil {
panic(err)
}
//register ourselves in the rpc
if err := n.rpc.RegisterService(n, ""); err != nil {
panic(err)
}
//register the codec
n.rpc.RegisterCodec(json.NewCodec(), "application/json")
//start processing
go n.run()
return n
}
示例9: New
//New returns a new web Builder ready to Announce to the given tracker. It
//announces that it is available at `hosted` which should be the full url of
//where this builder resides on the internet.
func New(b builder.Builder, tracker, hosted string) *Builder {
//create our new builder
n := &Builder{
b: b,
base: hosted,
rpc: gorpc.NewServer(),
tcl: client.New(tracker, http.DefaultClient, client.JsonCodec),
bq: rpc.NewBuilderQueue(),
mux: http.NewServeMux(),
dler: newDownloader(),
}
//register the build service in the rpc
if err := n.rpc.RegisterService(n.bq, ""); err != nil {
panic(err)
}
//make sure we respond to pings
if err := n.rpc.RegisterService(pinger.Pinger{}, ""); err != nil {
panic(err)
}
//register the codec
n.rpc.RegisterCodec(json.NewCodec(), "application/json")
//add the handlers to our mux
n.mux.Handle("/", n.rpc)
n.mux.Handle("/download/", http.StripPrefix("/download/", n.dler))
//start processing tasks
go n.run()
return n
}
示例10: TestServiceBeforeAfter
func TestServiceBeforeAfter(t *testing.T) {
s := rpc.NewServer()
s.RegisterCodec(NewCodec(), "application/json")
service := &Service1{}
service.beforeAfterContext = map[string]string{}
s.RegisterService(service, "")
s.RegisterBeforeFunc(func(i *rpc.RequestInfo) {
service.beforeAfterContext["before"] = "Before is true"
})
s.RegisterAfterFunc(func(i *rpc.RequestInfo) {
service.beforeAfterContext["after"] = "After is true"
})
var res Service1Response
if err := execute(t, s, "Service1.BeforeAfter", &Service1Request{}, &res); err != nil {
t.Error("Expected err to be nil, but got:", err)
}
if res.Result != 1 {
t.Errorf("Expected Result = 1, got %d", res.Result)
}
if afterValue, ok := service.beforeAfterContext["after"]; !ok || afterValue != "After is true" {
t.Errorf("Expected after in context to be 'After is true', got %s", afterValue)
}
}
示例11: main
func main() {
//stock account Initialization
var st = (new(StockAccounts))
//Trade Id random generator
tradeId = rand.Intn(99999) + 1
//start listening
router := mux.NewRouter()
server := rpc.NewServer()
server.RegisterCodec(json.NewCodec(), "application/json")
server.RegisterService(st, "")
chain := alice.New(
func(h http.Handler) http.Handler {
return handlers.CombinedLoggingHandler(os.Stdout, h)
},
handlers.CompressHandler,
func(h http.Handler) http.Handler {
return recovery.Handler(os.Stderr, h, true)
})
router.Handle("/rpc", chain.Then(server))
log.Fatal(http.ListenAndServe(":8070", server))
}
示例12: New
//New returns a new Runner ready to be Announced and run tests locally.
func New(runner, tracker, hosted string) *Runner {
n := &Runner{
tcl: client.New(tracker, http.DefaultClient, client.JsonCodec),
base: hosted,
runner: runner,
rpc: gorpc.NewServer(),
rq: rpc.NewRunnerQueue(),
resp: make(chan rpc.Output),
}
//register the run service in the rpc
if err := n.rpc.RegisterService(n.rq, ""); err != nil {
panic(err)
}
//register the pinger
if err := n.rpc.RegisterService(pinger.Pinger{}, ""); err != nil {
panic(err)
}
//register ourselves in the rpc
if err := n.rpc.RegisterService(n, ""); err != nil {
panic(err)
}
//register the codec
n.rpc.RegisterCodec(json.NewCodec(), "application/json")
//start processing
go n.run()
return n
}
示例13: TestFaults
func TestFaults(t *testing.T) {
s := rpc.NewServer()
s.RegisterCodec(NewCodec(), "text/xml")
s.RegisterService(new(FaultTest), "")
var err error
var res1 FaultTestResponse
err = execute(t, s, "FaultTest.Multiply", &FaultTestBadRequest{4, 2, 4}, &res1)
if err == nil {
t.Error("Expected err to be not nil, but got:", err)
}
if err.Error() != "Wrong number of arguments" {
t.Errorf("Wrong response: %v.", err.Error())
}
var res2 FaultTestBadResponse
err = execute(t, s, "FaultTest.Multiply", &FaultTestRequest{4, 2}, &res2)
if err == nil {
t.Error("Expected err to be not nil, but got:", err)
}
if !strings.HasPrefix(err.Error(), "Fields type mismatch") {
t.Errorf("Wrong response: %v.", err.Error())
}
}
示例14: main
func main() {
Portfolios = make(map[float32]Portfolio)
// HTTP request multiplexer
// mux.Router matches incoming requests against a list of registered routes
// and calls a handler for the route that matches the URL
r := mux.NewRouter()
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
stockDealer := new(StockDealer)
s.RegisterService(stockDealer, "")
// middle ware: organizing hared functionalities
chain := alice.New(
func(h http.Handler) http.Handler {
return handlers.CombinedLoggingHandler(os.Stdout, h)
},
handlers.CompressHandler,
func(h http.Handler) http.Handler {
return recovery.Handler(os.Stderr, h, true)
})
r.Handle("/rpc", chain.Then(s))
fmt.Println("Server listening on 8080")
log.Fatal(http.ListenAndServe(":8080", r))
}
示例15: main
func main() {
createHashTable()
s := rpc.NewServer()
s.RegisterCodec(json.NewCodec(), "application/json")
s.RegisterService(new(StockMarket), "")
http.Handle("/rpc", s)
http.ListenAndServe("localhost:10000", nil)
}