Jump to content
EliasKoch

Несколько ajax запросов - формирование очереди

Recommended Posts

Добрый день опишу логику,
пишу скрипт выгрузки товаров в вк, скрипт долгий может выполнятся овер9999 секунд не суть в настройках скрпита прописал  

ini_set('max_execution_time', 0);
ignore_user_abort(true);
set_time_limit(0);

Для того чтобы игнорировать 504 ошибку так как хостер не дает возможность изменить время ожидания, в общем не суть. 

смысл скрипта вкратце 

1) определяю количество категорий которое надо выгружать.
2) это количество я пишу в кеш.

3) далее циклом прохожу по категориям вытаскиваю товары, и добавляю их в вк)
4) после каждой итерации я пишу в кеш сколько у меня категорий ушло в вк.


так как скрипт может завершится 504 ошибкой или будет долго выполнятся я решил сделать что то вроде прогресса, долбить к примеру каждые 2 секунды и определять сколько загрузилось категорий из общего числа.
долблю через ajax 

и так суть.


1) я ajax'ом вызываю метод который отвечает за выгрузку  в вк

2) я одновременно с этим же вызовом запускаю процес долбдения (main_timer)

    function add_category() {

            var data= $($('#form-category [name*="selected"]:checked').parents('tr').find('[name*="product"]')).serialize();
            $.ajax({
                type:'post',
                dataType: "json",
                url:'index.php?route=common/vk_integration/category_add&token=<?= $token?>',
                data:data,
            });
            getProgress();
            $('#progres_modal').modal('show');
             main_timer = setInterval(progress();', 2000);
        }

сам таймер

function progress() {
            $.ajax({
                type:'post',
                url:'index.php?route=common/vk_integration/progress&token=<?= $token?>',
                dataType: "json",
                success: function (data) {
                    console.log(data);
                    if(data.success=='1'){
                        $('#progres_modal').modal('hide');
                        clearTimeout(main_timer);
                    }else{
                        $('#curent_result').text(data.current_item);
                        $('#count_result').text(data.count);
                    }
                }
            });
        }


Чего я ожидаю 

у скрипта экспорта вк длительного выполнения (пусть себе крутится)
а у таймера - Запрос - ответ и так далее .

Но на деле я получаю скрипт экспорта вк pennding и все долбления pennding но только скрипт закончит выполнение (200) все запросы будут 200
как будто все запросы попадают в очередь а мне  надо что то вроде  распараллеливания

ps написано все в одном контроллере

 

Edited by EliasKoch

Share this post


Link to post
Share on other sites

1. Разделите получения списка категорий постранично. ( Если категорий много )
2. Разделите получение товаров в категории постранично.
3. Для Ajax используй callback, тогда не будет проблем с долгим ожиданием.

 

Share this post


Link to post
Share on other sites

Был вариант такой но тогда выгрузка будет проходить намного больше, чем  ту логику которую  я продумал я

Share this post


Link to post
Share on other sites

Нашел решение для своей проблемы

session_write_close();

в первом скрипте

 

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
You are posting as a guest. If you have an account, please sign in.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Similar Content

    • By Benzin102
      День добрый!
      Написал функцию для админки для генерации некой инфы и сохранении её в БД. Сейчас идёт аяксовый запрос в контроллер, там фором прогоняется цикл и возвращается инфа с массивом нагенерированных штук. Контроллер возвращает стандартным "$this->response->setOutput(json_encode($json));" по завершению всего цикла. 
      Есть ли возможность воткнуть ответ в темплейт после каждой итеррации цикла?
    • By greychatte
      Добрый день, уважаемые!
       
      Прикрутила простейший скрипт ajax для загрузки товаров в product/category.tpl.
       
      <script>
        $('.sliderArrow').on('click', '.toPageButton', function(){
        $.ajax({
          url: '/catalog/controller/product/category.php',
          type: "get",
          data:  $('.toPageButton').attr('href') ,
          success: function(data){
          alert(data);
          },
          error: function() 
          {}          
         });
        });
      </script>
       
      А в результате он мне пишет: Fatal error: Class 'Controller' not found in /catalog/controller/product/category.php on line 3. 
      Файл category.php не меняла. 
      Что я делаю не так?
       
       
    • By svmax
      Ищу модуль как на картинке. Нужно лазить по пунктам меню без перезагрузки, при провале в подкатегорию чтобы была кнопка назад и оставалась ссылка на верхнюю категорию. 

      НО в чем проблема: старая версия osStore 1.5.5.1.2 , PHP сейчас 5.6, в ближайшие пару месяцев перейдем на 7+ . Можете посоветовать модуль? 

    • By evxos
      Здравствуйте. Не могу самостоятельно решить следующий вопрос.
      Добавил в корзину кнопки плюс\минус для изменения количества продукта в корзине. Но как коректно подключить Ajax запросы для обновления не могу понять. 
      <button type="button" class="minus">-</button> <input type="text" name="quantity[{{ product.cart_id }}]" value="{{ product.quantity }}" size="1" class="form-control cart-q" id="score"/> $('.minus').click(function () { var $input = $(this).parent().find('#score'); var count = parseInt($input.val()) - 1; count = count < 1 ? 1 : count; $input.val(count); $input.change(); return false; setTimeout(function () { $.ajax({ type: 'post', url: 'index.php?route=checkout/cart/edit', data: 'key=' + $input.name() + '&quantity=' + $input.val(), dataType: 'json', success: function () { $('#cart > ul').load('index.php?route=common/cart/info ul li'); } }); }, 100); Что передать в data для обновления состояния корзины? В правильном ли направлении двигаюсь? 
       
    • By ArtemPitov
      Важно: адаптация платная
       
      Дополнение добавляет бесконечную погрузку товаров на основные страницы товаров. 
      Особенностью дополнения является смена url без перезагрузки страницы, что в свою очередь позволяет сохранить страницу товара на которой находится пользователь даже после обновления страницы вручную. Модуль тестировал на дефолтном шаблоне, адаптация платная
       
      Возможности 
      Динамическая смена URL (как Вконтакте)  Автоматическая загрузка товаров (как лента Вконтакте) Переход к последнему товару при возврате   
      Демо каталог: https://apl.pitov.pro/desktops/mac/ модуль включен только  на этой странице
      Демо админка: у модуля нет админки
       
      Лицензия: 
      1.       Дополнение продается по принципу “AS IS”
      2.       Одна лицензия распространяется только на один домен
  • Recently Browsing   0 members

    No registered users viewing this page.

×

Important Information

On our site, cookies are used and personal data is processed to improve the user interface. To find out what and what personal data we are processing, please go to the link. If you click "I agree," it means that you understand and accept all the conditions specified in this Privacy Notice.