Skip to content

3rd-stone/ECV

Repository files navigation

旧数据上云SOP

此文档描述执行旧数据上云的步骤。以 ll 这个站举例,其他站类似。

louda晚间流量较大,用 早上 + 中午 + 下午 + 晚上十二点以后 的时间段 跑这个脚本,不然会有大量上传失败。

Prerequisite 前置要求 | 准备工作

第一步. 原始excel按照二级域名分类

  1. 打开某个站的 excel,按照从A-Z的顺序 sort之后,可以发现一般会包含多个二级域名 (以 ll 为例,如video.xxxx.com, video2.xxxx.com, video1.xxxx.com (http://video1.xxxxcom/) 等)。先按照二级域名的不同,将这个list拆分成不同的表格。每个表格只包含对应的二级域名的list。如video.txt, video1.txt, video2.txt
  2. 分别打开不同的二级域名表格,将数据按照条数进行拆分。推荐 每500行 为一个list。不要 excel格式,直接txt文本。如video_part1.txt, video_part2.txt. video1_part.txt, video2_part5.txt 等等。

第二步. 启动服务器。

  1. 启动 Amazon linux2 服务器,型号选择 t3.medium, 打开 T2/T3 unlimited 的模式。
  2. 给 EC2 挂载具有完整 S3 权限的 IAM Role。或者在 CLI 上配置AKSK密钥

第三步.配置 python 环境

Linux 或 Windows上的Python 3 环境 , 安装 requests 和 boto3 库

Linux

yum install python3  
pip3 install requests 
pip3 install boto3

Windows

# download python3 from [python.org](https://www.python.org/downloads/windows/) 
pip3 install requests
pip3 install boto3

第四步. 准备脚本

  1. 在默认 ~ 的路径下, mkdir ll 建立 ll 的文件夹 之后 cd ll 进入文件夹
  2. 在旧数据上云的过程中,我们主要需要4个脚本, _1_upload.py, _2_check_error.py, 以及 _3_compare_ts.py, _4_re_upload_ts.py。 分别用于上传list,重传失败的文件,以及最后验证文件完整性, 以及再次重传没有的ts文件。先把这几个代码 copy到服务器上。

第五步. 确认S3路径

提前确认好每个站的bucket 以及prefix。

使用步骤

针对每个txt列表 | 上传过程

  1. 将 video_partN.txt 上传到服务器 ~/ll 这个文件夹下
  2. 打开 _1_upload.py。在“自修改信息区域”, 修改 file_path,bucket,以及prefix。这三个参数分别代表,本地txt list路径 ,目标S3桶,以及目标S3桶的prefix。 以video.xxxxx.com为例,s3桶为 aws-lldk-com,prefix为 video-xxxxx-com。maxThreads经过测试 800 最好
  3. 一定要二次检查保证配置的信息是正确的
  4. mkdir log
  5. 执行命令: nohup python3 _1_upload.py > log/video_partN.log 2>&1 &
  6. 去配置其他server,修改对应参数,可以同时并行多个server,比如10或者20个。因资源抢占问题,不建议在一个server上运行多个程序。
  7. 过几个小时,登录到server上。查看进程有没有执行完毕。 ps aux | grep ‘python’,如无,继续等待。不要删除或者移动任何文件。
  8. 如执行完毕,检查实际处理的条数是否和video_partN.txt一致。执行 wc -l video_partN.txt , 再执行 grep 'deal' log/video_partN.log | wc -l
    1. 如果两者数目一致,说明程序执行没有问题。ls可以发现文件夹多了一个日期的log,如2020-03-20-07-39-45.log,这个日志是记录 import.py 里由于超时等原因没有上传成功的url的。 执行 python3 _2_check_error.py, 该脚本会自动找到最新的日期log,将日期log 里面记录下来的没有上传成功的list重新上传。并且又会生成新的日期log。 如果执行完 _2_check_error.py, wc -l 最新的时间戳日志.log,看一下是不是0行,如果多于0行,继续执行 python3 _2_check_error.py (如果希望在后台运行不中断,使用nohup),直到没有新的错误link生成
    2. 如果不一致,说明实际程序执行到某一行时,可能因为特殊字符(中文或者是")的原因自动退出了。这时候需要先执行 python3 _2_check_error.py ,再去对应的行数检查(vim进去之后,: set nu,然后到对应行查看)。
    3. 查看完毕解决字符问题后,重新建一个剩余url的list,修改 _1_upload.py 的参数,让 _1_upload.py 继续执行剩下的没有执行的行数。

等二级域名下所有文件都上传完毕 | 验证过程

  1. 循环上述上传过程,直到某个二级域名下的所有数据都上传成功(即最新日期的日志没有错误链接了)。接下来,需要验证某个站是否都上传成功了,有没有漏掉的文件,
  2. 打开 _3_compare_ts.py 这个文件,找到 自修改信息区域,修改bucket名字,prefix (如video-xxx-com/) 记得带 "/", txt_file为某个二级域名的全部txt list。(注意,一个站下有会有多个二级域名,要分开执行)
  3. python3 _3_compare_ts.py ,该脚本会验证每个文件夹下的ts分片数是不是和index.m3u8当中的是一致的,并且记录那些不一致的URL到日志当中,日志为tsfile文件夹中的最新日期日志,路径:tsfile/2020-03-...log
  4. 运行 python3 _4_re_upload_ts.py, 修改bucket和prefix参数,把这些文件上传有漏的情况,重新上传一遍。
  5. 二次运行 python3 _3_compare_ts.py ,检查日志是否为空,如果不为空,循环这个_4_re_upload_ts.py,直到最后日志为空。

脚本功能说明

_1_upload.py

功能:
1.给定txt的链接文件,扫描链接并完成上传到s3的操作
2.404的链接将不会上传文件
3.所有未成功的链接将记录到最新日期的log文件中(和_1_upload.py脚本同一路径)

自定义脚本参数(可以自行修改变量):
file_path = '' - txt文件链接,字符串类型,例如 'btt1.txt'
maxThreads = 300 - 线程数量,int类型,例如300
bucket = 'test--20200310' - s3桶名称,字符串类型
prefix = 'video1-hsanhl-com/' - s3桶前缀路径,字符串类型 最前面不要/,最后要/,比如 'abc/123/'

_2_check_error.py

功能:
1.检索·upload.py·生成的最新日期的日志,并自动上传所有被记录的失败链接
2.404的链接将不会上传文件
3.所有未成功的链接将记录到最新日期的log文件中(和upload.py脚本同一路径)

直接运行脚本即可
可以通过修改 upload.check_error(max_thread = 300) 中的最大线程数来加快进度(受带宽和机器性能限制)

_3_compare_ts.py

功能:
1.给定txt文件,分析所有s3中ts文件数量,和链接中应有文件数量不相等的url,记录到同路径tsfile文件夹下的最新日期日志文件中
自定义脚本参数(可以自行修改变量):
my_bucket = s3.Bucket('test--20200310') - 修改s3桶名称
txt_file = 'btt1.txt' - txt文件路径
prefix = '' - 前缀名称,不修改则会根据链接自动检测 - 字符串类型 最前面不要/,最后要/,比如 'abc/123/'


_4_re_upload_ts.py

功能:
1.检索_3_compare_ts.py生成的最新日期日志,并上传所有ts文件
2.失败的链接会在同路径下的最新日期日志文件中

upload_index.py

功能:
1.根据给定的txt文件,上传所有index.m3u8文件(同ts文件同一目录)
2.bucket和prefix请在upload.py文件中指定 3.上传失败的链接会记录到同文件夹下的最新日期日志中

About

python scripts for ECV

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages