当前位置:   article > 正文

【离线数仓】Day01-用户行为数据采集:数仓概念、需求及架构、数据生成及采集、linux命令及其他组件常见知识...

离线数仓用到的组件

 一、数据仓库概念

二、项目需求及架构设计

1、需求分析

 

 2、项目框架

 3、框架版本选型

服务器选型:云主机

服务器规划

三、数据生成模块

1、数据基本格式

公共字段:所有手机都包含

业务字段:埋点上报的字段,有具体的业务类型

  1. "et": [ //事件
  2. {
  3. "ett": "1506047605364", //客户端事件产生时间
  4. "en": "display", //事件名称
  5. "kv": { //事件结果,以key-value形式自行定义
  6. "goodsid": "236",
  7. "action": "1",
  8. "extend1": "1",
  9. "place": "2",
  10. "category": "75"
  11. }
  12. }
  13. ]
  14. }

2、事件日志数据

3、启动日志数据

标签

含义

entry

入口: push=1,widget=2,icon=3,notification=4, lockscreen_widget =5

open_ad_type

开屏广告类型:  开屏原生广告=1, 开屏插屏广告=2

action

状态:成功=1  失败=2

loading_time

加载时长:计算下拉开始到接口返回数据的时间,(开始加载报0,加载成功或加载失败才上报时间)

detail

失败码(没有则上报空)

extend1

失败的message(没有则上报空)

en

日志类型start

  1. {
  2.     "action":"1",
  3.     "ar":"MX",
  4.     "ba":"HTC",
  5.     "detail":"",
  6.     "en":"start",
  7.     "entry":"2",
  8.     "extend1":"",
  9.     "g":"43R2SEQX@gmail.com",
  10.     "hw":"640*960",
  11.     "l":"en",
  12.     "la":"20.4",
  13.     "ln":"-99.3",
  14.     "loading_time":"2",
  15.     "md":"HTC-2",
  16.     "mid":"995",
  17.     "nw":"4G",
  18.     "open_ad_type":"2",
  19.     "os":"8.1.2",
  20.     "sr":"B",
  21.     "sv":"V2.0.6",
  22.     "t":"1561472502444",
  23.     "uid":"995",
  24.     "vc":"10",
  25.     "vn":"1.3.4"
  26. }

4、数据生成脚本

 创建公共字段bean、启动日志bean和一系列操作的bean

Logback主要用于在磁盘和控制台打印日志。

resources文件夹下创建logback.xml文件

将编写好的项目打成jar包

四、数据采集模块

 1、Hadoop安装

hdfs和yarn的集群规划

 

服务器hadoop102

服务器hadoop103

服务器hadoop104

HDFS

NameNode

DataNode

DataNode

DataNode

SecondaryNameNode

Yarn

NodeManager

Resourcemanager

NodeManager

NodeManager

DataNode进行磁盘扩展,hdfs-site.xml文件中配置多目录

支持LZO压缩配置,使用twitter提供的hadoop-lzo开源组件

core-site.xml中配置并xsync

启动、测试、建立索引

  1. [atguigu@hadoop102 hadoop-2.7.2]$ sbin/start-dfs.sh
  2. [atguigu@hadoop103 hadoop-2.7.2]$ sbin/start-yarn.sh
  3. yarn jar share/hadoop/mapreduce/hadoop-mapreduce-examples-2.7.2.jar wordcount -Dmapreduce.output.fileoutputformat.compress=true -Dmapreduce.output.fileoutputformat.compress.codec=com.hadoop.compression.lzo.LzopCodec /input /output
  4. hadoop jar ./share/hadoop/common/hadoop-lzo-0.4.20.jar com.hadoop.compression.lzo.DistributedLzoIndexer /output

基准测试与参数调优

hadoop jar /opt/module/hadoop-2.7.2/share/hadoop/mapreduce/hadoop-mapreduce-client-jobclient-2.7.2-tests.jar TestDFSIO -write -nrFiles 10 -fileSize 128MB

hdfs和yarn调优

2、Zookeeper安装

编写群起脚本

配置系统环境变量source  /etc/profile与特定用户环境变量~/.bashrc文件

3、日志生成

日志启动参数:

  1. // 参数一:控制发送每条的延时时间,默认是0
  2. Long delay = args.length > 0 ? Long.parseLong(args[0]) : 0L;
  3. // 参数二:循环遍历次数
  4. int loop_len = args.length > 1 ? Integer.parseInt(args[1]) : 1000;

上传执行生成

[atguigu@hadoop102 module]$ java -classpath log-collector-1.0-SNAPSHOT-jar-with-dependencies.jar com.atguigu.appclient.AppMain  >/opt/module/test.log

生成启动脚本

  1. #! /bin/bash
  2. for i in hadoop102 hadoop103
  3. do
  4. ssh $i "java -classpath /opt/module/gmall/logcollector-1.0-SNAPSHOT-jar-with-dependencies.jar com.atguigu.appclient.AppMain $1 $2 > /opt/module/test.log &"
  5. done

时间同步修改脚本:sudo date -s $1

进程查看脚本:ssh $i "$*"

4、采集日志flume

 

服务器hadoop102

服务器hadoop103

服务器hadoop104

Flume(采集日志)

Flume

Flume

 

组件:source、channel

ETL和分类型拦截器

ETL拦截器主要用于,过滤时间戳不合法和Json数据不完整的日志
日志类型区分拦截器主要用于,将启动日志和事件日志区分开来,方便发往Kafka的不同Topic。

  1. public class LogTypeInterceptor implements Interceptor {
  2. @Override
  3. public void initialize() {
  4. }
  5. @Override
  6. public Event intercept(Event event)

分发至lib目录

编写日志采集flume启动停止脚本

  1. #! /bin/bash
  2. case $1 in
  3. "start"){
  4. for i in hadoop102 hadoop103
  5. do
  6. echo " --------启动 $i 采集flume-------"
  7. ssh $i "nohup /opt/module/flume/bin/flume-ng agent --conf-file /opt/module/flume/conf/file-flume-kafka.conf --name a1 -Dflume.root.logger=INFO,LOGFILE > /dev/null 2>&1 &"
  8. done
  9. };;
  10. "stop"){
  11. for i in hadoop102 hadoop103
  12. do
  13. echo " --------停止 $i 采集flume-------"
  14. ssh $i "ps -ef | grep file-flume-kafka | grep -v grep |awk '{print \$2}' | xargs kill"
  15. done
  16. };;
  17. esac

5、kafka安装

压力测试:

kafka-consumer-perf-test.sh
kafka-producer-perf-test.sh

[atguigu@hadoop102 kafka]$ bin/kafka-producer-perf-test.sh  --topic test --record-size 100 --num-records 100000 --throughput 1000 --producer-props bootstrap.servers=hadoop102:9092,hadoop103:9092,hadoop104:9092

Kafka机器数量(经验公式)=2*(峰值生产速度*副本数/100)+1

6、消费Kafka数据Flume

 

服务器hadoop102

服务器hadoop103

服务器hadoop104

Flume(消费Kafka)

Flume

五、总结

1、数据采集模块

Linux&Shell相关总结

序号

命令

命令解释

1

top

查看内存

2

df -h

查看磁盘存储情况

3

iotop

查看磁盘IO读写(yum install iotop安装)

4

iotop -o

直接查看比较高的磁盘读写程序

5

netstat -tunlp | grep 端口号

查看端口占用情况

6

uptime

查看报告系统运行时长及平均负载

7

ps  aux

查看进程

shell工具:awk、sed、cut、sort

2、zookeeper总结

1)选举机制
半数机制
2)常用命令
ls、get、create

3、Hadoop总结

1)Hadoop默认不支持LZO压缩,如果需要支持LZO压缩,需要添加jar包,并在hadoop的cores-site.xml文件中添加相关压缩配置。(建表时候安装)
2)Hadoop常用端口号
3)Hadoop配置文件以及简单的Hadoop集群搭建
4)HDFS读流程和写流程
5)MapReduce的Shuffle过程及Hadoop优化(包括:压缩、小文件、集群优化)
6)Yarn的Job提交流程
7)Yarn的默认调度器、调度器分类、以及他们之间的区别
8)HDFS存储多目录
9)Hadoop参数调优

4、kafka

Kafka幂等性
Kafka0.11版本引入了幂等性,幂等性配合at least once语义可以实现exactly once语义。但只能保证单次会话的幂等。

Kafka分区分配
Range和RoundRobin

Kafka的ISR副本同步队列
ISR(In-Sync Replicas),副本同步队列。ISR中包括Leader和Follower。如果Leader进程挂掉,会在ISR队列中选择一个服务作为新的Leader。有replica.lag.max.messages(延迟条数)和replica.lag.time.max.ms(延迟时间)两个参数决定一台服务是否可以加入ISR副本队列,在0.10版本移除了replica.lag.max.messages参数,防止服务频繁的进去队列。
任意一个维度超过阈值都会把Follower剔除出ISR,存入OSR(Outof-Sync Replicas)列表,新加入的Follower也会先存放在OSR中。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/592019
推荐阅读
相关标签
  

闽ICP备14008679号