forked from yuxh/gearman-go
finished some worker's apis.
This commit is contained in:
commit
153066eb03
19
src/pkg/gearman/Makefile
Normal file
19
src/pkg/gearman/Makefile
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Copyright 2009 The Go Authors. All rights reserved.
|
||||||
|
# Use of this source code is governed by a BSD-style
|
||||||
|
# license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
include $(GOROOT)/src/Make.inc
|
||||||
|
|
||||||
|
TARG=gearman
|
||||||
|
CGOFILES=\
|
||||||
|
gearman.go\
|
||||||
|
worker.go\
|
||||||
|
client.go\
|
||||||
|
|
||||||
|
CLEANFILES+=gearman_test
|
||||||
|
|
||||||
|
include $(GOROOT)/src/Make.pkg
|
||||||
|
|
||||||
|
%: install %.go
|
||||||
|
$(GC) $*.go
|
||||||
|
$(LD) -o $@ $*.$O
|
6
src/pkg/gearman/client.go
Normal file
6
src/pkg/gearman/client.go
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
package gearman
|
||||||
|
|
||||||
|
// #cgo: LDFLAGS: -lgearman
|
||||||
|
// #include <libgearman/gearman.h>
|
||||||
|
|
||||||
|
import "C"
|
6
src/pkg/gearman/gearman.go
Normal file
6
src/pkg/gearman/gearman.go
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
package gearman
|
||||||
|
|
||||||
|
// #cgo: LDFLAGS: -lgearman
|
||||||
|
// #include <libgearman/gearman.h>
|
||||||
|
|
||||||
|
import "C"
|
13
src/pkg/gearman/gearman_test.go
Normal file
13
src/pkg/gearman/gearman_test.go
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"gearman"
|
||||||
|
"fmt"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
worker := gearman.GearmanWorkerCreate()
|
||||||
|
worker.AddServer("127.0.0.1", 4730)
|
||||||
|
worker.Work()
|
||||||
|
worker.Free()
|
||||||
|
}
|
62
src/pkg/gearman/worker.go
Normal file
62
src/pkg/gearman/worker.go
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
package gearman
|
||||||
|
|
||||||
|
// #cgo LDFLAGS: -lgearman
|
||||||
|
// #include <libgearman/gearman.h>
|
||||||
|
import "C"
|
||||||
|
|
||||||
|
import(
|
||||||
|
"log"
|
||||||
|
"unsafe"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GearmanWorker struct {
|
||||||
|
worker C.gearman_worker_st
|
||||||
|
}
|
||||||
|
// Create gearman worker
|
||||||
|
func GearmanWorkerCreate() * GearmanWorker {
|
||||||
|
|
||||||
|
worker := new(GearmanWorker)
|
||||||
|
if C.gearman_worker_create(&worker.worker) == nil {
|
||||||
|
log.Panic("Memory allocation failure on worker creation")
|
||||||
|
}
|
||||||
|
return worker
|
||||||
|
}
|
||||||
|
|
||||||
|
// get error
|
||||||
|
func (worker * GearmanWorker) Error() string {
|
||||||
|
return C.GoString(C.gearman_worker_error(&worker.worker))
|
||||||
|
}
|
||||||
|
|
||||||
|
// add server
|
||||||
|
func (worker * GearmanWorker) AddServer(host string, port uint16) {
|
||||||
|
h := C.CString(host)
|
||||||
|
defer C.free(unsafe.Pointer(h))
|
||||||
|
if C.gearman_worker_add_server(&worker.worker, h,
|
||||||
|
C.in_port_t(port)) != C.GEARMAN_SUCCESS {
|
||||||
|
log.Panic(worker.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// add function
|
||||||
|
func (worker * GearmanWorker) AddFunction(funcname string, timeout uint32, f interface{}, context interface{}) {
|
||||||
|
fn := C.CString(funcname)
|
||||||
|
defer C.free(unsafe.Pointer(fn))
|
||||||
|
if C.gearman_worker_add_function(&worker.worker, fn, C.uint32_t(timeout), C.gearman_worker_fn(&unsafe.Pointer(&f)), unsafe.Pointer(&context)) != C.GEARMAN_SUCCESS {
|
||||||
|
log.Panic(worker.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// work
|
||||||
|
func (worker * GearmanWorker) Work() {
|
||||||
|
for {
|
||||||
|
if C.gearman_worker_work(&worker.worker) != C.GEARMAN_SUCCESS {
|
||||||
|
log.Panic(worker.Error())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// free
|
||||||
|
// should used as defer
|
||||||
|
func (worker * GearmanWorker) Free() {
|
||||||
|
C.gearman_worker_free(&worker.worker)
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user