Skip to content

Latest commit

 

History

History
376 lines (278 loc) · 11.7 KB

tpcds-benchmark.md

File metadata and controls

376 lines (278 loc) · 11.7 KB

运行 TPC-DS 基准测试

本文说明如何运行 TPC-DS 基准测试。

前提条件

创建基准测试集群环境

本文创建的基准测试集群环境涉及到的阿里云资源包括:

  • 资源组
  • ECS 安全组
  • VPC 网络和虚拟交换机
  • ACK 集群,该集群包含名为 spark-masterspark-worker 的节点池
  1. 修改配置文件 terraform/alicloud/terraform.tfvars ,本文使用的配置如下:

    # Alicloud
    profile = "default"
    zone_id = "cn-beijing-i"
    
    # Spark node pool
    spark_master_instance_count = 1
    spark_master_instance_type  = "ecs.g7.2xlarge"
    spark_worker_instance_count = 6
    spark_worker_instance_type  = "ecs.g7.8xlarge"
    
    # Fluid node pool
    fluid_instance_count = 0
    fluid_instance_type  = "ecs.i3.2xlarge"
    
    # Celeborn node pool
    celeborn_instance_count = 0
    celeborn_instance_type  = "ecs.i3.2xlarge"

    该配置文件的含义如下:

    • 使用 ${HOME}/.aliyun/config.json 中名为 default 的 profile
    • 可用区为 cn-beijing-i
    • spark-master 节点池包含 1ecs.g7.2xlarge ECS 实例
    • spark-worker 节点池包含 6ecs.g7.8xlarge ECS 实例
  2. 执行如下命令,创建基准测试集群环境:

    # 初始化
    terraform -chdir=terraform/alicloud init
    
    # 创建资源
    terraform -chdir=terraform/alicloud apply

    命令执行过程中需要手动输入 yes 进行确认。

部署 Spark Operator

  1. 如果尙未添加阿里云容器服务 Helm chart 仓库,执行如下命令进行添加:

    helm repo add --force-update aliyunhub https://aliacs-app-catalog.oss-cn-hangzhou.aliyuncs.com/charts-incubator
  2. 执行如下命令,部署阿里云 ack-spark-operator 组件:

    helm install spark-operator aliyunhub/ack-spark-operator \
        --version 2.1.0 \
        --namespace spark \
        --create-namespace \
        --set image.registry=registry-cn-beijing-vpc.ack.aliyuncs.com \
        --set 'spark.jobNamespaces={default}' \
        --set spark.serviceAccount.name=spark

准备基准测试容器镜像

执行如下命令,构建基准测试容器镜像并推送至镜像仓库:

IMAGE_REGISTRY=registry-cn-beijing.ack.aliyuncs.com      # 请替换成你的镜像仓库地址
IMAGE_REPOSITORY=ack-demo/spark-tpcds-benchmark          # 请替换成你的镜像仓库名称
IMAGE_TAG=3.3.2-0.1                                      # 镜像标签
IMAGE=${IMAGE_REGISTRY}/${IMAGE_REPOSITORY}:${IMAGE_TAG} # 完整的镜像地址
PLATFORMS=linux/amd64,linux/arm64                        # 镜像架构

# 构建镜像并推送至你的镜像仓库中
docker buildx build \
    --output=type=registry \
    --push \
    --platform=${PLATFORMS} \
    --tag=${IMAGE} \
    --build-arg=SPARK_IMAGE=apache/spark:v3.3.2 \
    .

注:

  • 该容器镜像中包含了基准测试相关的 Jar 包,后续步骤中会将其他依赖 Jar 包上传至 OSS,并将 OSS 作为只读存储卷挂载至 Spark Pod 中。
  • 你可以通过修改变量 IMAGE_REPOSITORYIMAGE_TAG 的值以使用自己的镜像仓库。

准备依赖 Jar 包并上传至 OSS

  1. 执行如下命令,设置 OSS 相关配置:

    # OSS 存储桶所在地域
    REGION=cn-beijing
    
    # OSS 存储桶名称
    OSS_BUCKET=example-bucket
    
    # OSS 访问端点(默认使用内网访问端点)
    OSS_ENDPOINT=oss-${REGION}-internal.aliyuncs.com
  2. 如果指定的 OSS 存储桶不存在,执行如下命令,创建该存储桶:

    ossutil mb oss://${OSS_BUCKET} --region ${REGION}
  3. Spark 作业访问 OSS 数据有多种方式,本文选择使用 JindoSDK 6.4.0 版本。执行如下命令,下载 JindoSDK 相关依赖 Jar 包并上传至 OSS:

    wget https://jindodata-binary.oss-cn-shanghai.aliyuncs.com/mvn-repo/com/aliyun/jindodata/jindo-core/6.4.0/jindo-core-6.4.0.jar
    wget https://jindodata-binary.oss-cn-shanghai.aliyuncs.com/mvn-repo/com/aliyun/jindodata/jindo-core-linux-el7-aarch64/6.4.0/jindo-core-linux-el7-aarch64-6.4.0.jar
    wget https://jindodata-binary.oss-cn-shanghai.aliyuncs.com/mvn-repo/com/aliyun/jindodata/jindo-core-linux-el6-x86_64/6.4.0/jindo-core-linux-el6-x86_64-6.4.0.jar
    wget https://jindodata-binary.oss-cn-shanghai.aliyuncs.com/mvn-repo/com/aliyun/jindodata/jindo-sdk/6.4.0/jindo-sdk-6.4.0.jar
    
    ossutil cp jindo-core-6.4.0.jar oss://${OSS_BUCKET}/spark/jars/
    ossutil cp jindo-core-linux-el7-aarch64-6.4.0.jar oss://${OSS_BUCKET}/spark/jars/
    ossutil cp jindo-core-linux-el6-x86_64-6.4.0.jar oss://${OSS_BUCKET}/spark/jars/
    ossutil cp jindo-sdk-6.4.0.jar oss://${OSS_BUCKET}/spark/jars/

创建 PV 和 PVC

  1. 创建如下 Secret 清单文件并保存为 oss-secret.yaml

    apiVersion: v1
    kind: Secret
    metadata:
      name: oss-secret
    stringData:
      akId: <OSS_ACCESS_KEY_ID>
      akSecret: <OSS_ACCESS_KEY_SECRET>

    注意事项:

    • <OSS_ACCESS_KEY_ID><OSS_ACCESS_KEY_SECRET> 需分别替换成阿里云 AccessKey ID 和 AccessKey Secret。
  2. 执行如下命令创建 Secret 资源:

    kubectl create -f oss-secret.yaml
  3. 创建如下 PV 清单文件并保存为 oss-pv.yaml

    apiVersion: v1
    kind: PersistentVolume
    metadata:
      name: oss-pv
      labels:
        alicloud-pvname: oss-pv
    spec:
      capacity:
        storage: 200Gi
      accessModes:
      - ReadOnlyMany
      persistentVolumeReclaimPolicy: Retain
      csi:
        driver: ossplugin.csi.alibabacloud.com
        volumeHandle: oss-pv
        nodePublishSecretRef:
          name: oss-secret
          namespace: default
        volumeAttributes:
          bucket: <OSS_BUCKET>
          url: <OSS_ENDPOINT>
          otherOpts: "-o umask=022 -o max_stat_cache_size=0 -o allow_other"
          path: /

    注意事项:

    • <OSS_BUCKET> 需要替换成 OSS 存储桶名称。
    • <OSS_ENDPOINT> 需要替换成 OSS 访问端点,例如北京地域 OSS 内网访问端点为 oss-cn-beijing-internal.aliyuncs.com
  4. 执行如下命令创建 PV 资源:

    kubectl create -f oss-pv.yaml
  5. 创建如下 PVC 清单文件并保存为 oss-pvc.yaml

    apiVersion: v1
    kind: PersistentVolumeClaim
    metadata:
      name: oss-pvc
    spec:
      accessModes:
      - ReadOnlyMany
      resources:
        requests:
          storage: 200Gi
      selector:
        matchLabels:
          alicloud-pvname: oss-pv
  6. 执行如下命令创建 PVC 资源:

    kubectl create -f oss-pvc.yaml
  7. 执行如下命令查看 PVC 状态:

    kubectl get pvc oss-pvc

    预期输出:

    NAME      STATUS   VOLUME   CAPACITY   ACCESS MODES   STORAGECLASS   AGE
    oss-pvc   Bound    oss-pv   200Gi      ROX                           38s
    

    输出表明 PVC 已经创建并绑定成功。

提交基准测试作业

  1. 执行如下命令,设置基准测试作业参数:

    # 规模因子
    SCALE_FACTOR=3072
  2. 执行如下命令,提交基准测试作业:

    helm install tpcds-benchmark charts/tpcds-benchmark \
        --set image.registry=${IMAGE_REGISTRY} \
        --set image.repository=${IMAGE_REPOSITORY} \
        --set image.tag=${IMAGE_TAG} \
        --set oss.bucket=${OSS_BUCKET} \
        --set oss.endpoint=${OSS_ENDPOINT} \
        --set benchmark.scaleFactor=${SCALE_FACTOR} \
        --set benchmark.numIterations=1

    可以添加更多形如 --set key=value 的参数指定基准测试的配置,支持的配置选项请参见 charts/tpcds-benchmark/values.yaml

  3. 执行如下命令,实时查看基准测试作业状态:

    kubectl get -w sparkapplication tpcds-benchmark-${SCALE_FACTOR}gb
  4. 执行如下命令,实时查看 Driver Pod 日志输出:

    kubectl logs -f tpcds-benchmark-${SCALE_FACTOR}gb-driver

查看基准测试结果

  1. 执行如下命令,查看基准测试输出:

    ossutil ls -s oss://${OSS_BUCKET}/spark/result/tpcds/${SCALE_FACTOR}gb/

    期望输出如下:

    oss://spark-on-ack/spark/result/tpcds/SF=3072/
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/_SUCCESS
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/part-00000-80c681de-ae8d-4449-b647-5e3d373edef1-c000.json
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/summary.csv/
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/summary.csv/_SUCCESS
    oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/summary.csv/part-00000-5a5d1e4a-3fe0-43a1-8248-3259af4f10a7-c000.csv
    Object Number is: 7
    
    0.172532(s) elapsed
  2. 执行如下命令,从 OSS 下载基准测试结果至本地并保存为 result.csv

    ossutil cp oss://spark-on-ack/spark/result/tpcds/SF=3072/timestamp=1716901969870/summary.csv/part-00000-5a5d1e4a-3fe0-43a1-8248-3259af4f10a7-c000.csv result.csv
  3. 执行如下命令,查看基准测试结果:

    cat result.csv

    期望输出如下(已省略部分内容):

    q1-v2.4,13.169382888,13.169382888,13.169382888,0.0
    q10-v2.4,9.502788331,9.502788331,9.502788331,0.0
    q11-v2.4,57.161809588,57.161809588,57.161809588,0.0
    q12-v2.4,5.344221526999999,5.344221526999999,5.344221526999999,0.0
    q13-v2.4,16.183193874,16.183193874,16.183193874,0.0
    q14a-v2.4,121.433786224,121.433786224,121.433786224,0.0
    q14b-v2.4,112.871190193,112.871190193,112.871190193,0.0
    q15-v2.4,14.63114106,14.63114106,14.63114106,0.0
    q16-v2.4,47.082124609,47.082124609,47.082124609,0.0
    q17-v2.4,14.320191869,14.320191869,14.320191869,0.0
    q18-v2.4,30.619759895999998,30.619759895999998,30.619759895999998,0.0
    q19-v2.4,7.874492828999999,7.874492828999999,7.874492828999999,0.0
    q2-v2.4,34.106892226999996,34.106892226999996,34.106892226999996,0.0
    q20-v2.4,6.1991251609999996,6.1991251609999996,6.1991251609999996,0.0
    ...

    输出结果分为五列,分别为查询名称、最短运行时间(秒)、最长运行时间(秒)、平均运行时间(秒)和标准差(秒)。本示例由于只跑了一轮查询,因此最短/最长/平均执行时间相同,标准差为 0。

环境清理

  1. 执行如下命令,删除基准测试作业:

    helm uninstall tpcds-benchmark
  2. 执行如下命令,删除 PVC 资源:

    kubectl delete -f oss-pvc.yaml
  3. 执行如下命令,删除 PV 资源:

    kubectl delete -f oss-pv.yaml
  4. 执行如下命令,删除 Secret 资源:

    kubectl delete -f oss-secret.yaml
  5. 如果不再需要本示例中创建的存储桶,执行如下命令,删除 OSS 存储桶:

    ossutil rm oss://${OSS_BUCKET} -b

    注意事项:

    • 删除 OSS 存储桶为不可逆操作,请谨慎操作,以免数据丢失。
  6. 销毁本集群测试集群环境:

    terraform -chdir=terraform/alicloud destroy