BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
SP_SAS
Obsidian | Level 7

Hi there,


I have a program that currently runs like this. I have simplified to ask question.


%let total_runs=30;


%let max_paralle_allowed = 10; /*you do not want to run more than 10 jobs at a time*/


%do i = 1 to 3;

%do j = %eval((&i*&max_paralle_allowed)-10+1) %to %eval(&i*&max_paralle_allowed);

options sascmd="!sascmld memsize=2g" autosignon;

signon remote=task&j;

rsubmit process=task&j wait=no log="" output="";

libname abc "";

%include "mymacro.sas";

%mymacro();

endrsubmit;


%end; /*end of j*/

waitfor _all_ task1 task2 task3.....task10;

signoff remote = task1 task2 task3... task10;

 

%end; /*end of i*/


Issue: Now what happens is currently it will run 10 parallel jobs. Once all 10 are done it will kick off another 10 and then another 10. What happens in this setting is when out of the first 10, 8 jobs are done and 2 are running for 10 more hours, the program waits for those 2 to complete before starting next 10.


What I want to do is : The program first kicks off 10 max allowed jobs. Then keeps checking if total running jobs are less then 10 if that is the case then it will kick off next one and so on.. i.e. as soon as some of the first 10 jobs are complete the new jobs keep getting submitted (max running at a time 10)..


Any help would be appreciated.

 

1 ACCEPTED SOLUTION

Accepted Solutions
ChrisBrooks
Ammonite | Level 13

Hi @SP_SAS - it will involve some significant recoding but I think the article on this web page will do what you want https://direct-root.com/blog/dynamic-parallel-processing-in-sas-rsubmit/

View solution in original post

3 REPLIES 3
Patrick
Opal | Level 21

@SP_SAS 

I guess what you would need to do is use a WAITFOR _ANY_.

If any of the tasks finishes you then need to check which tasks are still running and which one finished so that you know how many new tasks you can start - and eventually also get the correct names for the &task<n> macro variables so that you only reuse macro variable names for iterations which finished already.

 

If you've got SAS DI Studio: The Loop transformation would let you implement such logic easily and very robust.

SP_SAS
Obsidian | Level 7

Thanks..

ChrisBrooks
Ammonite | Level 13

Hi @SP_SAS - it will involve some significant recoding but I think the article on this web page will do what you want https://direct-root.com/blog/dynamic-parallel-processing-in-sas-rsubmit/

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 3 replies
  • 1364 views
  • 0 likes
  • 3 in conversation