原文链接:https://www.plaza4me.com/article/20180825223826278

由于在elasticsearch在6.3版本之后x-pack是默认安装好的,所以不再需要用户自己去安装

在此之前你可以先体验试用版30天(不影响后面破解)

启动elasticsearch后通过curl启动测试(注意端口修改)

curl -H "Content-Type:application/json" -XPOST  http://localhost:9285/_xpack/license/start_trial?acknowledge=true

然后你会看到如下返回信息表示启用测试版成功

{"acknowledged":true,"trial_was_started":true,"type":"trial"}

由于接下来的密码设置等步骤和破解使用是一样的方式,就不多赘述了,大家可以往下翻查找自己想要的配置

1.进入/usr/local目录(根据自己喜好选择,创建的文件后期会删除)

如果不想自己弄的也可以直接使用我打包好的(然后可以跳到步骤3的覆盖命令去)

jar包下载地址:https://pan.baidu.com/s/1ESSuFfQI-eSewV_kGdNo8A 密码:img3

①创建LicenseVerifier.java文件

vim LicenseVerifier.java

复制以下代码

  1.  
    package org.elasticsearch.license;
  2.  
    import java.nio.*; import java.util.*;
  3.  
    import java.security.*;
  4.  
    import org.elasticsearch.common.xcontent.*;
  5.  
    import org.apache.lucene.util.*;
  6.  
    import org.elasticsearch.common.io.*;
  7.  
    import java.io.*;
  8.  
     
  9.  
    public class LicenseVerifier {
  10.  
    public static boolean verifyLicense(final License license, final byte[] encryptedPublicKeyData) {
  11.  
    return true;
  12.  
    }
  13.  
     
  14.  
    public static boolean verifyLicense(final License license) {
  15.  
    return true;
  16.  
    }
  17.  
    }

②创建XPackBuild.java文件

vim XPackBuild.java

复制以下代码

  1.  
    package org.elasticsearch.xpack.core;
  2.  
    import org.elasticsearch.common.io.*;
  3.  
    import java.net.*;
  4.  
    import org.elasticsearch.common.*;
  5.  
    import java.nio.file.*;
  6.  
    import java.io.*;
  7.  
    import java.util.jar.*;
  8.  
    public class XPackBuild {
  9.  
    public static final XPackBuild CURRENT;
  10.  
    private String shortHash;
  11.  
    private String date;
  12.  
    @SuppressForbidden(reason = "looks up path of xpack.jar directly") static Path getElasticsearchCodebase() {
  13.  
    final URL url = XPackBuild.class.getProtectionDomain().getCodeSource().getLocation();
  14.  
    try { return PathUtils.get(url.toURI()); }
  15.  
    catch (URISyntaxException bogus) {
  16.  
    throw new RuntimeException(bogus); }
  17.  
    }
  18.  
     
  19.  
    XPackBuild(final String shortHash, final String date) {
  20.  
    this.shortHash = shortHash;
  21.  
    this.date = date;
  22.  
    }
  23.  
     
  24.  
    public String shortHash() {
  25.  
    return this.shortHash;
  26.  
    }
  27.  
    public String date(){
  28.  
    return this.date;
  29.  
    }
  30.  
     
  31.  
    static {
  32.  
    final Path path = getElasticsearchCodebase();
  33.  
    String shortHash = null;
  34.  
    String date = null;
  35.  
    Label_0157: { shortHash = "Unknown"; date = "Unknown";
  36.  
    }
  37.  
     
  38.  
    CURRENT = new XPackBuild(shortHash, date);
  39.  
    }
  40.  
    }

2.分别编译两个文件

javac -cp "/usr/local/elasticsearch/lib/elasticsearch-6.3.2.jar:/usr/local/elasticsearch/lib/lucene-core-7.3.1.jar:/usr/local/elasticsearch/modules/x-pack/x-pack-core/x-pack-core-6.3.2.jar" LicenseVerifier.java
javac -cp "/usr/local/elasticsearch/lib/elasticsearch-6.3.2.jar:/usr/local/elasticsearch/lib/lucene-core-7.3.1.jar:/usr/local/elasticsearch/modules/x-pack/x-pack-core/x-pack-core-6.3.2.jar:/usr/local/elasticsearch/lib/elasticsearch-core-6.3.2.jar"  XPackBuild.java

编译完成后会生成LicenseVerifier.class和XPackBuild.class两个文件

3.覆盖之前的jar文件

  1.  
    cd /usr/local
  2.  
    mkdir tempJar
  3.  
    cp /usr/local/elasticsearch/modules/x-pack/x-pack-core/x-pack-core-6.3.2.jar tempJar/
  4.  
    cd tempJar
  5.  
    jar -xf x-pack-core-6.3.2.jar
  6.  
    cp ../LicenseVerifier.class org/elasticsearch/license/
  7.  
    cp ../XPackBuild.class org/elasticsearch/xpack/core/
  8.  
    rm x-pack-core-6.3.2.jar
  9.  
    jar -cvf x-pack-core-6.3.2.jar *
  10.  
    #覆盖之前的jar包
  11.  
    cp x-pack-core-6.3.2.jar /usr/local/elasticsearch/modules/x-pack/x-pack-core/

4.修改elasticsearch.yml配置文件

  1.  
    #添加如下代码打开x-pack安全验证
  2.  
    xpack.security.enabled: true

5.生成用户名和密码

  1.  
    cd /usr/local/elasticsearch/bin
  2.  
    #自动生成(二选一)
  3.  
    ./elasticsearch-setup-passwords auto
  4.  
    #手动生成(二选一)
  5.  
    ./elasticsearch-setup-passwords interactive

6.将生成的elastic密码配置到kibana中(如何安装配置kibana

  1.  
    cd /usr/local/kibana/config
  2.  
    vim kibana.yml
  3.  
    #找到以下参数并修改(以下用户名和密码均为你自己的elasticsearch的账户和密码)
  4.  
    #就是上一步骤5生成的密码
  5.  
    elasticsearch.username: elastic
  6.  
    elasticsearch.password: XXXXXXXXXXX

7.启动kibana(先启动elasticsearch)

  1.  
    cd /usr/local/kibana/bin
  2.  
    ./kibana

启动完成后访问kibana(这个就不用我多说了吧,记得要开放端口哦)

但是我们发现只有一个月的试用时间(在登陆成功后的主页面Management->LicenseManagement可以看到)

Your Trial license is active

Your license will expire on September 20, 2018 2:49 PM CST

8.破解

所以接下来我们要做的就是上传license.json(这是我弄好的,注意保存为.json格式)

  1.  
    {
  2.  
    "license": {
  3.  
    "uid": "9gfhf46-5g78-4f1e-b5a4-afet359bc3a3",
  4.  
    "type": "platinum",
  5.  
    "issue_date_in_millis": 1534723200000,
  6.  
    "expiry_date_in_millis": 2544271999999,
  7.  
    "max_nodes": 100,
  8.  
    "issued_to": "www.plaza4me.com",
  9.  
    "issuer": "Web Form",
  10.  
    "signature": "AAAAAwAAAA3lQFlr4GED3cGRsdfgrDDFEWGN0hjZDBGYnVyRXpCOsdfasdfsgEfghgdg3423MVZwUzRxVk1PSmkxagfsdf3242UWh3bHZVUTllbXNPbzBUemtnbWpBbmlWRmRZb25KNFlBR2x0TXc2K2p1Y1VtMG1UQU9TRGZVSGRwaEJGUjE3bXd3LzRqZ05iLzRteWFNekdxRGpIYlFwYkJiNUs0U1hTVlJKNVlXekMrSlVUdFIvV0FNeWdOYnlESDc3MWhlY3hSQmdKSjJ2ZTcvYlBFOHhPQlV3ZHdDQ0tHcG5uOElCaDJ4K1hob29xSG85N0kvTWV3THhlQk9NL01VMFRjNDZpZEVXeUtUMXIyMlIveFpJUkk2WUdveEZaME9XWitGUi9WNTZVQW1FMG1DenhZU0ZmeXlZakVEMjZFT2NvOWxpZGlqVmlHNC8rWVVUYzMwRGVySHpIdURzKzFiRDl4TmM1TUp2VTBOUlJZUlAyV0ZVL2kvVk10L0NsbXNFYVZwT3NSU082dFNNa2prQ0ZsclZ4NTltbU1CVE5lR09Bck93V2J1Y3c9PQAAAQCGcZtOlZwj0Rnl2MUjERG94a+xcifpVAurIA+z4rroxaqaewpb2MJLZVJt1ZCGeKB0KIWRAm2pkPjM2JigjaPIUBhpW4/yUzbdRtRuQB4loEKd7/p9EbHDh5GzeI8qfkMh3j7QaAlz4Bk+eett+ZNqNXHEdkr+Re9psdnqfUESz1uROhMoYWbn/Bdd0AJLKzhRnEOE972xdnAar8bCP1DIDljI9IOnYhEc6O6CboKCMJY4AWOvJY83bud4FO25hrKf6bMy0F2oO2yUkVV0UiFMX19JbhcC+WIAgxMk/KG7e/MqR8bJ1jNu2usMlgkvV97BxiPogTujFnTQxoHdpNdR",
  11.  
    "start_date_in_millis": 1534723200000
  12.  
    }
  13.  
    }

然后把license.json上传到服务器并使用curl提交

curl -XPUT -u elastic 'http://127.0.0.1:9255/_xpack/license' -H "Content-Type: application/json" -d @license.json

不出意外的话你会得到报错信息

{"error":{"root_cause":[{"type":"illegal_state_exception","reason":"Cannot install a [PLATINUM] license unless TLS is configured or security is disabled"}],"type":"illegal_state_exception","reason":"Cannot install a [PLATINUM] license unless TLS is configured or security is disabled"},"status":500}

大意就是说你把x-pack关了再上传试试(然后我们关了再试试)

  1.  
    vim /usr/local/elasticsearch/config/elasticsearch.yml
  2.  
    #找到并修改以下变量
  3.  
    xpack.security.enabled: false

再次启动elasticsearch并提交license.json我们会得到如下响应{"acknowledged":true,"license_st.......................}(就是这种)

这就说明我们基本上已经快要成功了

然后我们把x-pack再打开

  1.  
    vim /usr/local/elasticsearch/config/elasticsearch.yml
  2.  
    #找到并修改以下变量
  3.  
    xpack.security.enabled: true

重启elasticsearch

不出意外的话你们会得到这个

ERROR: [1] bootstrap checks failed
[1]: Transport SSL must be enabled for setups with production licenses. Please set [xpack.security.transport.ssl.enabled] to [true] or disable security by setting [xpack.security.enabled] to [false]

意思就是说:你要me把ssl什么的打开,要么就把x-pack关了才行(我去,我费这么大劲你给我说这个)

9.配置SSL

  1.  
    cd /usr/local/elasticsearch/bin/
  2.  
    ./elasticsearch-certgen

然后会出现如下信息标红的代表你要填写的

******************************************************************************
Note: The 'elasticsearch-certgen' tool has been deprecated in favour of the
      'elasticsearch-certutil' tool. This command will be removed in a future
      release.
******************************************************************************

This tool assists you in the generation of X.509 certificates and certificate
signing requests for use with SSL in the Elastic stack. Depending on the command
line option specified, you may be prompted for the following:

* The path to the output file
    * The output file is a zip file containing the signed certificates and
      private keys for each instance. If a Certificate Authority was generated,
      the certificate and private key will also be included in the output file.
* Information about each instance
    * An instance is any piece of the Elastic Stack that requires a SSL certificate.
      Depending on your configuration, Elasticsearch, Logstash, Kibana, and Beats
      may all require a certificate and private key.
    * The minimum required value for each instance is a name. This can simply be the
      hostname, which will be used as the Common Name of the certificate. A full
      distinguished name may also be used.
    * A filename value may be required for each instance. This is necessary when the
      name would result in an invalid file or directory name. The name provided here
      is used as the directory name (within the zip) and the prefix for the key and
      certificate files. The filename is required if you are prompted and the name
      is not displayed in the prompt.
    * IP addresses and DNS names are optional. Multiple values can be specified as a
      comma separated string. If no IP addresses or DNS names are provided, you may
      disable hostname verification in your SSL configuration.
* Certificate Authority private key password
    * The password may be left empty if desired.

Let's get started...

Please enter the desired output file [certificate-bundle.zip]: cert.zip  (压缩包名称)
Enter instance name: my-application(实例名)
Enter name for directories and files [p4mES]: elasticsearch(文件夹名)
Enter IP Addresses for instance (comma-separated if more than one) []: 127.0.0.1(实例ip,多个ip用逗号隔开)
Enter DNS names for instance (comma-separated if more than one) []: node-1(节点名,多个节点用逗号隔开)
Would you like to specify another instance? Press 'y' to continue entering instance information: 
Certificates written to /usr/local/elasticsearch/bin/cert.zip(这个是生成的文件存放地址,不用填写)

This file should be properly secured as it contains the private keys for all
instances and the certificate authority.

After unzipping the file, there will be a directory for each instance containing
the certificate and private key. Copy the certificate, key, and CA certificate
to the configuration directory of the Elastic product that they will be used for
and follow the SSL configuration instructions in the product guide.

For client applications, you may only need to copy the CA certificate and
configure the client to trust this certificate.

接下来就是把.zip压缩包解压然后把ca文件夹和elasticsearch文件夹的东西都放到/usr/local/elasticsearch/config目录下

再修改elasticsearch.yml配置文件

  1.  
    vim /usr/local/elasticsearch/config/elasticsearch.yml
  2.  
    #添加如下变量
  3.  
    xpack.security.transport.ssl.enabled: true
  4.  
    xpack.ssl.key: elasticsearch.key
  5.  
    xpack.ssl.certificate: elasticsearch.crt
  6.  
    xpack.ssl.certificate_authorities: ca.crt

再重新启动elasticsearch会出现exception caught on transport layer [NettyTcpChannel{localAddress=0.0.0.0/0.0.0.0:45812, remoteAddress=/0:0:0:0:0:0:0:1:9300}], closing connection

出现这种情况我的选择是禁用ipv6

  1.  
    vim /etc/sysctl.conf
  2.  
    #添加如下变量
  3.  
    net.ipv6.conf.all.disable_ipv6 = 1
  4.  
    net.ipv6.conf.default.disable_ipv6 = 1
  5.  
    #保存退出
  1.  
    #使修改生效
  2.  
    sysctl -p

再次启动便没有任何问题了

然后看我们的license也应该是到2050年过期了

10.总结

自己配置起来很快,但是写了这么多是真不容易,有些地方可能还比较啰嗦但主要是为了写清楚。如果还不清楚的话可以私信或者留言,我会第一时间回复。最后奉上我的小站(plaza4me.com)

elasticsearch6.3.2之x-pack6.3.2破解安装并配合kibana使用的更多相关文章

  1. centos7安装elasticsearch6.3.x集群并破解安装x-pack

    一.环境信息及安装前准备 主机角色(内存不要小于1G): 软件及版本(百度网盘链接地址和密码:链接: https://pan.baidu.com/s/17bYc8MRw54GWCQCXR6pKjg 提 ...

  2. Mac环境下 elasticsearch-6.0.1 和 elasticsearch-head 完整安装过程

     安装步骤: 安装java jdk 安装elasticsearch-6.0.1 及中文分词 anslysis-ik-6.0.1 安装elasticsearch-head 下载jdk https://w ...

  3. Elasticsearch6.5.2 X-pack破解及安装教程

    先正常安装 elasticSearch, kibana. 1. 如果是6.5.2版本,可以直接下载jar文件:https://download.csdn.net/download/bigben0123 ...

  4. 【ELK】之Centos6.9_x64安装elasticsearch6.2.1

    1.下载elasticsearch6.2.1 wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.2.1 ...

  5. Kafka:ZK+Kafka+Spark Streaming集群环境搭建(十七)Elasticsearch-6.2.2集群安装,组件安装

    1.集群安装es ES内部索引原理: <时间序列数据库的秘密(1)—— 介绍> <时间序列数据库的秘密 (2)——索引> <时间序列数据库的秘密(3)——加载和分布式计算 ...

  6. elasticsearch-6.2.4 + kibana-6.2.4-windows-x86_64安装配置

    1.es和kibana的版本都是6.2.4 elasticsearch-6.2.4 + kibana-6.2.4-windows-x86_64 2.先安装es,下载下来解压, config目录下修改  ...

  7. Elasticsearch6.4.0-windows环境部署安装

    Elasticsearch可以轻松的实现全文检索,本文主要介绍Elasticsearch(ES)环境的安装部署,该文及后续使用的ES版本为6.4.0.希望能够帮助到大家. 一.安装Elasticsea ...

  8. Centos7安装elasticsearch6.3及ik分词器,设置开机自启

    参考Elasticsearch 在CentOs7 环境中开机启动 建议虚拟机的内存大小为4G 1. 新建一个用户john 出于安全考虑,elasticsearch默认不允许以root账号运行. 创建用 ...

  9. Linux下安装Elasticsearch6.5

    1.安装JDK8(Elastic 需要 Java 8 环境) 1)下载jdk8文件:http://www.oracle.com/technetwork/java/javase/downloads/jd ...

随机推荐

  1. Jira 7.2.4简单安装过程

    1. 下载安装jira的安装文件 这里使用同事已经下载好的文件. 2. 下载破解文件. 也是同事下载好的 具体文件为 atlassian-jira-software--x64 51CTO下载-jira ...

  2. JVM的自愈能力

    在IT行业,碰到问题的第一个反应通常是——“你重启过没”——而这样做可能会适得其反,本文要讲述的就是这样的一个场景. 接下来要介绍的这个应用,它不仅不需要重启,而且毫不夸张地说,它能够自我治愈:刚开始 ...

  3. ssm 整合 redis(简单教程)

    最后我建议大家使用 Spring StringRedisTemplate 配置,参阅: http://blog.csdn.net/hanjun0612/article/details/78131333 ...

  4. Strategic Game HDU - 1054(最小顶点覆盖)

    最小顶点覆盖:用最少的点,让每条边都至少和其中一个点关联: ...以为自己很聪明..用边连边...最后还是点连点  哎.... hc 写的  匈牙利足够///// #include <iostr ...

  5. 【BZOJ1489】[HNOI2009]双递增序列(动态规划)

    [BZOJ1489][HNOI2009]双递增序列(动态规划) 题面 BZOJ 洛谷 题解 这\(dp\)奇奇怪怪的,设\(f[i][j]\)表示前\(i\)个数中,第一个数列选了\(j\)个数,第二 ...

  6. 【BZOJ3872】Ant colony(二分,动态规划)

    [BZOJ3872]Ant colony(二分,动态规划) 题面 又是权限题... Description There is an entrance to the ant hill in every ...

  7. 【转】crc16几种标准校验算法及c语言代码

    一.CRC16校验码的使用 现选择最常用的CRC-16校验,说明它的使用方法. 根据Modbus协议,常规485通讯的信息发送形式如下: 地址 功能码 数据信息 校验码 1byte 1byte nby ...

  8. linux运维之分析日志相关命令(1)

    一.分析日志 1.查看有多少IP访问 awk '{print $1}' log_file|sort|uniq|wc -l 2.查看某一个页面被访问的次数 grep "/index.php&q ...

  9. LookupError: unknown encoding: cp65001解决方案

    本人遇到这个问题搜索了很多网站,有人建议在cmd中执行命令chcp 936,然而,,,最终决定更换cmd窗口,window的cmd真的很烂, 果断使用git cmd,完美解决...

  10. Mysql(二)函数与连接

    一.函数 1.if函数 if(exp1, exp2, exp3)     判断exp1是否为true(不为0,并且不为nlll),如果为true,返回 exp2的值,否则返回exp3的值. selec ...