Skip to content

Run shell command (usually one-threaded) into multiple concurrent processes

License

Notifications You must be signed in to change notification settings

bobiverse/threadme

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ThreadMe

Run any cli command in concurrent mode. Choose how many threads you need (default: 5).

Usage

Simple

Run command with default params

./threadme -cmd "date +%s"

Output:

             Command: [date +%s]
Job count to perform: [100]
             Threads: [5]
               Delay: 10 ms
Time limit for single worker: 60000 ms
--------------------------------------------------------------------------------
OUTPUT:[4/6] [date +%s] ==> [1650025517]
OUTPUT:[2/6] [date +%s] ==> [1650025517]
OUTPUT:[1/6] [date +%s] ==> [1650025517]
OUTPUT:[3/6] [date +%s] ==> [1650025517]
...

Dynamic number input #1

Use param {{N}} to use job number.

./threadme -cmd 'wc -l {{N}}.txt' 
Output:
[4/10] [wc -l 4.txt] ==> [3 4.txt]
ERROR: [2/10] [wc -l 2.txt] ==> [wc: 2.txt: No such file or directory; exit status 1;]
ERROR: [6/10] [wc -l 6.txt] ==> [wc: 6.txt: No such file or directory; exit status 1;]
[7/10] [wc -l 7.txt] ==> [1 7.txt]
ERROR: [8/10] [wc -l 8.txt] ==> [wc: 8.txt: No such file or directory; exit status 1;]
...

Read command input from file

Use param {{LINE}} to use job param from file.

./threadme -cmd 'bash sendmail.sh {{LINE}}' -f customers.txt
Output:
[0/8256] [bash sendmail.sh a@a.example.com] ==> [Sent: a@a.example.com]
ERROR: [4/8256] [bash sendmail.sh e@e.example.com] ==> [Invalid user; exit status 1;]
[2/8256] [bash sendmail.sh c@c.example.com] ==> [Sent: c@c.example.com]
[1/8256] [bash sendmail.sh b@b.example.com] ==> [Sent: b@b.example.com]
[3/8256] [bash sendmail.sh d@d.example.com] ==> [Sent: d@d.example.com]
...

Stop all jobs if error message occurs

Use -stop-on flag to halt all tasks upon encountering an error message. Note: All tasks will be discontinued if any job yields a message indicating a stop condition.

./threadme -cmd 'bash sendmail.sh {{LINE}}' -f customers.txt -stop-on 'Error:'
Output:
[0/8256] [bash sendmail.sh a@a.example.com] ==> [Sent: a@a.example.com]
ERROR: [4/8256] [bash sendmail.sh e@e.example.com] ==> [Invalid user; exit status 1;]
[2/8256] [bash sendmail.sh c@c.example.com] ==> [Sent: c@c.example.com]
[1/8256] [bash sendmail.sh b@b.example.com] ==> [Sent: b@b.example.com]
[3/8256] [bash sendmail.sh d@d.example.com] ==> [Sent: d@d.example.com]
[4/8256] [bash sendmail.sh e@e.example.com] ==> [Error: timeout while sending e@e.example.com]
> Stop output message found: Error: timeout while sending e@e.example.com
> Stopping all workers!
> Duration: 12.03473712s

Keep running while message present

Use -while flag to cease all tasks when a success message is absent from any of the jobs. Note: All jobs will be terminated if the message differs for even a single job.

./threadme -cmd 'bash sendmail.sh {{LINE}}' -f customers.txt -while 'Sent:'
Output:
[0/8256] [bash sendmail.sh a@a.example.com] ==> [Sent: a@a.example.com]
ERROR: [4/8256] [bash sendmail.sh e@e.example.com] ==> [Invalid user; exit status 1;]
> No `while message` found: Invalid user; exit status 1;
> Stopping all workers!
> Duration: 7.03404163s 

Use different interpreter

Use -interpreter flag to change command interpreter. By default it's from variable$SHELL.

Have $RANDOM value

# `/bin/bash`
./threadme -cmd 'echo "$USER $RANDOM"' -n=1
# [0/1] [echo $USER $RANDOM] ==> [bobiverse 31459]

Don't have $RANDOM value

./threadme -cmd 'echo "$USER $RANDOM"' -n=1 -interpreter=/bin/sh
# [0/1] [echo $USER $RANDOM] ==> [bobiverse]

About

Run shell command (usually one-threaded) into multiple concurrent processes

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages