安装

Hadoop安装: http://www.powerxing.com/install-hadoop/ 
Hadoop集群配置: http://www.powerxing.com/install-hadoop-cluster/ 
Hive安装: https://chu888chu888.gitbooks.io/hadoopstudy/content/Content/8/chapter0807.html

安装具体教程请看上面链接,本地测试只用了单机配置,集群配置(后面的flume用到)看上面的详细链接, 因为之前没有接触过java的相关,这里说下遇到的几个问题.

HadoopHive的1.x和2.x版本要对应 
JAVA/Hadoop相关的环境变量配置,习惯了PHP的童鞋在这块可能容易忽略 
启动Hadoop提示Starting namenodes on [],namenodes为空,是因为没有指定ip或端口,修改hadoop/core-site.xml如下

  1. <configuration>
  2. <property>
  3. <name>dfs.namenode.rpc-address</name>
  4. <value>127.0.0.0:9001</value>
  5. </property>
  6. </configuration>

安装完成后输入jps可以查看到NameNode,DataNode等

 

上报和接收

swoole和workerman都有简单版本实现的数据监控,包括上报,接收,存储,展示, 主要使用udp上传(swoole版本已升级为tcp长连接),redis缓存,文件持久化,highcharts展示,可以作为思路参考 
swoole-statistics : https://github.com/smalleyes/statistics 
workerman-statistics : https://github.com/walkor/workerman-statistics 
本例使用swoole提供的接口实现UDP传输,因为上报数据是一定程度可以容错,所以选择UDP效率优先 
接收数据临时存储在Redis中,每隔几分钟刷到文件中存储,文件名按模块和时间分割存储,字段|分割(后面与hive对应)

 

数据转存

创建Hive数据表

根据文件数据格式编写Hive数据表, TERMINATED BY字段与前面文件字段分隔符想对应 
对表按日期分区PARTITIONED BY

  1. CREATE TABLE login (
  2. time int comment '登陆时间',
  3. type string comment '类型,email,username,qq等',
  4. device string comment '登陆设备,pc,android,ios',
  5. ip string comment '登陆ip',
  6. uid int comment '用户id',
  7. is_old int comment '是否老用户'
  8. )
  9. PARTITIONED BY (
  10. `date` string COMMENT 'date'
  11. )
  12. ROW FORMAT DELIMITED FIELDS TERMINATED BY '|';

定时(Crontab)创建hadoop分区

  1. hive -e "use web_stat; alter table login add if not exists partition (date='${web_stat_day}')"

转存

Flume监听文件目录,将数据传输到能访问Hdfs集群的服务器上,这里传输到了224机器的7000端口

  1. #agent3表示代理名称 login
  2. agent3.sources=source1
  3. agent3.sinks=sink1
  4. agent3.channels=channel1
  5. 配置source1

配置source1

  1. agent3.sources.source1.type=spooldir
  2. agent3.sources.source1.spoolDir=/data/releases/stat/Data/10001/
  3. agent3.sources.source1.channels=channel1
  4. agent3.sources.source1.fileHeader = false

配置sink1

  1. agent3.sinks.sink1.type=avro
  2. agent3.sinks.sink1.hostname=192.168.23.224
  3. agent3.sinks.sink1.port=7000
  4. agent3.sinks.sink1.channel=channel1

配置channel1

  1. agent3.channels.channel1.type=file
  2. agent3.channels.channel1.checkpointDir=/data/flume_data/checkpoint_login
  3. agent3.channels.channel1.dataDirs=/data/flume_data/channelData_login

启动flume

加到supervisor守护进程

  1. /home/flume/bin/flume-ng agent -n agent3 -c /home/flume/conf/ -f /home/flume/conf/statistics/login_flume.conf -Dflume.root.logger=info,console

224机器监听7000端口,将数据写到hdfs集群

agent1表示代理名称

  1. agent4.sources=source1
  2. agent4.sinks=sink1
  3. agent4.channels=channel1

配置source1

  1. agent4.sources.source1.type=avro
  2. agent4.sources.source1.bind=192.168.23.224
  3. agent4.sources.source1.port=7000
  4. agent4.sources.source1.channels=channel1

配置sink1

  1. agent4.sinks.sink1.type=hdfs
  2. agent4.sinks.sink1.hdfs.path=hdfs://hdfs/umr-ubvzlf/uhiveubnhq5/warehouse/web_stat.db/login/date\=%Y-%m-%d
  3. agent4.sinks.sink1.hdfs.fileType=DataStream
  4. agent4.sinks.sink1.hdfs.filePrefix=buffer_census_
  5. agent4.sinks.sink1.hdfs.writeFormat=TEXT
  6. agent4.sinks.sink1.hdfs.rollInterval=30
  7. agent4.sinks.sink1.hdfs.inUsePrefix = .
  8. agent4.sinks.sink1.hdfs.rollSize=536870912
  9. agent4.sinks.sink1.hdfs.useLocalTimeStamp = true
  10. agent4.sinks.sink1.hdfs.rollCount=0
  11. agent4.sinks.sink1.channel=channel1

配置channel1

  1. agent4.channels.channel1.type=file
  2. agent4.channels.channel1.checkpointDir=/data/flume_data/login_checkpoint
  3. agent4.channels.channel1.dataDirs=/data/flume_data/login_channelData

启动

加到supervisor守护进程

  1. /usr/local/flume/bin/flume-ng agent -n agent4 -c /usr/local/flume/conf/ -f /usr/local/flume/conf/statistics/login_flume.conf -Dflume.root.logger=info,console

清洗数据

通过Thrift的PHP扩展包调用Hive,编写类SQL的HQL转换为MapReduce任务读取计算HDFS里的数据, 将结果存储在MySQL中 
php-thrift-client下载地址: https://github.com/garamon/php-thrift-hive-client

  1. define('THRIFT_HIVE' , ROOT .'/libs/thrift');
  2. $GLOBALS['THRIFT_ROOT'] = THRIFT_HIVE . '/lib';
  3. require_once $GLOBALS['THRIFT_ROOT'] . '/packages/hive_service/ThriftHive.php';
  4. require_once $GLOBALS['THRIFT_ROOT'] . '/transport/TSocket.php';
  5. require_once $GLOBALS['THRIFT_ROOT'] . '/protocol/TBinaryProtocol.php';
  6. require_once THRIFT_HIVE . '/ThriftHiveClientEx.php';
  7. $transport = new \TSocket('127.0.0.1', 10000);
  8. $transport->setSendTimeout(600 * 1000);
  9. $transport->setRecvTimeout(600 * 1000);
  10. $this->client = new \ThriftHiveClientEx(new \TBinaryProtocol($transport));
  11. $this->client->open();
  12. $this->client->execute("show databases");
  13. $result = $this->client->fetchAll();
  14. var_dump($result);
  15. $this->client->close();

HQL语法说明: https://chu888chu888.gitbooks.io/hadoopstudy/content/Content/8/chapter0803.html

注意的是,尽量要将HQL语句能转换为MapReduce任务,不然没利用上Hadoop的大数据计算分析,就没意义 
例如下面的逻辑,取出来在内存里分析,这样的逻辑尽量避免,因为sql在hive里执行就是普普通通的数据,没有转换为mapreduce

  1. select * from login limit 5;
  2. // php处理
  3. $count = 0;
  4. foreach ($queryResult as $row) {
  5. $count ++;
  6. }

一次性转换为MapReduce,利用Hadoop的计算能力

  1. select type,count(*) from login group by type; // 这样就用到了

建表使用了PARTITIONED BY分区断言后,查询就可以利用分区剪枝(input pruning)的特性,但是断言字段必须离where关键字最近才能被利用上 
// 如前面的login表使用到了date分区断言,这里就得把date条件放在第一位

  1. select count(*) from login where date='2016-08-23' and is_old=1;

Hive中不支持等值连表,如下

  1. select * from dual a,dual b where a.key = b.key;

应写为:

  1. select * from dual a join dual b on a.key = b.key;

Hive中不支持insert,而且逻辑上也不允许,应为hadoop是我们用来做大数据分析,而不应该作为业务细分数据

 

数据报表展示

这一步就简单了,读取MySQL数据,使用highcharts等工具做各种展示,也可以用crontab定时执行php脚本发送日报,周报等等

 

后续更新

最近看一些资料和别人沟通发现,清洗数据这一步完全不用php,可以专注于HQL实现清洗逻辑,将结果保存在hadoop中,再用Sqoop将hadoop数据和MySQL数据同步。即简化了流程,免去mysql手工插入,又做到了数据更实时,为二次清洗逻辑的连表HQL做了铺垫

PHP+Hadoop+Hive+Thrift+Mysql实现数据统计分析的更多相关文章

  1. hive向mysql导入数据sqoop命令出错

    报错信息: java.lang.Exception: java.io.IOException: java.lang.ClassNotFoundException: info at org.apache ...

  2. Spark+Hadoop+Hive集群上数据操作记录

    [rc@vq18ptkh01 ~]$ hadoop fs -ls / drwxr-xr-x+ - jc_rc supergroup 0 2016-11-03 11:46 /dt [rc@vq18ptk ...

  3. PHP+Hadoop实现数据统计分析

    记一次完全独立完成的统计分析系统的搭建过程,主要用到了PHP+Hadoop+Hive+Thrift+Mysql实现 安装 Hadoop安装: http://www.powerxing.com/inst ...

  4. Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql、oracle...)间进行数据的传递

    http://niuzhenxin.iteye.com/blog/1706203   Sqoop是一款开源的工具,主要用于在HADOOP(Hive)与传统的数据库(mysql.postgresql.. ...

  5. Hadoop Hive与Hbase整合+thrift

    Hadoop Hive与Hbase整合+thrift 1.  简介 Hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供完整的sql查询功能,可以将sql语句 ...

  6. Centos搭建mysql/Hadoop/Hive/Hbase/Sqoop/Pig

    目录: 准备工作 Centos安装 mysql Centos安装Hadoop Centos安装hive JDBC远程连接Hive Hbase和hive整合 Centos安装Hbase 准备工作: 配置 ...

  7. 使用Sqoop从MySQL导入数据到Hive和HBase 及近期感悟

    使用Sqoop从MySQL导入数据到Hive和HBase 及近期感悟 Sqoop 大数据 Hive HBase ETL 使用Sqoop从MySQL导入数据到Hive和HBase 及近期感悟 基础环境 ...

  8. 大数据学习系列之四 ----- Hadoop+Hive环境搭建图文详解(单机)

    引言 在大数据学习系列之一 ----- Hadoop环境搭建(单机) 成功的搭建了Hadoop的环境,在大数据学习系列之二 ----- HBase环境搭建(单机)成功搭建了HBase的环境以及相关使用 ...

  9. 使用sqoop从mysql导入数据到hive

      目录 前言 一.使用的导入命令 二.遇到的问题及解决 1. 用文本字段进行分区的问题 2. Hadoop历史服务器Hadoop JobHistory没开启的问题 3. 连接元数据存储数据库报错 4 ...

随机推荐

  1. EWS 流通知订阅邮件

    摘要 查找一些关于流通知订阅邮件的资料,这里整理一下. 核心代码块 using System; using System.Collections.Generic; using System.Linq; ...

  2. sqlserver 删除表中数据 id 从1开始

    TRUNCATE  TABLE  TbName   --TbName是表名 但如果TbName中某些字段与其它表有主外键关系,会报错: 无法截断表 'Plants',因为该表正由 FOREIGN KE ...

  3. PHP语法-该注意的细节

    php in_array(mixed $needle, array $haystack[, bool $strict = FALSE] ) 注意: 一.如果$needle 是字符串,则比较是区分大小写 ...

  4. 【Tomcat】部署Web到tomcat的四种方式

    一.静态部署 1.直接将web项目文件件拷贝到webapps 目录中     Tomcat的Webapps目录是Tomcat默认的应用目录,当服务器启动时,会加载所有这个目录下的应用.所以可以将JSP ...

  5. python学习之老男孩python全栈第九期_day009知识点总结

    '''# len# 计算字符串的长度# s = '金老板小护士'# len(s)# 不能用 len 怎么办#low一点的方法# count = 0# for i in s:# count += 1# ...

  6. js-JavaScript实现数字的千位分隔符

    function thousandSeparator(num) { return num && (num .toString().indexOf('.') != -1 ? num.to ...

  7. springboot No Java compiler available for configuration options compilerClassName: [null] and compil

    今天使用eclipse创建springboot整合jsp出现一个问题,在idea中并没有遇到这个问题.最后发现是需要在eclipse中添加一个eclipse依赖,依赖如下: <dependenc ...

  8. SQLServer 学习笔记之超详细基础SQL语句 Part 11

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...

  9. ngnix https

    server {            listen       80;#端口号        server_name  www.xxxx.net;#本机                charset ...

  10. 微信小程序开发--模板(template)使用,数据加载,点击交互

    微信小程序视图层提供了 模板(template),可以在模板中定义代码片段,然后在不同的地方调用.结果在数据渲染那懵逼了.按照官网上对模板的说明和对数据的加载. 1.定义模板 使用name属性,作为模 ...