SAP R/3 форум ABAP консультантов
Russian ABAP Developer's Club

Home - FAQ - Search - Memberlist - Usergroups - Profile - Log in to check your private messages - Register - Log in - English
Blogs - Weblogs News

Расспараллеливание массовой обработки данных



 
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP
View previous topic :: View next topic  
Author Message
menx
Участник
Участник



Joined: 21 Nov 2008
Posts: 25
Location: СПб - Валлдорф

PostPosted: Mon Mar 02, 2009 3:19 pm    Post subject: Расспараллеливание массовой обработки данных Reply with quote

Предпосылки:
Есть громадный набор данных. С целью ускорения его обработки делается расспаралеливание обработки блоками. Получается блок и делается ассинхронный RFC вызов, передавая блок на обработку. При получении результата, блок удаляется из источника. И тд пока источник не опустеет.

Проблема:
При возникновении ошибки (например communication error), надо как-то узнать для какого блока она случилась, чтобы вернуть этот блок данных на повторную обработку.

Вопрос:
Как узнать контекст вызова: либо входные параметры, либо имя задачи, либо еще какую-нибудь информацию дающую возможность вычислить блок.

Может кто-нибудь сталкивался с подобной задачей и уже придумал подходящий workaround?

Заранее спасибо.
Back to top
View user's profile Send private message
vga
Мастер
Мастер


Age: 80
Joined: 04 Oct 2007
Posts: 1218
Location: Санкт-Петербург

PostPosted: Mon Mar 02, 2009 3:49 pm    Post subject: Reply with quote

Что блоки делают? Пишут данные в таблицу, создают документы?
Может проверить результат их работы.
Back to top
View user's profile Send private message Blog Visit poster's website
Удав
Гуру
Гуру


Age: 48
Joined: 25 Jan 2008
Posts: 580
Location: Москва

PostPosted: Mon Mar 02, 2009 4:32 pm    Post subject: Reply with quote

Если исходные данные хранятся в одной таблице, то:
1.формировать таблицу блоков со структурой
-Имя задачи
-стартовый номер записи
-количество записей в блоке
-статус (успешно/с ошибкой)
2.обработку запускать по этой таблице, sy-subrc после вызова в таблице можно менять так:
0 - передано в обработку
4 - communication error
9 - завершено успешно (в процедуре ...performing ... on end of task)
3.После завершения цикла сортировать таблицу блоков по стартовому номеру (descending), удалить обработанные записи
4.Удалить все записи со статусом 9.
Если таблица блоков не пустая, перейти к п.2

2 вариант: вместо отдельной таблицы создать в исходной таблице с данными поле "Имя задачи" и перед запуском в обработку заполнять его.

_________________
С уважением,
Удав.
Back to top
View user's profile Send private message
menx
Участник
Участник



Joined: 21 Nov 2008
Posts: 25
Location: СПб - Валлдорф

PostPosted: Mon Mar 02, 2009 5:20 pm    Post subject: Reply with quote

@vga: К сожалению проверить работу нельзя. Вернее можно, но это по сути сведен на нет всю выгоду от распараллеливания.

@Удав: вообщем-то сейчас я именно так и делаю. Но проблема возникает если ошибка случится не сразу в месте вызова FM, а в форме, которая повешена на end of task. Там я не знаю никакой информации о вызове, ни имени таска, ни передаваемого блока. Меня волнует вот как раз то место.
Back to top
View user's profile Send private message
Удав
Гуру
Гуру


Age: 48
Joined: 25 Jan 2008
Posts: 580
Location: Москва

PostPosted: Mon Mar 02, 2009 6:00 pm    Post subject: Reply with quote

menx wrote:
Там я не знаю никакой информации о вызове, ни имени таска, ни передаваемого блока. Меня волнует вот как раз то место.

Как это не знаешь? По первому методу статус 0 будет Wink
Да и в каком случае perform end of task не выполнится, если call function прошел без ошибок?
Кстати, в форме, вызываемой по end of task есть параметр taskname.

_________________
С уважением,
Удав.
Back to top
View user's profile Send private message
menx
Участник
Участник



Joined: 21 Nov 2008
Posts: 25
Location: СПб - Валлдорф

PostPosted: Mon Mar 02, 2009 7:33 pm    Post subject: Reply with quote

о, точно! taskname есть же.
как я о нем забыл ...
ну теперь проблемы отпали.

спасибо всем и Удаву в частности.
Back to top
View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP All times are GMT + 4 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


All product names are trademarks of their respective companies. SAPNET.RU websites are in no way affiliated with SAP AG.
SAP, SAP R/3, R/3 software, mySAP, ABAP, BAPI, xApps, SAP NetWeaver and any other are registered trademarks of SAP AG.
Every effort is made to ensure content integrity. Use information on this site at your own risk.