在Windows上安装Elasticsearch 5.x

mac2022-06-30  302

自己想学习Elasticsearch,但是又不懂Linux,按照同事给的Linux安装教程,也是搞不明白,于是想先在Windows上安装一下入门。可是百度的大部分都是ES 1.x,2.x版本的教程,5.x的教程也是搞不明白,很多步骤就直接跳过了。经过一步一步的尝试,最终还是成功了。记录下,希望对大家有所帮助。

一、JAVA环境配置

ElasticSearch是基于lucence开发的,也就是运行需要java jdk()支持。所以要先安装JAVA环境。由于ElasticSearch 5.x 依赖于JDK 1.8的,所以现在我们下载JDK 1.8或者更高版本。下载JDK1.8,下载完成后安装。接下来就是环境变量配置。

1、右键 【我的电脑】→【属性】→【高级系统设置】→【环境变量】如图

2、在【系统变量】里【新建】,变量名为JAVA_HOME,变量值为JDK的安装路径。然后确定。

验证是否成功,打开cmd,输入echo %JAVA_HOME%显示你设置的JDK的路径即为正确。

3、在【系统变量】选项区域中查看PATH变量,如果不存在,则新建变量 PATH,否则选中该变量,单击“编辑”按钮,在“变量值”文本框的最后位置追加【%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;】单击确定按钮。

4、在【系统变量】选项区域中查看CLASSPATH 变量,如果不存在,则新建变量CLASSPATH,否则选中该变量,单击“编辑”按钮,在“变量值”文本框的最后位置追加【.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;】。

5、打开cmd,输入javac命令测试是否成功,出现下图则ok

注:配置完成之后需要在新的cmd窗口输入javac。

二、ElasticSearch配置

1、下载ElasticSearch

从官网下载ElasticSearch https://www.elastic.co/downloads/elasticsearch,下载zip。

这里我们下载最新版 ElasticSearch5.3 。

2、解压到指定的目录,这里我解压到了C盘根目录。
3、进入到C:\elasticsearch-5.3.0\bin执行elasticsearch.bat
4、本机就启动了一个ElasticSearch节点,启动后会显示如图所示

5、打开浏览器里测试一下

OK大功告成~~

三、安装ElasticSearch-head插件

网上很多教程都说用plugin命令去装es-head插件,跟开头说的一样都是1.x,2.x版本,我也下载看了,里面是有plugin的文件。可是我们是要用5.x的版本,es包里并没有提供plugin文件。

elasticsearch5不可以直接通过plugin -install mobz/elasticsearch-head安装,并且head需要在node环境下运行

1、安装node环境

安装参考:http://www.runoob.com/nodejs/nodejs-install-setup.html  (最好通过.msi安装,.exe安装环境变量自动配置有问题)

网址:https://nodejs.org/en/download/ 下载Windows版msi的

安装完后打开cmd查看版本node -v

2、安装grunt
grunt是一个很方便的构建工具,可以进行打包压缩、测试、执行等等的工作,5.x里的head插件就是通过grunt启动的。因此需要安装grunt.注意:路径切到nodejs安装目录下,[我安装在C:\Program Files\nodejs]。npm install -g grunt-cli-g代表全局安装。安装路径为C:\Users\{yourname}\AppData\Roaming\npm,并且自动加入PATH变量。查看版本号grunt -version

4、下载head插件

https://github.com/mobz/elasticsearch-head

5、配置head

由于head的代码还是2.6版本的,直接执行有很多限制,比如无法跨机器访问。因此需要用户修改两个地方:

① c:/elasticsearch-head-master/Gruntfile.js,增加hostname属性,设置为*,如图

②修改连接地址:C:\elasticsearch-head-master/_site/app.js,将表红线地址改为es服务器地址。

修改一下es使用的参数。编辑C:/elasticsearch-5.3.0/config/config/elasticsearch.yml:

cluster.name: es-5.2-test #换个集群的名字,免得跟别人的集群混在一起 node.name: node-es-101 #换个节点名字 network.host: 0.0.0.0 #修改一下ES的监听地址,这样别的机器也可以访问 http.port: 9200 #端口号,默认就好 # 增加新的参数,这样head插件可以访问es http.cors.enabled: true http.cors.allow-origin: "*" @注意,设置参数的时候:后面要有空格!
6、安装head

其实下载elasticsearch-head的时候,github的链接上有介绍安装方式,如下:

git clone git://github.com/mobz/elasticsearch-head.git cd elasticsearch-head npm install npm run start open http://localhost:9100/

进入到我们下载好的elasticsearch-head包里,然后执行npm install

安装完成之后npm run start或grunt server

浏览器访问 http://localhost:9100/

到此,Elasticsearch和ElasticSearch-head已经装好了。

四、安装分词

以下是安装的官方插件,个别插件需要配置才能使用,可根据需要删除 plugins 目录无关的插件,重启 elasticsearch 生效。

bin/elasticsearch-plugin install discovery-multicast bin/elasticsearch-plugin install analysis-icu bin/elasticsearch-plugin install analysis-kuromoji bin/elasticsearch-plugin install analysis-phonetic bin/elasticsearch-plugin install analysis-smartcn bin/elasticsearch-plugin install analysis-stempel bin/elasticsearch-plugin install analysis-ukrainian bin/elasticsearch-plugin install discovery-file bin/elasticsearch-plugin install ingest-attachment bin/elasticsearch-plugin install ingest-geoip bin/elasticsearch-plugin install ingest-user-agent bin/elasticsearch-plugin install mapper-attachments bin/elasticsearch-plugin install mapper-size bin/elasticsearch-plugin install mapper-murmur3 bin/elasticsearch-plugin install lang-javascript bin/elasticsearch-plugin install lang-python bin/elasticsearch-plugin install repository-hdfs bin/elasticsearch-plugin install repository-s3 bin/elasticsearch-plugin install repository-azure bin/elasticsearch-plugin install repository-gcs bin/elasticsearch-plugin install store-smb bin/elasticsearch-plugin install discovery-ec2 bin/elasticsearch-plugin install discovery-azure-classic bin/elasticsearch-plugin install discovery-gce    Linux安装方式:http://www.cnblogs.com/lollipop/p/6817309.html  转自:http://www.cnblogs.com/lollipop/p/6817328.html

转载于:https://www.cnblogs.com/kms1989/p/7121775.html

相关资源:JAVA上百实例源码以及开源项目

最新回复(0)