大数据开发学习Day37

一、Linux

1. 批量统计当前目录下各类文件数量

bash 复制代码
ls -l | awk '{print $5,$9}' | sort | uniq -c

ls -l 列出文件详细属性

awk 截取文件大小与文件名

uniq -c 去重统计同类文件数目

实战用途:统计日志、数据文件数量,快速盘点 HDFS 本地缓存文件

2. 清空大日志文件不删文件(业务在线必备)

bash 复制代码
> /opt/hadoop/logs/hadoop-rm.log

直接清空内容,保留文件句柄,服务不用重启

禁止生产直接rm删运行中日志,极易导致进程异常

常用于 YARN、Spark 运行日志快速瘦身

3. HDFS 查看文件块存储位置

bash 复制代码
hdfs fsck /user/hive/dwd/order.db -files -blocks -locations

查看 HDFS 文件切块数量、副本数、存储节点

排查数据块损坏、副本丢失、存储不均衡问题

集群运维数据完整性巡检常用命令

二、SQL

表说明

dwd_user_login 用户登录表:user_id,login_time,login_ip,device_type,dt

dwd_sales_goods 商品销售表:goods_id,sale_num,sale_price,sale_time,shop_id

dwd_user_coupon 用户优惠券表:user_id,coupon_id,get_time,use_time,status

1. 统计每个用户最近 3 次登录时间

sql 复制代码
SELECT user_id,login_time,rn
FROM (
    SELECT 
        user_id,
        login_time,
        ROW_NUMBER() OVER(PARTITION BY user_id ORDER BY login_time DESC) rn
    FROM dwd_user_login
) t
WHERE rn <= 3;

按用户分组,登录时间倒序排序

行号越小代表登录时间越近

筛选行号≤3,取出最近三次登录记录

用途:用户行为溯源、异常登录风险排查

2. 计算店铺商品销售额与客单价

sql 复制代码
SELECT
    shop_id,
    SUM(sale_num * sale_price) total_sale,
    AVG(sale_price) avg_price
FROM dwd_sales_goods
GROUP BY shop_id
ORDER BY total_sale DESC;

单商品销售额 = 销量 * 单价

聚合求和得到店铺总销售额

AVG 求平均售价即店铺客单价

电商店铺营收排行、经营分析核心 SQL

3. 统计领取未使用、已使用、过期优惠券数量

sql 复制代码
SELECT
    COUNT(CASE WHEN status=1 THEN coupon_id END) get_not_use,
    COUNT(CASE WHEN status=2 THEN coupon_id END) used_coupon,
    COUNT(CASE WHEN status=3 THEN coupon_id END) expire_coupon
FROM dwd_user_coupon
WHERE dt BETWEEN '2026-05-01' AND '2026-05-20';

status=1 已领取未使用;2 已使用;3 已过期

用CASE WHEN行转列分类统计

限定时间范围分区过滤,提升查询效率

营销活动优惠券核销数据分析专用

三、Pyspark

今日重点:PySpark 广播变量实战 + 大表小表 JOIN 最优方案

  • 适用场景
    一张超大业务表 + 一张小维度配置表关联
    维度表数据量小(字典表、地区表、品类映射表)
    直接 JOIN 产生大量 Shuffle,任务运行缓慢
  • 核心原理
    把小维度表广播分发到所有 Executor 节点
    每个计算节点本地持有全量小表数据,无需跨节点拉取数据
    彻底消除 Shuffle,极速完成关联
  • 完整可运行代码 + 注释
python 复制代码
from pyspark.sql import SparkSession
from pyspark.sql.functions import broadcast

spark = SparkSession.builder.appName("BroadcastJoin").getOrCreate()

# 1. 读取超大用户行为明细表
big_behavior_df = spark.read.parquet("/user/hive/dwd/user_behavior")

# 2. 读取极小维度映射表(地区编码-地区名称)
small_area_df = spark.read.csv("/data/area_code_map.csv",header=True)

# 3. 广播小表进行关联(企业标准写法)
result_df = big_behavior_df.join(
    broadcast(small_area_df),
    big_behavior_df.area_code == small_area_df.area_code,
    how="left"
)

result_df.show()
spark.stop()
  • 详细优势

    零 Shuffle 过程,执行速度提升数倍

    极大减少集群磁盘 IO 与网络传输

    维度表更新直接替换文件即可,业务无感知

    数仓分层 DWD 层关联维度表标配写法

  • 使用禁忌 & 避坑

    禁止广播大表,会造成 Executor 内存爆满 OOM

    默认广播阈值:10MB 以内自动广播,可手动调整

    多张小表关联,全部统一加broadcast()包裹

python 复制代码
spark.conf.set("spark.sql.autoBroadcastJoinThreshold",20971520)
  • 面试必背
    大表 JOIN 小表 → 广播 Join(最优)
    大表 JOIN 大表 → 优化分区 + 调整 Shuffle 并行度
    倾斜大表 JOIN → 加盐打散 + 广播组合使用

四、算法

这里是引用

有效的括号

python 复制代码
def isValid(s: str) -> bool:
    stack = []
    dic = {')':'(',']':'[','}':'{'}
    for char in s:
        if char in dic.values():
            stack.append(char)
        else:
            if not stack or stack.pop() != dic[char]:
                return False
    return len(stack) == 0

思路精讲

利用栈先进后出特性匹配括号

字典存储右括号对应左括号映射关系

遍历字符,左括号入栈

遇到右括号弹出栈顶比对,不一致直接判定无效

遍历结束栈为空代表全部匹配完成
大数据实战用途

日志 JSON 字符串格式校验

复杂嵌套字段数据合法性校验

数据清洗规则校验高频栈思想

相关推荐
zxd0203115 小时前
Zabbix7 监控系统学习总结
学习
z200509305 小时前
【linux学习】在linux下使用git提交到gitee
git·学习·gitee
叶~小兮5 小时前
Zabbix 7.0学习笔记
笔记·学习·zabbix
浪子sunny5 小时前
2026股票实时行情数据Skills技能分享
大数据·人工智能·python
一条泥憨鱼5 小时前
【Java 进阶】LinkedHashMap 与 TreeMap
java·开发语言·数据结构·笔记·后端·学习
ゆづき5 小时前
假如编程语言们有外号
java·c语言·c++·python·学习·c#·生活
xuhaoyu_cpp_java5 小时前
Linux学习(一)
linux·经验分享·笔记·学习
red_redemption5 小时前
自由学习记录(189)
学习
云朵观自在6 小时前
企业媒体宣发为何选择JHMS?——一家策略导向的媒体传讯服务商
大数据·人工智能·经验分享·媒体·jhms