Elasticsearch + php + msyql+nginx安装流程

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介:

sudo yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-develglib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devele krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers

#nginx所需要的库文件件

sudo yum -y install pcre-deve l zlib-deve l gd gd-deve l freetype net-tools
yum -y install pcre*

#PHP依赖的库文件
sudo yum -y install gd-devel libjpeg-devel libpng-devel freetype-devel libxml2-devel curl-devel

yum -y install mysql mysql-devel //尽可能用源码编译安装
yum -y install mysql-server //尽可能用源码编译安装
mysql -uroot -p #登陆方式

3.登录MySQL修改密码
mysql -uroot -S /opt/mysql/3306/mysql.sock
mysql> flush privileges;
mysql> set password for root@'localhost'= password('miaohr1qaz');

4.登录数据库给multi用户添加权限
mysql -uroot -S /opt/mysql/3306/mysql.sock -pmiaohr1qaz
mysql> GRANT SHUTDOWN ON *.* TO 'multi'@'localhost' IDENTIFIED BY 'multi';


5.设置root远程访问
mysql> UPDATE mysql.user SET Host='%' WHERE Host='localhost';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';
mysql> FLUSH PRIVILEGES; 


nginx 安装

./configure --prefix=/usr/nginx

make
make install

 

匹配nginx.conf开启
location ~ \.php{  root html;  fastcgi_pass 127.0.0.1:9000  fastcgi_index index.php  fastcgi_param SCRIPT_FILENAME /usr/nginx/html{  root html;  fastcgi_pass 127.0.0.1:9000  fastcgi_index index.php  fastcgi_param SCRIPT_FILENAME /usr/nginx/htmlfastcgi_script_name;
include fastcgi_params; 
}


启动nginx 
/usr/nginx/sbin/nginx 
重启
/usr/nginx/sbin/nginx -s reload

 


php安装方法

mysql_config 没有的话是因为没有安装mysql-devel
(mysql_config 是一个绿色的可执行文件)

./configure --prefix=/data/local/php \
--enable-fpm \
--with-zlib \
--enable-mbstring \
--with-openssl \
--with-mysqli \
--enable-mysqlnd \
--with-mysql-sock \
--with-gd \
--enable-gd-native-ttf \
--enable-pdo \
--with-pdo-mysql \
--with-gettext \
--with-curl \
--enable-sockets \
--enable-bcmath \
--enable-xml \
--with-bz2 \
--enable-zip \
-enable-pcntl

make
make install

从php的解压包里
cp php.ini-development /usr/php/lib/php.ini
在/usr/php/etc/里
cp /usr/php/etc/php-fpm.conf.default /usr/php/etc/php-fpm.conf

date.timezone = “Asia/Shanghai”
default_charset = "utf-8"

然后启动nginx,mysql 和/usr/php/sbin/php-fpm

ps aux | grep -c php-fpm 查看状态

 

 

服务器1
cluster.name: ejiqun
node.name: node1
node.rack: r1 #机架号 最好不同
path.data: /elastic_data/data 
 path.logs: /elastic_data/logs
network.host: 192.168.1.210
http.port: 9200
transport.tcp.port: 9300 #设置节点之间交互的端口号
discovery.zen.ping.timeout: 120s #设置集群中自动发现其他节点时ping连接的超时时间
discovery.zen.ping.multicast.enabled: true #设置是否打开多播发现节点
discovery.zen.ping.unicast.hosts: ["192.168.1.210:9300", "192.168.1.211:9300"]

服务器2
cluster.name: ejiqun
node.name: node2
node.rack: r2 #机架号 最好不同
path.data: /elastic_data/data 
 path.logs: /elastic_data/logs
network.host: 192.168.1.211
http.port: 9200
transport.tcp.port: 9300 #设置节点之间交互的端口号
discovery.zen.ping.timeout: 120s #设置集群中自动发现其他节点时ping连接的超时时间
discovery.zen.ping.multicast.enabled: true #设置是否打开多播发现节点
discovery.zen.ping.unicast.hosts: ["192.168.1.210:9300", "192.168.1.211:9300"]

安装jdk
去http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html中下载jdk的安装文件。由于我的Linux是32位的,因此我下载jdk-8u25-linux-i586.tar.gz文件。
新建/usr/java文件夹,将jdk-8u25-linux-i586.tar.gz放到该文件夹中,并将工作目录切换到/usr/java目录下。
执行命令tar -zxvf jdk-8u25-linux-i586.gz 进行解压,解压后发现/usr/java多了一个jdk1.8.0_25文件夹。
通过以上步骤,jdk就已经全部安装完成了。下面,就是环境变量的配置。
配置环境变量
使用vim /etc/profile编辑profile文件
在/etc/profile底部加入如下内容
JAVA_HOME=/usr/java/jdk1.8.0_25
PATH=JAVAHOME/bin:PATH
CLASSPATH=JAVAHOME/jre/lib/ext:JAVA_HOME/lib/tools.jar
export PATH JAVA_HOME CLASSPATH

以上,环境变量配置完成。需要注意的是,PATH在配置的时候,一定要把JAVAHOME/bin使javajavajavaJAVA_HOME/bin下,而在其它目录下,会造成很大的问题。
还要注意,以前其它教程写的CLASSPATH=JAVAHOME/lib.tools.jarjar使source/etc/profileprofile使javaccommandnotfound使javaversionjavaversion"1.8.025"echoJAVA_HOME, echo CLASSPATH,echoPATH,看看自己的配置是否都正确。


elasticsearch-jdbc使用
第一步:环境匹配
1)elasticsearch 2.3.3 成功安装部署 
2)mysql安装成功,增删改查无误~~。 

3)要保证elasticsearch-jdbc的版本要与elasticsearch的版本是一致的(下面的内容会提示下载)。否则会报错,无法进行之后的步骤。
(例如elasticsearch-jdbc-2.3.3.0-dist.zip(对应的你的elaseticsearh-2.3.3)
第二步:下载JDBC工具

选择你需要的版本进行下载。(例如elasticsearch-jdbc-2.3.3.0-dist.zip(对应的你的elaseticsearh-2.3.3) ,下载后缀为dist.zip的即可)
地址:
http://xbib.org/repository/org/xbib/elasticsearch/importer/elasticsearch-jdbc/
解压下载的文件unzip elasticsearch-jdbc-2.3.3.0-dist.zip
解压下载的文件unzip elasticsearch-jdbc-2.3.3.0-dist.zip

创建mysql脚本计划任务
cd /elasticsearch-jdbc-2.3.3.0/bin/ (在bin目录下建立我们的新脚本)
vi import_es.sh

#!/bin/sh
bin=/elasticsearch-jdbc-2.3.3.1/bin
lib=/elasticsearch-jdbc-2.3.3.1/lib
echo '{
"type" : "jdbc",
"jdbc": {
"elasticsearch.autodiscover":true,
"elasticsearch.cluster":"ejiqun",
"url":"jdbc:mysql://10.0.8.7:3306/bo",
"user":"caiyun",
"password":"bo2016.",
"sql":"select email from members",
"elasticsearch" : {
"host" : "192.168.48.129",
"port" : 9300
},
"index" : "test",
"type" : "ffcs"
}
}' | java \
-cp "lib/" Dlog4j.configurationFile={bin}/log4j2.xml \
org.xbib.tools.Runner \
org.xbib.tools.JDBCImporter

为 import_es.sh 添加可执行权限。 
chmod a+x import_es.sh //(a+x 是给所有人加上可执行权限,包括所有者,所属组,和其他人 o+x 只是给其他人加上可执行权限)
执行脚本:./import_es.sh

第五步:检测数据是否新增成功
curl 'localhost:9200/_cat/indices?pretty' //索引是否有新增呢??
curl -XGET 'http://localhost:9200/test/ffcs/_search?pretty' //抓取显示数据


通过各种条件查询
curl 'localhost:9200/test/ffcs/_search?pretty' -d '
{
"filter":{"term":{"name":"john"}}
}'

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
php-滨
+关注
目录
打赏
0
0
0
0
1
分享
相关文章
|
8天前
|
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
【02】客户端服务端C语言-go语言-web端PHP语言整合内容发布-优雅草网络设备监控系统-2月12日优雅草简化Centos stream8安装zabbix7教程-本搭建教程非docker搭建教程-优雅草solution
57 20
os-copilot安装与多项功能测评,帮助开发人员PHP环境排查问题
本文介绍了OS Copilot在ECS上 Alibaba Cloud Linux的安装与使用,并对其多项参数进行了功能测评。OS Copilot是为操作系统提供智能化辅助的工具,支持自动化任务、智能推荐、故障排查等功能。安装时需检查是否已安装(`rpm -q os-copilot`),若未安装则用`yum install os-copilot`命令安装,并配置AccessKey信息连接阿里云服务。通过测试不同参数命令,如`-t`参数,展示了其自动化执行和智能生成回答的能力,显著提升运维效率。
os-copilot安装与多项功能测评,帮助开发人员PHP环境排查问题
docker安装nginx,前端项目运行
通过上述步骤,你可以轻松地在Docker中部署Nginx并运行前端项目。这种方法不仅简化了部署流程,还确保了环境的一致性,提高了开发和运维的效率。确保按步骤操作,并根据项目的具体需求进行相应的配置调整。
129 25
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
1145 1
01 入门PHP就来我这-安装phpstudy
路老师的PHP入门教程,带你从零开始学习PHP。首先下载并安装phpStudy,接着配置域名和端口,最后创建并运行第一个PHP文件。内容详实,适合初学者。
82 3
01 入门PHP就来我这-安装phpstudy
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
111 5
|
4月前
|
PHP7 MongDB 安装与使用
10月更文挑战第19天
57 1
PHP7 MongDB 安装与使用
php性能监测模块XHProf安装与测试
【10月更文挑战第13天】php性能监测模块XHProf安装与测试
51 0
Mac os 安装 nginx 教程(success)
这篇文章是关于如何在Mac OS系统上使用Homebrew安装nginx及其依赖,并解决安装过程中可能出现的权限问题。
373 0
Mac os 安装 nginx 教程(success)
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。
这篇文章是关于Elasticsearch的学习指南,包括了解Elasticsearch、版本对应、安装运行Elasticsearch和Kibana、安装head插件和elasticsearch-ik分词器的步骤。
422 0
elasticsearch学习一:了解 ES,版本之间的对应。安装elasticsearch,kibana,head插件、elasticsearch-ik分词器。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等