CentOS install etcd 测试

简介: 1,关于etcdetcd是一个类似于zookeeper的,服务发现工具。 参考简介: http://dockone.io/article/667 https://coreos.com/blog/performance-of-etcd.html etcd性能对比:2,搭建环境在linux 下面:安装最新的3.1.1https://github.com/c

1,关于etcd


etcd是一个类似于zookeeper的,服务发现工具。
参考简介:
http://dockone.io/article/667
https://coreos.com/blog/performance-of-etcd.html
etcd性能对比:

2,搭建环境


在linux 下面:安装最新的3.1.1

https://github.com/coreos/etcd/releases/download/v3.1.1/etcd-v3.1.1-linux-amd64.tar.gz

解压缩。直接启动。
./etcd version
./etcd
我使用的是virtualbox安装的,因为是虚拟机。所以使用了NAT的网络。远程访问做了一个端口转发。

同时启动一个etcd需要绑定到ip 10.0.2.15 ,默认启动之后是绑定到了127.0.0.1这个ip。

./etcd --name test-etcd --advertise-client-urls http://10.0.2.15:2379 --listen-client-urls http://10.0.2.15:2379

不知道为啥要使用两次命令,没有直接叫 addr 的参数。
etcd 目前默认使用 2379 端口提供 HTTP API 服务,2380 端口和 peer 通信。

3,使用java客户端连接


https://github.com/coreos/jetcd
下载lib库。依赖google的 grpc,protobuf。
maven 下载比较慢,可以使用ali的镜像。

java代码:

import com.coreos.jetcd.EtcdClient;
import com.coreos.jetcd.EtcdClientBuilder;
import com.coreos.jetcd.EtcdKV;
import com.coreos.jetcd.api.KeyValue;
import com.coreos.jetcd.api.RangeResponse;
import com.coreos.jetcd.exception.AuthFailedException;
import com.coreos.jetcd.exception.ConnectException;
import com.google.common.util.concurrent.ListenableFuture;
import com.google.protobuf.ByteString;

import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.concurrent.ExecutionException;

/**
 */
public class TestJetcd {
    public static void main(String[] args) throws ExecutionException, InterruptedException, UnsupportedEncodingException, AuthFailedException, ConnectException {
        EtcdClient client = EtcdClientBuilder.newBuilder().endpoints("http://localhost:2379").build();
        EtcdKV kvClient = client.getKVClient();

        System.out.println(kvClient);

        ByteString key = ByteString.copyFrom("test_key", "UTF-8");
        ByteString value = ByteString.copyFrom("test_value", "UTF-8");
//        System.out.println(kvClient.get(key).get());


        // put the key-value
        kvClient.put(key, value).get();
        //
        List<KeyValue> list = kvClient.get(key).get().getKvsList();
        //循环显示所有数据。
        for (KeyValue keyValue : list) {
            //转换成utf-8 项目。
            String tmpKey = keyValue.getKey().toStringUtf8();
            System.out.println("key : " + tmpKey);
            String tmpVal = keyValue.getValue().toStringUtf8();
            System.out.println("value : " + tmpVal);
            System.out.println("version : " + keyValue.getVersion());
        }

        // delete the key
        //kvClient.delete(key).get();
    }
}

4,报错


Exception in thread "main" java.util.concurrent.ExecutionException: io.grpc.StatusRuntimeException: UNAVAILABLE
    at com.google.common.util.concurrent.AbstractFuture.getDoneValue(AbstractFuture.java:476)
    at com.google.common.util.concurrent.AbstractFuture.get(AbstractFuture.java:455)

有的时候会这样报错。就得检查下etcd服务启动没有。
看看virtualbox的端口通不通。
或者直接用http访问就行。
http://127.0.0.1:2379/version

就是一个http调用。
其他命令参考:
http://cizixs.com/2016/08/02/intro-to-etcd
这个哥们写的挺全的。

5,总结


本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/56276386 未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

etcd 的性能还是非常的强悍的。
java的客户端使用的是grpc进行通信的。

目录
相关文章
|
Linux Python
centos使用Linux命令行测试网速/带宽
安装speedtest-cli speedtest-cli是一个用Python编写的轻量级Linux命令行工具,在Python2.4至3.4版本下均可运行。
3533 0
|
NoSQL 架构师 Java
再见 CentOS,AlmaLinux 9 测试版发布
美东时间 4 月 19 日,AlmaLinux 团队宣布了他们 9.0 测试版的里程碑。该团队表示,AlmaLinux 9.0 Beta 目前适用于所有受支持的架构,包括 x86_64、AArch64、PPC64LE 和 s390x。
491 0
|
NoSQL Linux Redis
Centos下 Docker 安装 Redis 并测试使用记录
本文是博主学习docker的记录,希望对大家有所帮助。
429 0
Centos下  Docker 安装 Redis 并测试使用记录
|
消息中间件 Kafka Linux
四十二、centos安装kafka,集群模式(生产者消费者部署测试)
四十二、centos安装kafka,集群模式(生产者消费者部署测试)
四十二、centos安装kafka,集群模式(生产者消费者部署测试)
|
Linux KVM 虚拟化
CentOS 7.2 运行 KVM测试
CentOS 7.2 运行 KVM测试
640 0
CentOS 7.2 运行 KVM测试
|
Linux Docker 容器
|
自然语言处理 安全 Java
我个人的log4cplus-1.2.1的编译与测试使用,CentOS环境
我个人的log4cplus-1.2.1的编译与测试使用,CentOS环境
679 0
|
负载均衡 网络协议 算法
Linux入门教程:centos 7 安装HAproxy四层TCP负载均衡配置及测试,
haproxy负载均衡166.110.110.100 后端服务器1 166.110.110.1 后端服务器2 166.110.110.2
755 0
|
Linux
Centos下pip3 install pycrypto安装失败的解决办法
Centos下pip3 install pycrypto安装失败的解决办法
1482 0
Centos下pip3 install pycrypto安装失败的解决办法