阿里云服务器--Elasticsearch配置

一、申请注册

Elasticsearch 是一个基于 Lucene 的搜索服务,它提供了 RESTful web 接口的分布式、多用户全文搜索引擎 。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是第二大最流行的企业搜索引擎。
Elasticsearch 应用于云计算中,具有实时搜索、稳定、可靠、快速、安装使用方便等优势;但也存在一些安全隐患:默认安装完成后,Elasticsearch 可以使用 9200 端口通告 web 的方式访问查看数据信息。
文档地址:https://help.aliyun.com/document_detail/57876.html?spm=a2c4g.11186623.6.550.25468d0faHVf4B
注意:
创建ES时,VPC的选择一定要注意,如果连ECS,一定要和ECS在同一个VPC。

二、ES访问测试

(一)密码重置

密码重置

(二)登录控制台Kibana

Kibana是一个开源的分析和可视化平台,设计用于和Elasticsearch一起工作。
你用Kibana来搜索,查看,并和存储在Elasticsearch索引中的数据进行交互。
你可以轻松地执行高级数据分析,并且以各种图标、表格和地图的形式可视化数据。
Kibana使得理解大量数据变得很容易。它简单的、基于浏览器的界面使你能够快速创建和共享动态仪表板,实时显示Elasticsearch查询的变化。


登录控制台Kibana

Kibana控制台

(三)ECS VPC配置

如果ECS要访问EC需配置VPC:
经典网络问题:
如果是经典网络需做如下设置

1、为专有网络创建Classiclink

专有网络创建Classiclink
打开Classiclink
打开ClassicLink

在ECS控制台,选择开启了 classicLink 的 VPC 所在 Region

2、连接到专有网络

连接到专有网络

连接状态

登陆链接了 Classiclink 的ECS实例,通过 curl 的形式访问对应 VPC 网络环境中的阿里云Elasticsearch实例验证。


创建实例

[root@iz2ze78abfa21jjsp4u9wmz ~]# curl -XPOST -u elastic:hrz123456! 'http://es-cn-mp911l8uh001qzcfj.elasticsearch.aliyuncs.com:9200/filebeat/my_type/'?pretty -d '{"title": "One", "tags": ["ruby"]}'
执行命令:
PUT filebeat

ES访问测试

设置公网地址访问白名单:


公网地址访问白名单

三、创建文档

开启自动创建索引。


开启自动创建索引
修改配置
允许自动创建索引

curl http://<HOST>:9200/my_index/my_type -XPOST -d '{"title": "One", "tags": ["ruby"]}'
my_index :是索引名称。
<HOST>:表示阿里云ES实例内网/公网地址。
每个文档都拥有自己的 ID 和 type,在返回的结果中会显示响应的 ID 和 type,如果在创建时没有指定,则系统会为其随机生成一个。
注意:
如果您已开启自动创建索引(默认关闭),并且指定的 index 名称不存在,则在创建 document 时,系统将自动创建 index

四、更新文档

若Elasticsearch中存在文档,可使用如下语句更新文档。
http://<HOST>:9200/my_index/my_type/<doc_id>
<HOST>:表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。
<doc_id>:表示文档标识ID。
curl http://<HOST>:9200/my_index/my_type/AV4JIvi15ny3i8DCdK1H -XPOST -d '{"title": "Four updated", "tags": ["ruby", "php"]}'

五、检索文档

可以通过HTTP GET对文档进行检索查询:
$ curl http://<HOST>:9200/my_index/my_type/AV4JIvi15ny3i8DCdK1H
<HOST>:表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。

六、搜索文档

可以通过HTTP GET或HTTP POST对文档进行搜索,通过 URI 参数制定搜索对象,目标如下:
http://<HOST>:9200/_search
http://<HOST>:9200/{index_name}/_search
http://<HOST>:9200/{index_name}/{type_name}/_search
<HOST>:表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。
例如:
$ curl http://<HOST>:9200/my_index/my_type/_search?q=title:T*
<HOST>:表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。

七、复杂搜索

必须使用HTTP POST对文档进行复杂搜索:
$ curl http://<HOST>:9200/my_index/my_type/_search?pretty=true -XPOST -d '{
"query": {
"query_string": {"query": "*"}
},
"facets": {
"tags": {
"terms": {"field": "tags"}
}
}}'

<HOST>:表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。
温馨提示:
使用?pretty=true是为了让返回结果更具可读性。

八、 删除文档

$ curl http://<HOST>:9200/{index}/{type}/{id} -XDELETE
  • <HOST>表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。

九、删除指定类型对文档

$ curl http://<HOST>:9200/{index}/{type} -XDELETE
  • <HOST>表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。

十、删除一个索引

$ curl http://<HOST>:9200/{index} -XDELETE
  • <HOST>表示阿里云ES实例内网/公网地址,详情请参见阿里云ES实例基本信息界面。

十一、Java语言

需要先创建对应索引和mapping或者[开启自动创建索引]
注意:
ES官方已不建议通过TransportClient来访问Elasticsearch,使用TransportClient 5.5.3版在建立连接时会报 NoNodeAvailableException 问题,并且ES官方已经不再维护TransportClient。如果已经使用并且有提示报错,可用以下方法绕过:

  • 建议换成[Java Low Level REST Client]来访问Elasticsearch。
  • 在Java maven项目的[POM配置文件]中,使用 x-pack-transport-5.3.3 版client进行访问,并且POM配置文件中的elasticsearch版本也必须为5.3.3版,不建议通过该方案来绕着实现,不保证能完全兼容。

(一)Maven配置

要先创建对应索引和mapping或者开启自动创建索引
分词配置

YML文件配置

代码:

接口:
public interface IESRestService {
    /**
     * 同步方式向ES集群写入数据
     *
     * @param index
     * @param type
     * @param id
     * @param entity
     * @return
     */
    boolean syncCreateDocument(String index, String type, String id, HttpEntity entity);

    /**
     * 异步的方式向ES写入数据
     *
     * @param index
     * @param type
     * @param id
     * @param entity
     */
    void asyncCreateDocument(String index, String type, String id, HttpEntity entity);

    /**
     * 创建索引
     * @param index
     */
     void createIndex(String index);
    /**
     * 获取文档
     * @param index
     * @param type
     * @param id
     * @return
     */
     String getDocument(String index, String type, String id);

    /**
     * 查询所有数据
     * @param index
     * @param type
     * @return
     */
     String queryAll(String index, String type);

    /**
     * 根据ID获取
     * @param index
     * @param type
     * @param key
     * @param value
     */
     void queryById(String index, String type, String key, String value);

    /**
     * 更新数据
     * @param index
     * @param type
     * @param id
     * @param key
     * @param value
     */
    void updateByScript(String index, String type, String id, String key, String value);
}
Java实现类:
@Service
public class ESRestServiceImpl implements IESRestService {

    private static String userName = "elastic";
    private static String password = "hrz123456!";
    private static String host = "es-cn-mp911l8uh001qzcfj.public.elasticsearch.aliyuncs.com";
    private static int port = 9200;
    private RestClient restClient = null;

    public static RestClient getInstance() {
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials(userName, password));
        RestClient restClient = RestClient.builder(new HttpHost(host, port))
                .setHttpClientConfigCallback(new RestClientBuilder.HttpClientConfigCallback() {
                    @Override
                    public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
                        return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
                    }
                }).build();
        return restClient;
    }

    @PostConstruct
    public void init() {
        restClient = ElasticsearchUtils.getInstance();
    }

    @PreDestroy
    public void destroy() {
        if (restClient != null) {
            try {
                restClient.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 同步方式向ES集群写入数据
     *
     * @param index
     * @param type
     * @param id
     * @param entity
     * @return
     */
    @Override
    public boolean syncCreateDocument(String index, String type, String id, HttpEntity entity) {
        Response indexResponse = null;
        try {
            indexResponse = restClient.performRequest(
                    "PUT",
                    "/" + index + "/" + type + "/" + id,
                    Collections.<String, String>emptyMap(),
                    entity);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return (indexResponse != null);
    }

    /**
     * 异步的方式向ES写入数据
     *
     * @param index
     * @param type
     * @param id
     * @param entity
     */
    public void asyncCreateDocument(String index, String type, String id, HttpEntity entity) {
        /**
         *  HTTP的方法,可以是PUT,POST,DELETE,HEAD,GET等
         *  endpoint, 这个就是指数据在ES中的位置,由index,type以及id确定
         *  是一个map指的是操作数,即目标数据,这个例子里面表示要存入ES的数据对象
         *  异步操作的监听器,在这里,注册listener,对操作成功或者失败进行后续的处理,比如在这里向前端反馈执行后的结果状态
         */
        restClient.performRequestAsync(
                "PUT",
                "/" + index + "/" + type + "/" + id,
                Collections.<String, String>emptyMap(),
                entity,
                new ResponseListener() {
                    @Override
                    public void onSuccess(Response response) {
                        System.out.println(response);
                    }

                    @Override
                    public void onFailure(Exception exception) {
                        System.out.println("异步操作失败!");
                    }
                });
    }

    /**
     * 创建索引
     *
     * @param index
     */
    @Override
    public void createIndex(String index) {
        String method = "PUT";
        String endpoint = "/" + index;
        Response response = null;
        try {
            response = restClient.performRequest(method, endpoint);
            System.out.println(EntityUtils.toString(response.getEntity()));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 获取文档
     *
     * @param index
     * @param type
     * @param id
     * @return
     */
    public String getDocument(String index, String type, String id) {
        String method = "GET";
        String result = null;
        String endpoint = "/" + index + "/" + type + "/" + id;
        Response response = null;
        try {
            response = restClient.performRequest(method, endpoint);
            result = EntityUtils.toString(response.getEntity());
            return result;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 查询所有数据
     *
     * @param index
     * @param type
     * @return
     */
    public String queryAll(String index, String type) {
        String result = null;
        try {
            String method = "POST";
            String endpoint = "/" + index + "/" + type + "/_search";
            HttpEntity entity = new NStringEntity("{\n" +
                    "  \"query\": {\n" +
                    "    \"match_all\": {}\n" +
                    "  }\n" +
                    "}", ContentType.APPLICATION_JSON);
            Response response = restClient.performRequest(method, endpoint, Collections.<String, String>emptyMap(), entity);
            result = EntityUtils.toString(response.getEntity());
            return result;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 根据ID获取
     *
     * @param index
     * @param type
     * @param key
     * @param value
     */
    public void queryById(String index, String type, String key, String value) {
        String method = "POST";
        String endpoint = "/" + index + "/" + type + "/_search";
        HttpEntity entity = new NStringEntity("{\n" +
                "  \"query\": {\n" +
                "    \"match\": {\n" +
                "      \"" + key + "\": \"" + value + "\"\n" +
                "    }\n" +
                "  }\n" +
                "}", ContentType.APPLICATION_JSON);
        Response response = null;
        try {
            response = restClient.performRequest(method, endpoint, Collections.<String, String>emptyMap(), entity);
            System.out.println(EntityUtils.toString(response.getEntity()));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 更新数据
     *
     * @param index
     * @param type
     * @param id
     * @param key
     * @param value
     */
    public void updateByScript(String index, String type, String id, String key, String value) {
        try {
            String method = "POST";
            String endpoint = "/" + index + "/" + type + "/" + id + "/_update";
            HttpEntity entity = new NStringEntity("{\n" +
                    "  \"doc\": {\n" +
                    "    \"" + key + "\":\"" + value + "\"\n" +
                    "   }\n" +
                    "}", ContentType.APPLICATION_JSON);
            Response response = restClient.performRequest(method, endpoint, Collections.<String, String>emptyMap(), entity);
            System.out.println(EntityUtils.toString(response.getEntity()));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

测试结果:

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容