当前位置:首页 > 技术文档 > 正文内容

Cenots上elasticsearch安装与使用

admin7年前 (2018-06-12)技术文档1759
  1. 安装java环境

    懒人模式:yum install java*

    简单配置下:

    vim /etc/profile

    尾部加上:

export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-8.b10.el7_5.x86_64
export CLASSPATH=.:$JAVA_HOME/jre/lib/rt.jar:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export PATH=$PATH:$JAVA_HOME/bin

    保存退出后使用命令更新配置

source /etc/profile

    2.安装elasticsearch

由于ES不在yum的本地源,所以我们需要添加ES的yum配置。

     下载并安装ES的yum公钥

rpm --import https://packages.elastic.co/GPG-KEY-elasticsearch

    配置ES的yum源

vim /etc/yum.repos.d/elasticsearch.repo

    输入下面的内容:


[elasticsearch-2.x]
name=Elasticsearch repository for 2.x packages
baseurl=http://packages.elastic.co/elasticsearch/2.x/centosgpgcheck=1gpgkey=http://packages.elastic.co/GPG-KEY-elasticsearchenabled=1

二、yum安装ES

    更新yum的缓存


yum makecache

    安装ES

yum install elasticsearch

三、测试ES

1、配置和启动ES服务器进程

/sbin/chkconfig --add elasticsearch
systemctl start elasticsearch

2、查看状态(可能遇到启动失败,如果遇到内存不足情况,弄点swap虚拟内存凑一下)

systemctl status elasticsearch

3、运行测试

curl -X GET localhost:9200

返回的json结果如下:

{
    "name": "Mister One",
    "cluster_name": "elasticsearch",
    "cluster_uuid": "HGBnQTTDTpKlCJnMSXyHBg",
    "version": {
        "number": "2.4.6",
        "build_hash": "5376dca9f70f3abef96a77f4bb22720ace8240fd",
        "build_timestamp": "2017-07-18T12:17:44Z",
        "build_snapshot": false,
        "lucene_version": "5.5.4"
    },
    "tagline": "You Know, for Search"
}

四、通过IP访问ES的配置

四、通过IP访问ES的配置

 

1、打开/etc/elasticsearch/elasticsearch.yml

vim /etc/elasticsearch/elasticsearch.yml

   


 55行的network.host,把后面改为0.0.0.0或者虚拟机ip地址,这样就可以在window系统用浏览器通过访问虚拟机的ip,正确访问效果如下

 

image.png

安装elasticsearch-head插件,用于监控

 cd /usr/share/elasticsearch/bin

执行:

 ./plugin install mobz/elasticsearch-head

安装完成后,即可通过浏览器访问:

http://192.168.32.128:9200/_plugin/head/

image.png

    php使用案例:

<?php 
require_once('vendor/autoload.php');
use Elasticsearch\ClientBuilder;


function get_conn(){
	$host = 'localhost';
	$dbname = 'mraz';
	$user = 'root';
	$passwd = '111111';


	$conn = new PDO("mysql:dbname=$dbname;host=$host",$user,$passwd);
	return $conn;
}


function create_index(){
	//Elastic search php client




	$client = Elasticsearch\ClientBuilder::create()->setHosts(['192.168.32.128'])->build();
	$sql    = "SELECT * FROM emp";
	$conn   = get_conn();
	$stmt   = $conn->query($sql);
	$rtn    = $stmt->fetchAll();


	//delete index which already created
	$params = array();
	$params['index'] = 'emp_index';
	$client->indices()->delete($params);
	
	//create index on log_date,src_ip,dest_ip
	$rtnCount = count($rtn);
	for($i=0;$i<$rtnCount;$i++){
		$params = array();
		$params['body'] = array(
			'id'       => $rtn[$i]['id'],
			'fdName'   => $rtn[$i]['fdName'],
			'fdAge'    => $rtn[$i]['fdAge'],
			'fdStatus' => $rtn[$i]['fdStatus']
		);
		$params['index'] = 'emp_index';
		$params['type']  = 'emp_type';
		
		//Document will be indexed to log_index/log_type/autogenerate_id		
		$client->index($params);
	}
	echo 'create index done!';
}


function search(){
	//Elastic search php client
	$client = Elasticsearch\ClientBuilder::create()->build();
	$params = array();
	$params['index'] = 'emp_index';
	$params['type'] = 'emp_type';
	$params['body']['query']['match']['fdStatus'] = '1';
	$params['body']['sort'] = array('fdAge'=>array('order'=>'desc'));
	$params['size'] = 3;  
   	$params['from'] = 1;  
	$rtn = $client->search($params);
	var_dump($rtn);
}


set_time_limit(0);
// create_index();
search();
?>


分享到:

扫描二维码推送至手机访问。

版权声明:本文由云河空间发布,如需转载请注明出处。

本文链接:https://yuyunhe.cn/index.php/post/264.html

分享给朋友:

“Cenots上elasticsearch安装与使用” 的相关文章

php登录函数login session+mysql

<?php // 为php和mysql剔除不安全html代码。 //http://blog.ddian.cn function safestrip($string){    $string = strip_tags(...

php 获取客户端的ip、地理信息、浏览器信息、本地真实ip

<?php  // 作用取得客户端的ip、地理信息、浏览器http://blog.qita.in  class get_gust_info {        ////获得访客浏...

phpcms v9更换模板的具体操作方法

phpcms v9更换模板的具体操作方法

这篇文章主要介绍了phpcms v9更换模板的具体操作方法,需要的朋友可以参考下分享一下Phpcms V9更换模板的具体操作方法先分享下大概的步骤:1、上传模版文件到服务器;2、在站点管理 里边【模板风格配置】选择新模板;3、设置不同模型对应模板;4、修改现有的栏目,匹配新模板;5、更新栏目缓存、系...

jQuery UI 使用入门

jQuery UI 使用入门

 最近项目中使用了一些插件来做页面,这里把jQuery UI的使用分享出来,希望 对新手有帮助。文章结尾附源码下载。1 jQuery UI        有时你仅仅是为了实现一个渐变的动画效果而不得不把javascrip 重新学习一遍然后书写大量代码。直到...

PHP利用Curl模拟登录并获取数据例子

PHP利用Curl模拟登录并获取数据例子

几乎所有的程序员来模仿用户登录或抓取数据都会使用到curl函数,下面我来给各位介绍利用curl函数实现登录并抓取数据,希望下面例子对各位有帮助。PHP的curl()在抓取网页的效率方面是比较高的,而且支持多线程,而file_get_contents()效率就要稍低些,当然,使用curl时需要开启下c...

php利用百度地图API进行IP定位和GPS定位

最 近在做一个手机端的webapp地图应用,而核心内容当然是定位了,但是定位的话有几种方式,IP定位,GPS定位,基站定位(这个貌似webapp用不 了), 那么剩下核心的gps定位和ip定位了,我们知道,html5有定位API,但是该API拿到的GPS数据是硬件坐标,无法直接显示在地图上。...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。