@Fox Привет.Я описывал задачу в этой теме https://community.bablosoft.com/topic/27417/вызов-многопоточной-функции
Дело в том,что я не могу вообще никак перевести свой скрипт на многопоток,у меня тупо,что в вызове функции в многопоток,что просто обычный многопоток,выполняет свою работу с данными по очереди,а не одновременно.И это очень сильно бьет по времени,а нужна именно скорость обработки.Все уже готово и скрипт рабочий полностью,но скорость обработки заставила воспользоваться многопотоком.Ранее,подобных проблем не замечал,а сейчас элементарную задачу не могу уже несколько дней решить.
Скрипт очень простой и работает без браузера вообще,в скрипте используется только одно взаимодействие с гет запросом.Пример скрипта я приложил в этой теме(но без запросов),он точно почти такой же,как и основа.
Логика такова:
1)Запускается скрипт (без всяких ресурсов изначально и данных) и создаются два ресурса.
2)Делается запрос на сайт,который обрабатывается в отдельной функции,т.е. обрабатывает полученные строки и записывает в ресурс.
3)Вызывается функция в несколько потоков,которая работает (должна работать) с каждой строкой из созданного ранее ресурса(уникальной)в отдельном потоке.Данные обрабатываются и записываются во второй ранее созданный ресурс.
4)Как только данные обработаны,ресурс переводится в список и список записывается в файл.Более ничего не делается.
-Сперва я думал,что проблема в создаваемых в ходе работы ресурсах,но нет.Создавал изначально ресурсы и то же самое было.
-Потом пробовал брать из файлов значения\потом создавать файлы по ходу и из них брать данные\сохранять напрямую пытался и.т.д
-Возможно думал стоят какие то ограничения из за слабого пк с 4 гб оперативы и взял сервер с 64 гб,но как обрабатывалась строка за 5 минут на моем пк,так же по скорости и на серваке.Ладно, с этим я уже ничего не поделаю из за регулярок в проекте,согласен.Но вот перевести на поток и хотя бы по 10 строк одновременно обрабатывать,очень бы помогло.А сейчас в любом случае,у меня,сколько бы потоков не выставил - работает все равно как один,просто по очереди разный поток берет свои данные(
Полное логирование каждого действия в ТХТ
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
Нужен метод как логировать тупо каждое действие со всех потоков. Ясно что я не про ручную проставку вывода влог между каждым блоком.
Я пишу много логов, а большой скрипт всегда разбиваю на кучу модулей/функций.
Еще ни разу не было, чтобы когда скрипт упал я долго думал почему так случилось. Обычно, когда я пишу код, я часто заранее понимаю, почему он может упасть в конкретном месте, там особенно много логов пишу, могу через кубик делать, даже так.
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
@sergerdn предугадать где бас "залупится" в безконечный цикл из-за того что он не успел что-то где-то записать в абсолютно исправавном блоке - маловозможно. А паузы в пару миллисекунд сувать в каждый так блок тоже так себе.
Это эфемерное умозаключение или вы можете описать алгоритм возникновения проблемы?
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
@sergerdn предугадать где бас "залупится" в безконечный цикл из-за того что он не успел что-то где-то записать в абсолютно исправавном блоке - маловозможно.
Никто не умеет видеть будущее и никто не может знать что случиться.
Но сделать тонну логов, чтобы в будущем можно было понять что происходит - это точно возможно. Люди делятся на два типа - кто пишет тонну логов и кто пока их не пишет.
Я к одному скрипту в том числе прикручивал сохранение скриншотов из браузера после определенных действий или после любой ошибки.
В том числе, если у меня есть куча синхронного кода подряд, то я втыкаю в середину кода sleep, чтобы один зависший поток не тормозил мне все остальные потоки.
Все этих техники известны в программировании, я ничего нового не изобрел.
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
P.S. Только не пишите не используйте метки. Это будет уместно, только после их выпила с софта.
Да почему же, использовать метки в BAS это самый простой способ выстрелить себе в ногу так, что потом будет очень сложно понять, что же, блин, происходит.
Проблема меток не в том, что они есть, а в том, что ими не умеют пользоваться.
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
@Fox Это фактическое заключение. Он попадал в цикл меточный, в котором не было паузы. И падал.
Интерфейс BAS может зависнуть в случае очень большого или бесконечного цикла без задержки, но BAS при этом не вылетает. Скорее всего ваша операционная система автоматически закрывает зависшие приложения
К примеру вот тестовый скрипт с бесконечным циклом без задержки, который выполняется в течении 30 секунд: 2904.xml
Вот так этот скрипт работает у меня:

P.S. Только не пишите не используйте метки. Это будет уместно, только после их выпила с софта.
Эм, ни когда не писал не использовать метки. Когда метки только добавили в BAS с ними было много проблем, по этому я их не использовал и говорил, что "метки зло". Сейчас все проблемы с метками исправлены, но проблема зависания интерфейса возникает из за очень большого или бесконечного цикла без задержки вне зависимости от конструкции. Например установите тип запуска "Повторять" и первым действием выведите в лог несуществующую переменную, получите точно такой же бесконечный цикл.
-
@hvrsh said in Полное логирование каждого действия в ТХТ:
@Fox Для тестинга нужен слоумод чтоли, чтобы по умолчанию были паузы по пару десятков миллисекунд возле каждого действия. было бы не плохо.
в смысле?