本文整理汇总了Golang中github.com/coreos/etcd/client.New函数的典型用法代码示例。如果您正苦于以下问题:Golang New函数的具体用法?Golang New怎么用?Golang New使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了New函数的20个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: Init
func Init(serviceName, registryLocation string) error {
log.Print("Initializing registry connection.")
nodeId := config.Service.NodeId
ttl = time.Duration(config.ServiceRegistry.EntryTTL) * time.Second
cfg := etcd.Config{
Endpoints: []string{config.Service.RegistryLocation},
Transport: etcd.DefaultTransport,
}
client, err := etcd.New(cfg)
if err != nil {
log.Fatal(err)
return err
}
kapi = etcd.NewKeysAPI(client)
log.Print("Registering " + serviceName + " Service node at " + hostUrl())
if _, err := kapi.Set(context.Background(), registryLocation+nodeId, hostUrl(),
&etcd.SetOptions{TTL: ttl}); err != nil {
fmt.Println(err)
log.Fatal(err)
return err
}
fetchServiceLists()
fetchPluginNodes()
go sendHeartbeat(registryLocation)
go updateServiceCache()
return nil
}
开发者ID:rhinoman,项目名称:wikifeat,代码行数:27,代码来源:registry_manager.go
示例2: etcdFactory
func etcdFactory(conf map[string]string) (Client, error) {
path, ok := conf["path"]
if !ok {
return nil, fmt.Errorf("missing 'path' configuration")
}
endpoints, ok := conf["endpoints"]
if !ok || endpoints == "" {
return nil, fmt.Errorf("missing 'endpoints' configuration")
}
config := etcdapi.Config{
Endpoints: strings.Split(endpoints, " "),
}
if username, ok := conf["username"]; ok && username != "" {
config.Username = username
}
if password, ok := conf["password"]; ok && password != "" {
config.Password = password
}
client, err := etcdapi.New(config)
if err != nil {
return nil, err
}
return &EtcdClient{
Client: client,
Path: path,
}, nil
}
开发者ID:reinoudk,项目名称:terraform,代码行数:31,代码来源:etcd.go
示例3: newClient
func newClient(c *cli.Context) (client.Client, error) {
eps, err := getEndpoints(c)
if err != nil {
return nil, err
}
tr, err := getTransport(c)
if err != nil {
return nil, err
}
cfg := client.Config{
Transport: tr,
Endpoints: eps,
HeaderTimeoutPerRequest: c.GlobalDuration("timeout"),
}
uFlag := c.GlobalString("username")
if uFlag != "" {
username, password, err := getUsernamePasswordFromFlag(uFlag)
if err != nil {
return nil, err
}
cfg.Username = username
cfg.Password = password
}
return client.New(cfg)
}
开发者ID:nathanpalmer,项目名称:etcd,代码行数:29,代码来源:util.go
示例4: syncToEtcd
func syncToEtcd(ctx context.Context, cfg *config.Config) error {
log.Log(ctx).Debug("Connecting to etcd")
etcdCfg := client.Config{
Endpoints: strings.Split(etcdEndpoints, ","),
}
c, err := client.New(etcdCfg)
if err != nil {
return err
}
root := "/quicklog/" + instanceName
kapi := client.NewKeysAPI(c)
input := cfg.Input
inputConfig, err := json.Marshal(input.Config)
if err != nil {
log.Log(ctx).Error("Error converting input config to JSON data", "error", err)
return err
}
output := cfg.Output
outputConfig, err := json.Marshal(output.Config)
if err != nil {
log.Log(ctx).Error("Error converting output config to JSON data", "error", err)
return err
}
filters := cfg.Filters
kapi.Set(ctx, root+"/input/driver", input.Driver, nil)
kapi.Set(ctx, root+"/input/parser", input.Parser, nil)
kapi.Set(ctx, root+"/input/config", string(inputConfig), nil)
kapi.Set(ctx, root+"/output/driver", output.Driver, nil)
kapi.Set(ctx, root+"/output/config", string(outputConfig), nil)
// clear all the filters before re-creating them
kapi.Delete(ctx, root+"/filters", &client.DeleteOptions{Recursive: true, Dir: true})
// filters must exist even if empty
kapi.Set(ctx, root+"/filters", "", &client.SetOptions{Dir: true})
for idx, filter := range filters {
filterConfig, err := json.Marshal(filter.Config)
if err != nil {
log.Log(ctx).Error("Error converting filter config to JSON data", "error", err)
return err
}
kapi.Set(ctx, root+"/filters/"+strconv.Itoa(idx)+"/driver", filter.Driver, nil)
kapi.Set(ctx, root+"/filters/"+strconv.Itoa(idx)+"/config", string(filterConfig), nil)
}
kapi.Set(ctx, root+"/reload", "1", nil)
return nil
}
开发者ID:sheenobu,项目名称:quicklog,代码行数:60,代码来源:etcd.go
示例5: NewEtcdTestClientServer
// NewEtcdTestClientServer creates a new client and server for testing
func NewEtcdTestClientServer(t *testing.T) *EtcdTestServer {
server := configureTestCluster(t, "foo", true)
err := server.launch(t)
if err != nil {
t.Fatalf("Failed to start etcd server error=%v", err)
return nil
}
cfg := etcd.Config{
Endpoints: server.ClientURLs.StringSlice(),
Transport: newHttpTransport(t, server.CertFile, server.KeyFile, server.CAFile),
}
server.Client, err = etcd.New(cfg)
if err != nil {
server.Terminate(t)
t.Fatalf("Unexpected error in NewEtcdTestClientServer (%v)", err)
return nil
}
if err := server.waitUntilUp(); err != nil {
server.Terminate(t)
t.Fatalf("Unexpected error in waitUntilUp (%v)", err)
return nil
}
return server
}
开发者ID:juanluisvaladas,项目名称:origin,代码行数:26,代码来源:utils.go
示例6: stress
func stress(mb int) error {
time.Sleep(5 * time.Second)
cfg := client.Config{
Endpoints: []string{"http://localhost:12379", "http://localhost:22379", "http://localhost:32379"},
Transport: client.DefaultTransport,
// set timeout per request to fail fast when the target endpoint is unavailable
HeaderTimeoutPerRequest: time.Second,
}
c, err := client.New(cfg)
if err != nil {
return err
}
kapi := client.NewKeysAPI(c)
for i := 0; i < mb*2; i++ {
fmt.Println("stressing", i)
k := make([]byte, 100)
binary.PutVarint(k, int64(rand.Intn(putSize)))
_, err = kapi.Set(context.Background(), string(k), "", nil)
if err != nil {
if i < 2 {
return err
}
}
time.Sleep(500 * time.Millisecond)
}
return nil
}
开发者ID:gyuho,项目名称:learn,代码行数:30,代码来源:24_stream_long_running.go
示例7: NewSource
func NewSource(opts ...config.SourceOption) config.Source {
options := config.SourceOptions{
Name: DefaultPath,
}
for _, o := range opts {
o(&options)
}
var cAddrs []string
for _, addr := range options.Hosts {
if len(addr) > 0 {
cAddrs = append(cAddrs, addr)
}
}
if len(cAddrs) == 0 {
cAddrs = []string{"http://127.0.0.1:2379"}
}
c, err := client.New(client.Config{
Endpoints: cAddrs,
})
if err != nil {
log.Fatal(err)
}
return &etcd{
addrs: cAddrs,
opts: options,
client: c,
}
}
开发者ID:micro,项目名称:go-platform,代码行数:35,代码来源:etcd.go
示例8: GetV2
// GetV2 gets the value to the key using V2 API.
func (c *Cluster) GetV2(w io.Writer, key []byte) error {
endpoints := []string{}
for _, nd := range c.NameToNode {
for v := range nd.Flags.ListenClientURLs {
endpoints = append(endpoints, v)
}
}
cfg := client.Config{
Endpoints: endpoints,
Transport: client.DefaultTransport,
HeaderTimeoutPerRequest: time.Second,
// SelectionMode: client.EndpointSelectionPrioritizeLeader,
}
ct, err := client.New(cfg)
if err != nil {
return err
}
kapi := client.NewKeysAPI(ct)
ts := time.Now()
resp, err := kapi.Get(context.Background(), string(key), nil)
if err != nil {
return err
}
fmt.Fprintf(w, "[GetV2] Done! Took %v for %s/%s.\n", time.Since(ts), key, resp.Node.Value)
return nil
}
开发者ID:mkobar,项目名称:runetcd,代码行数:30,代码来源:v2.go
示例9: TestLockManager
// NOTE: this test depends on an etcd cluster available
// on 127.0.0.1:2379 (the default port)
// TODO: remove the dependence on etcd for testing
func TestLockManager(t *testing.T) {
t.Parallel()
cfg := client.Config{
Endpoints: []string{"http://127.0.0.1:2379"},
Transport: client.DefaultTransport,
// set timeout per request to fail fast when the target endpoint is unavailable
HeaderTimeoutPerRequest: time.Second,
}
c, _ := client.New(cfg)
ecrpErrorChan := make(chan error)
ecrp := retryproxy.NewEtcdClientRetryProxy(c, ecrpErrorChan, 1, 60)
path := "locktest"
hn, _ := os.Hostname()
path += hn
path += uuid.New()
ttl := LockTTL
lm := NewLockManager(ecrp, path, ttl)
defer lm.Shutdown()
closeit := time.After(10 * time.Second)
for {
select {
case <-closeit:
return
case <-time.After(time.Second):
fmt.Printf("Have Lock: %t\n", lm.HaveLock())
}
}
}
开发者ID:stensonb,项目名称:clusterlock,代码行数:37,代码来源:lock_test.go
示例10: NewNode
func NewNode(stop chan bool) *Node {
n := new(Node)
n.stop = stop
n.stopBoard = make(chan bool, 2)
n.stopThread = make(chan bool, 2)
n.stopPost = make(chan bool, 2)
n.stopFile = make(chan bool, 2)
n.Stats = NewNodeStats()
n.Config = parseFlags()
n.Storage = fourchan.NewStorage(n.Config.CassKeyspace, n.Config.CassEndpoints...)
cfg := etcd.Config{
Endpoints: n.Config.EtcdEndpoints,
Transport: etcd.DefaultTransport,
HeaderTimeoutPerRequest: 3 * time.Second,
}
c, err := etcd.New(cfg)
if err != nil {
log.Fatal("Failed to connected to etcd: ", err)
}
n.Keys = etcd.NewKeysAPI(c)
n.Closed = false
// TODO these chan sizes are rather arbitrary...
n.CBoard = make(chan *fourchan.Board, numBoardRoutines)
n.CThread = make(chan *fourchan.Thread, numThreadRoutines)
n.CPost = make(chan *fourchan.Post, numPostRoutines)
n.CFile = make(chan *fourchan.File, numFileRoutines)
n.Files = make(map[int]string)
return n
}
开发者ID:LLParse,项目名称:streamingchan,代码行数:30,代码来源:node.go
示例11: main
func main() {
myFlagSet.Parse(os.Args[1:])
logger := log.New(os.Stderr, "wr ", log.LstdFlags)
client, err := etcd.New(etcd.Config{Endpoints: []string{"http://localhost:2379"}})
if err != nil {
logger.Fatalf("Failed setting up %v", err)
}
w, err := watcher.New(myFlagSet, etcd.NewKeysAPI(client), "/example/flagz", logger)
if err != nil {
logger.Fatalf("Failed setting up %v", err)
}
err = w.Initialize()
if err != nil {
logger.Fatalf("Failed setting up %v", err)
}
w.Start()
for true {
logger.Printf("staticint: %v dynint: %v dynstring: %v",
*staticInt,
dynInt.Get(),
dynStr.Get())
time.Sleep(1500 * time.Millisecond)
}
}
开发者ID:mwitkow,项目名称:go-flagz,代码行数:26,代码来源:cli.go
示例12: Init
func (e *EtcdAuth) Init(endpoint string, path string) {
e.path = path
var endpoints []string
endpoints = append(endpoints, fmt.Sprintf("http://%s", endpoint))
e.etcdConfig = client.Config{
Endpoints: endpoints,
Transport: client.DefaultTransport,
HeaderTimeoutPerRequest: time.Second * 5,
}
// Initialize etcd client
c, err := client.New(e.etcdConfig)
e.etcdClient = c
if err != nil {
log.Error.Printf("Failed to initialize etcd client: %v", err)
return
}
// Create a keys api
// Are we okay to use this instances for the lifetime
// of the application? What happens if the etcd
// instance we are connecting dies?
e.kapi = client.NewKeysAPI(e.etcdClient)
}
开发者ID:cchamplin,项目名称:deployd,代码行数:26,代码来源:etcd_auth.go
示例13: connectEtcd
func connectEtcd(ctx context.Context) error {
var err error
cfg := client.Config{
Endpoints: strings.Split(*etcdAddr, ","),
Transport: client.DefaultTransport,
HeaderTimeoutPerRequest: time.Second,
}
if *clusterName != "" {
clusterEtcdPrefix = fmt.Sprintf("%s/cluster/%s", *etcdPrefix, *clusterName)
} else {
clusterEtcdPrefix = fmt.Sprintf("%s/cluster", *etcdPrefix)
}
etcdClient, err = client.New(cfg)
if err != nil {
log.Fatal(err)
}
kapi = client.NewKeysAPI(etcdClient)
// Run Sync every 10 seconds
wg.Add(1)
go func() {
defer wg.Done()
for {
if err := etcdClient.AutoSync(ctx, 10*time.Second); err == context.DeadlineExceeded || err == context.Canceled {
break
}
if err != nil {
log.Print(err)
}
}
}()
return nil
}
开发者ID:dparrish,项目名称:openinstrument,代码行数:33,代码来源:etcd_config_store.go
示例14: NewEtcdMinion
// NewEtcdMinion creates a new minion with etcd backend
func NewEtcdMinion(config *EtcdMinionConfig) (Minion, error) {
c, err := etcdclient.New(config.EtcdConfig)
if err != nil {
return nil, err
}
cwd, err := os.Getwd()
if err != nil {
return nil, err
}
gitRepo, err := utils.NewGitRepo(filepath.Join(cwd, "site"), config.SiteRepo)
if err != nil {
return nil, err
}
id := utils.GenerateUUID(config.Name)
rootDir := filepath.Join(EtcdMinionSpace, id.String())
m := &etcdMinion{
name: config.Name,
rootDir: rootDir,
queueDir: filepath.Join(rootDir, "queue"),
classifierDir: filepath.Join(rootDir, "classifier"),
logDir: filepath.Join(rootDir, "log"),
id: id,
kapi: etcdclient.NewKeysAPI(c),
taskQueue: make(chan *task.Task),
gitRepo: gitRepo,
done: make(chan struct{}),
}
return m, nil
}
开发者ID:ycaille,项目名称:gru,代码行数:34,代码来源:etcd.go
示例15: Init
func (etc *etcd) Init() error {
var err error
if len(etc.Endpoints) == 0 {
return e.New("no end points")
}
cfg := client.Config{
Endpoints: etc.Endpoints,
//Transport: http.DefaultTransport,
}
c, err := client.New(cfg)
if err != nil {
return e.Forward(err)
}
etc.kapi = client.NewKeysAPI(c)
if etc.SecKeyRing == "" {
return nil
}
kr, err := os.Open(etc.SecKeyRing)
if err != nil {
return e.Forward(err)
}
defer kr.Close()
etc.cm, err = config.NewEtcdConfigManager(etc.Endpoints, kr)
if err != nil {
return e.Forward(err)
}
return nil
}
开发者ID:fcavani,项目名称:ping,代码行数:31,代码来源:gormethods.go
示例16: NewKeysAPI
func NewKeysAPI(cfg etcd.Config) (etcd.KeysAPI, error) {
eCli, err := etcd.New(cfg)
if err != nil {
return nil, err
}
return etcd.NewKeysAPI(eCli), nil
}
开发者ID:jeffjen,项目名称:go-discovery,代码行数:7,代码来源:util.go
示例17: New
func (s *Store) New(c config.Config) *Store {
// Open an etcd client
var endpoints []string
endpoints = append(endpoints, fmt.Sprintf("http://%v:%v", c.Etcd.Hostname, c.Etcd.Port))
ec := client.Config{
Endpoints: endpoints,
Transport: client.DefaultTransport,
}
e, err := client.New(ec)
if err != nil {
log.Fatalln("Could not connect to etcd:", err)
}
// Create a new KeysAPI for etcd
k := client.NewKeysAPI(e)
ns := &Store{
e: e,
c: c,
k: k,
basePath: fmt.Sprint(c.Etcd.BasePath, "/vips/"),
}
return ns
}
开发者ID:chrissnell,项目名称:lbaas,代码行数:27,代码来源:etcd.go
示例18: main
func main() {
logger := log.New(os.Stderr, "server", log.LstdFlags)
if err := serverFlags.Parse(os.Args[1:]); err != nil {
logger.Fatalf("%v", err)
}
client, err := etcd.New(etcd.Config{Endpoints: *etcdEndpoints})
if err != nil {
logger.Fatalf("Failed setting up etcd %v", err)
}
w, err := watcher.New(serverFlags, etcd.NewKeysAPI(client), *etcdFlagzPath, logger)
if err != nil {
logger.Fatalf("Failed setting up watcher %v", err)
}
err = w.Initialize()
if err != nil {
logger.Fatalf("Failed initializing watcher %v", err)
}
w.Start()
logger.Printf("etcd flag value watching initialized")
flagzEndpoint := flagz.NewStatusEndpoint(serverFlags)
http.HandleFunc("/debug/flagz", flagzEndpoint.ListFlags)
http.HandleFunc("/", handleDefaultPage)
addr := fmt.Sprintf("%s:%d", *listenHost, *listenPort)
logger.Printf("Serving at: %v", addr)
if err := http.ListenAndServe(addr, http.DefaultServeMux); err != nil {
logger.Fatalf("Failed serving: %v", err)
}
logger.Printf("Done, bye.")
}
开发者ID:mwitkow,项目名称:go-flagz,代码行数:32,代码来源:http.go
示例19: getFleetRegistryClient
func getFleetRegistryClient(fleetEndpoints []string) (fleetClient.API, error) {
var dial func(string, string) (net.Conn, error)
tlsConfig, err := fleetPkg.ReadTLSConfigFiles("", "", "")
if err != nil {
return nil, err
}
trans := &http.Transport{
Dial: dial,
TLSClientConfig: tlsConfig,
}
timeout := 3 * time.Second
eCfg := etcd.Config{
Endpoints: fleetEndpoints,
Transport: trans,
}
eClient, err := etcd.New(eCfg)
if err != nil {
return nil, err
}
kAPI := etcd.NewKeysAPI(eClient)
reg := registry.NewEtcdRegistry(kAPI, registry.DefaultKeyPrefix, timeout)
return &fleetClient.RegistryClient{Registry: reg}, nil
}
开发者ID:ubideo,项目名称:heapster,代码行数:27,代码来源:coreos.go
示例20: NewEtcdConfig
// NewEtcdConfig creates a new service discovery backend for etcd
func NewEtcdConfig(config map[string]interface{}) Etcd {
etcd := Etcd{
Prefix: "/containerbuddy",
}
etcdConfig := client.Config{}
switch endpoints := config["endpoints"].(type) {
case string:
etcdConfig.Endpoints = []string{endpoints}
case []string:
etcdConfig.Endpoints = endpoints
default:
log.Fatal("Must provide etcd endpoints")
}
prefix, ok := config["prefix"].(string)
if ok {
etcd.Prefix = prefix
}
etcdClient, err := client.New(etcdConfig)
if err != nil {
log.Fatal(err)
}
etcd.Client = etcdClient
etcd.API = client.NewKeysAPI(etcdClient)
return etcd
}
开发者ID:zofuthan,项目名称:containerbuddy,代码行数:28,代码来源:etcd.go
注:本文中的github.com/coreos/etcd/client.New函数示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论