Skip to content

Latest commit

 

History

History
166 lines (140 loc) · 5.16 KB

README.md

File metadata and controls

166 lines (140 loc) · 5.16 KB

hls-get

A command line tool for downloading M3U8 and segments.

Scenarios:

  • Simple mode: download one or multiple URL without DB support.
  • Redis support: download multiple URL via REDIS LIST.
  • MySQL support: download multiple URL via MySQL DB Table.

Usage:

hls-get [OPTIONS,...] [URL1,URL2,...]

Options:

  • c string Use a config file instead of the following parameters. Default empty.
  • CO int Concurrent tasks. (default 5)
  • L string Logging output file. Default 'stdout'.
  • V string Logging level. Default 'INFO'.
  • M string Source mode: redis, mysql. Empty means source via command args.
  • MD string MySQL database. (default "hlsgetdb")
  • MH string MySQL host. (default "localhost")
  • MN string MySQL username. (default "root")
  • MP int MySQL port. (default 3306)
  • MT string MySQL table. (default "hlsget_downloads")
  • MW string MySQL password.
  • O string Output directory. (default ".")
  • PR string Rewrite output path method. Empty means simple copy. The implement of Path Rewrite is powered by 'https://github.com/rwtodd/sed-go', please check the document when using it. Normally it's like a sed command, but with differences:
Go-sed Traditional RE Notes
s/a(bc*)d/$1/g s/a\(bc*\)d/\1/g Don't escape (); Use $1, $2, etc.
s/(?s).// s/.// If you want dot to match \n, use (?s) flag.
  • R int Retry times if download fails.
  • RD int Redis db num.
  • RH string Redis host. (default "localhost")
  • RK string List key name in redis. (default "HLSGET_DOWNLOADS")
  • RP int Redis port. (default 6379)
  • RR string Redirect server request.
  • RW string Redis password.
  • S bool Skip if exists.
  • SR string Rewrite segment name method. Empty means simple copy. NOT IMPLEMENTED YET.
  • TO int Request timeout in seconds. (default 20)
  • TT int Total download links.
  • UA string UserAgent. (default "hls-get v0.9.10")

Data Structure of MySQL:

The following Table Structure is for hls-get to download from a MySQL db table.

  • url field is the source url for downloading,

  • dest field will be filled with file saved path after downloaded,

  • status 0 means for download, 1 means downloading, 2 = success, less than 0 means failed.

  • ret_code and ret_msg indicates the download result, 0 and empty message means DONE well.

  • Table structure for hlsget_downloads

      DROP TABLE IF EXISTS `hlsget_downloads`;
      CREATE TABLE `hlsget_downloads` (
        `id` int(11) NOT NULL AUTO_INCREMENT,
        `url` varchar(256) NOT NULL,
        `status` int(11) NOT NULL DEFAULT '0',
        `dest` varchar(256) DEFAULT NULL,
        `ret_code` int(11) DEFAULT '0',
        `ret_msg` varchar(128) DEFAULT NULL,
        PRIMARY KEY (`id`),
        UNIQUE KEY `url` (`url`)
      ) ENGINE=InnoDB AUTO_INCREMENT=393211 DEFAULT CHARSET=latin1;
    
  • The following script shows load download list from epgdb_vod.pulish_movie:

    INSERT INTO hlsgetdb.hlsget_downloads (url, ret_code) SELECT `guid`, 0 FROM epgdb_vod.publish_movie WHERE `guid` <> "";
    

Data Structure of Redis:

Simply push your download list to Redis as a Redis List.

Example of Using MySQL:

    ./hls-get -O=/data/videos -C 10 -M=mysql -MW=root -TO=10 -TT=100 -S -R=3 -PR='s/\/vds[0-9]+\/data[0-9]+\/(.*)/$1/g' -RR='http://videoha.example.org/redirect?url=%s'
  • -C 10 Means download 10 links simultaneously
  • -M=mysql Using mysql db support
  • -MW=root MySQL root password
  • -TO=10 Timeout in 10 seconds for each request
  • -TT=100 Totally download 100 links
  • -S Skip exists segments
  • -R=3 Retry 3 times if tailed
  • -PR='s/\/vds[0-9]+\/data[0-9]+\/(.*)/$1/g' Rewrite output path
  • -RR='http://videoha.example.org/redirect?url=%s' Links needs a redirect server

Configuration example

## This is an example of config file for hls-get
## The format of config is TOML (like ini file)
# Output string
output="./"
# PathRewrite string
path_rewrite="s/\\/vds[0-9]+\\/data[0-9]+\\/(.*)/$1/g"
# SegmentRewrite string
segment_rewrite=""
# UserAgent string
user_agent="HLS-GET"
# LogFile string
log_file=""
# LogLevel string
log_level="DEBUG"
# Retries int
retries=3
# Skip bool
skip=true
# Redirect string
redirect="http://videoha.example.org/redirect?url=%s"
# Concurrent int
concurrent=5
# Timeout int
timeout=20
# Total int64
total=0
# Mode string
mode="mysql"

# Redis RedisConfig
[redis]
host="127.0.0.1"
port=6379
password=""
db=1
key="DOWNLOAD_MOVIES"

# MySQL MySQLConfig
[mysql]
host="127.0.0.1"
port=3306
db="hlsget_db"
table="download_movies"