IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Spark Core:Apache日志分析 -> 正文阅读

[大数据]Spark Core:Apache日志分析

Spark Core:Apache日志分析

1、实验描述

  • 根据实际业务需求使用spark 完成对Apache格式的日志内容的分析。
  • 实验时长:
    • 45分钟
  • 主要步骤:
    • 启动spark-shell
    • 自定义日志过滤函数
    • 日志预处理
    • 统计关于日志的相关指标
    • 统计结果展示或保存到本地

2、实验环境

  • 虚拟机数量:1
  • 系统版本:Centos 7.5
  • Scala版本:2.11.0
  • Spark版本: Apache spark-2.1.1

3、相关技能

  • Spark 常用算子
  • apache日志的格式
  • RDD 常见的操作

4、知识点

  • 使用Scala 开发spark 应用
  • 常见的日志格式
  • Spark 日志分析的基本方式

5、实现效果

统计不同页面的访问操作效果如下图:

img

6、实验步骤

6.1打开终端,启动spark-shell。

6.1.1启动spark-shell,启动时指定启动模式

[zkpk@master ~]$cd [zkpk@master ~]$ cd spark-2.1.1-bin-hadoop2.7/[zkpk@master spark-2.1.1-bin-hadoop2.7]$ bin/spark-shell  --master local[2]

6.2加载本地文件,使用textFile方法加载本地数据

scala> val logFile = "/home/zkpk/experiment/04/access.log"scala> val logRDD = sc.textFile(logFile)

image-20211124210110453

6.3Apache 日志的一般格式:

6.3.1日志内容从左到右依次是:远程IP地址,客户端记录,浏览者记录,

6.3.2请求的时间,包括三项内容:,日期,时间,时区,服务器收到的请求,包括三项内容:

6.3.2.1METHOD:请求的方法,GET/POST等

6.3.2.2RESOURCE:请求的目标链接地址

6.3.2.3PROTOCOL:HTTP版本号

6.3.3状态代码,表示请求是否成功

6.3.4发送的字节数

6.3.5发出请求时所在的URL

6.3.6客户端的详细信息:操作系统及浏览器等

6.4数据预处理:获取合法的日志数据,使用正则表达式做两件事情,一个是过滤掉非法的日志,一个是解析过滤后的日志来获得需要的数据元组。

6.4.1过滤无法解析的日志记录

val LogPatterns= """^(\S+) (\S+) (\S+) \[([\w/]+)([\w:/]+)\s([+\-]\d{4})\] "(\S+) (\S+) (\S+)" (\d{3}) (\d+)""".rdef filterWithparse(s: String) = {LogPatterns.findFirstIn(s) match {case Some(LogPatterns (_*)) => truecase _ => false}}

image-20211124210135045

6.4.2定义解析日志的函数:在Scala命令行键入如下内容,解析日志记录,得到需要的元组

def parseLog(s: String) = {val m = LogPatterns.findAllIn(s)if(m.hasNext){val clientIP = m.group(1).toString  val requestDate = m.group(4).toString val requestURL = m.group(8).toString val status = m.group(10).toString (clientIP, requestDate, requestURL, status) } else { ("null", "null", "null", "null")}}

image-20211124210146646

6.4.3解析日志文件

scala >val tmp = logRDD.filter(filterWithparse)scala > val logRDDv1 = sc.parallelize(tmp.take(tmp.count().toInt).map(parseLog))

image-20211124210215489

6.4.4统计每日PV,使用count操作

scala > logRDDv1.count

image-20211124210235469

6.4.5使用sortByKey,按照请求日期字段进行排序,并将结果保存到本地

scala > val logRDDv2 = logRDDv1.map(x => (x._2, 1)).reduceByKey(_ + _)//元组中的元素的访问通过下划线点下标访问(下标从1开始计)scala> logRDDv2.sortByKey().coalesce(1).saveAsTextFile("/tmp/log_date")

image-20211124210255700

6.4.5.1查看结果:

[zkpk@master ~]$more /tmp/log_date/part-00000

img

6.4.6统计独立IP数

scala > val logRDDv3 = logRDDv1.map(x => (x._2, x._1))scala>val logRDDv4=logRDDv3.distinct()scala> val logRDDv5 = logRDDv4.map(x => (x._1, 1)).reduceByKey(_ + _)scala> val distinct_ip = logRDDv5.collect()

image-20211124210338325

6.5统计每种不同的HTTP状态对应的访问次数,并且以降序展示

scala >val logRDDv6 = logRDDv1.map(x => (x._4, 1)).reduceByKey(_ + _)scala > val StatusPV = logRDDv6.sortByKey().collect()

image-20211124210352872

6.6统计不同独立IP的访问量,按照降序排列并展示前10条

scala> val logRDDv7 = logRDDv1.map(x => (x._1, 1)).reduceByKey(_ + _)scala> val disinctIP_count = logRDDv7.sortBy(x=>x._2, false).take(10)

image-20211124210411082

6.7统计不同页面的访问量

scala> val logRDDv8 = logRDDv1.map(x => (x._3, 1)).reduceByKey(_ + _)scala> val distinct_PV = logRDDv8.sortBy(x=>x._2, false).take(10).foreach(println)

image-20211124210435235

6.7.1由于日志中有大量的js文件的访问,因此我们增加一个去除列表,过滤掉属于列表中后缀名的文件

val stopList = List("jpg", "ico", "png", "gif", "css", "txt", "asp")def filterWithStop(s: String): Boolean = {for(c <- stopList){if(s.endsWith("."+c)){false}}true}val logRDDv9 = logRDDv1.filter(x => filterWithStop(x._3))

6.7.2再对过滤后的logRDDv9执行统计操作

scala> logRDDv9.map(x=>(x._3, 1)).reduceByKey(_+_).sortByKey().foreach(println)

image-20211124210544369

7、总结

本次实验,通过使用Spark统计分析apache格式的日志文件,达到熟练掌握spark相关算子的目的

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-11-26 08:55:06  更:2021-11-26 08:55:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 15:49:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码