Как избавиться от состояния гонки?

Поддержка
  • @mordor said in Как избавиться от состояния гонки?:

    Использовать глобальные переменные, как глобальный объект не получится. По той причине что в БАСе глобальные переменные, это не переменные по факту, а запись в базе данных которая по идее подключена к планировщику (процесс Scheduler.exe) Он и создаёт пул потоков, он же оперирует ресурсами и мониторит их, ну т.е. по факту твои предположения верны.

    Неверно. Глобальные переменные это всего лишь переменные в ОЗУ с глобальной областью видимости и к Scheduler.exe не имеют никакого отношения.

    @mordor said in Как избавиться от состояния гонки?:

    При добавлении нового аккаунта в интерфейсе

    Если задача сводится к мониторингу изменения статуса аккаунта, то это можно сделать либо через БД либо через Events(События), если используется веб интерфейс. Через БД мы просто в начале работы потока получаем/создаем запись с данными нашего аккаунта и потом по ее id меняем статусы и тд. В каком месте тут может возникнуть состояние гонки непонятно, тк каждый поток работает со своей записью в БД, а интерфейс только читает эти данные и отображает в интерфейсе.

  • @Lipstein said in Как избавиться от состояния гонки?:

    У меня допустим премиум, в котором я бы хотел сделать риалтайм отображение состояния потоков, не через дефолтный лог, а например, через красиво оформленный интерфейс с таблицей.

    Обратите внимание на это действие:

    32a21681-2482-4bcd-828d-9f0e226bf089-изображение.png

  • @UserTrue Ну может быть и так, но ты не можешь написать в коде что-то вроде

    [[GLOBAL:VAR]]["new propertie"] = "new propertie";
    

    Тебе сначала нужно вытащить из неё данные в локальную переменную, внести изменнения в эту локальную переменную, и перезаписать глобальную переменную. Поэтому тут может возникнуть гонка, либо нужно юзать лок, чего ТС явно не хочет.

    @UserTrue said in Как избавиться от состояния гонки?:

    Если задача сводится к мониторингу изменения статуса аккаунта, то это можно сделать либо через БД либо через Events(События), если используется веб интерфейс. Через БД мы просто в начале работы потока получаем/создаем запись с данными нашего аккаунта и потом по ее id меняем статусы и тд. В каком месте тут может возникнуть состояние гонки непонятно, тк каждый поток работает со своей записью в БД, а интерфейс только читает эти данные и отображает в интерфейсе.

    Ну так или иначе, чувак не понимает как работает база данных. По сути в базах данных, действительно ведь есть сессии в каждой из которых видны внесённые изменения за определённый момент общения с БД, поэтому опять же, назвать это ахинией сложно. Просто человек, явно не до конца понимает как это устроено.

  • @Fox said in Как избавиться от состояния гонки?:

    @Lipstein said in Как избавиться от состояния гонки?:

    У меня допустим премиум, в котором я бы хотел сделать риалтайм отображение состояния потоков, не через дефолтный лог, а например, через красиво оформленный интерфейс с таблицей.

    Обратите внимание на это действие:

    32a21681-2482-4bcd-828d-9f0e226bf089-изображение.png

    Благодарю, не обращал внимания вообще на это действие до покупки премиума.

    @mordor said in Как избавиться от состояния гонки?:

    @UserTrue Ну может быть и так, но ты не можешь написать в коде что-то вроде

    [[GLOBAL:VAR]]["new propertie"] = "new propertie";
    

    Тебе сначала нужно вытащить из неё данные в локальную переменную, внести изменнения в эту локальную переменную, и перезаписать глобальную переменную. Поэтому тут может возникнуть гонка, либо нужно юзать лок, чего ТС явно не хочет.

    @UserTrue said in Как избавиться от состояния гонки?:

    Если задача сводится к мониторингу изменения статуса аккаунта, то это можно сделать либо через БД либо через Events(События), если используется веб интерфейс. Через БД мы просто в начале работы потока получаем/создаем запись с данными нашего аккаунта и потом по ее id меняем статусы и тд. В каком месте тут может возникнуть состояние гонки непонятно, тк каждый поток работает со своей записью в БД, а интерфейс только читает эти данные и отображает в интерфейсе.

    Ну так или иначе, чувак не понимает как работает база данных. По сути в базах данных, действительно ведь есть сессии в каждой из которых видны внесённые изменения за определённый момент общения с БД, поэтому опять же, назвать это ахинией сложно. Просто человек, явно не до конца понимает как это устроено.

    Так и есть, я не до конца осведомлён в вопросах работы с БД. Тоже спасибо за помощь.

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    Использовать глобальные переменные, как глобальный объект не получится. По той причине что в БАСе глобальные переменные, это не переменные по факту, а запись в базе данных которая по идее подключена к планировщику (процесс Scheduler.exe) Он и создаёт пул потоков, он же оперирует ресурсами и мониторит их, ну т.е. по факту твои предположения верны.
    

    Неверно. Глобальные переменные это всего лишь переменные в ОЗУ с глобальной областью видимости и к Scheduler.exe не имеют никакого отношения.

    @mordor said in Как избавиться от состояния гонки?:

    При добавлении нового аккаунта в интерфейсе

    Если задача сводится к мониторингу изменения статуса аккаунта, то это можно сделать либо через БД либо через Events(События), если используется веб интерфейс. Через БД мы просто в начале работы потока получаем/создаем запись с данными нашего аккаунта и потом по ее id меняем статусы и тд. В каком месте тут может возникнуть состояние гонки непонятно, тк каждый поток работает со своей записью в БД, а интерфейс только читает эти данные и отображает в интерфейсе.

    И тебе спасибо, даже в режиме срача, удалось получить полезную инфу.

  • @mordor said in Как избавиться от состояния гонки?:

    Тебе сначала нужно вытащить из неё данные в локальную переменную, внести изменнения в эту локальную переменную, и перезаписать глобальную переменную. Поэтому тут может возникнуть гонка, либо нужно юзать лок, чего ТС явно не хочет.

    Вообще говоря можно изменить, если писать в выполнить код., то все выполниться в одном тике и не будет конфликтов, но я так обычно не делаю тк мне не кажется это красивым. И есть еще один минус, это JSON формат хранения глоб переменных и если в них много данных то это будет создавать нагрузку.

  • @UserTrue said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    Тебе сначала нужно вытащить из неё данные в локальную переменную, внести изменнения в эту локальную переменную, и перезаписать глобальную переменную. Поэтому тут может возникнуть гонка, либо нужно юзать лок, чего ТС явно не хочет.

    Вообще говоря можно изменить, если писать в выполнить код., то все выполниться в одном тике и не будет конфликтов, но я так обычно не делаю тк мне не кажется это красивым. И есть еще один минус, это JSON формат хранения глоб переменных и если в них много данных то это будет создавать нагрузку.

    eccdb014-59bf-49d5-81f9-34394ca93669-image.png
    Может я что-то не так пишу?
    При этом ни

    [[GLOBAL:LOG]]["name1"]
    

    ни

    [[GLOBAL:LOG]].name1
    

    Не срабатывают.

  • @mordor said in Как избавиться от состояния гонки?:

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    Тебе сначала нужно вытащить из неё данные в локальную переменную, внести изменнения в эту локальную переменную, и перезаписать глобальную переменную. Поэтому тут может возникнуть гонка, либо нужно юзать лок, чего ТС явно не хочет.

    Вообще говоря можно изменить, если писать в выполнить код., то все выполниться в одном тике и не будет конфликтов, но я так обычно не делаю тк мне не кажется это красивым. И есть еще один минус, это JSON формат хранения глоб переменных и если в них много данных то это будет создавать нагрузку.

    Может я что-то не так пишу?
    При этом ни

    LOG["name1"]
    

    ни

    LOG.name1
    

    Не срабатывают.

    json это строка, а не объект. Вы посмотрите код действия "Лог" с использованием глобальной переменной

  • @mordor Ни так... Вот пример
    glob.xml
    2020-05-30_202511.png

  • Так ты опять же читаешь данные переменной в локальную переменную меняешь её и записываешь заново, если бы это был глобальный список, то нужен был бы ЛОК, что бы потоки не переписывали устаревшие данные (это в случае если список не пополняется, а меняются его данные по индексам именно).

  • @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

  • @UserTrue said in Как избавиться от состояния гонки?:

    @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни. Слушай, удали линку на свой проект, там в нём модули твои. что бы никто не подмутил, мало ли.

  • @mordor said in Как избавиться от состояния гонки?:

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни.

    Она перетрется только, если между чтением и установкой глоб переменной будет асинхронное действие

  • @mordor said in Как избавиться от состояния гонки?:

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни. Слушай, удали линку на свой проект, там в нём модули твои. что бы никто не подмутил, мало ли.

    Я где то на форуме уже приводил пример работы с объектом в глобальной переменной в многопотоке. Каждое свойство объекта - номер потока, значение - рандомная строка. Скрипт после установки значения спал случайное время и проверял изменилось ли значение. Если изменилось, то скрипт прерывался. В итоге я гонял 100 потоков 10 минут и ни одной ошибки не возникло

  • @Fox said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни. Слушай, удали линку на свой проект, там в нём модули твои. что бы никто не подмутил, мало ли.

    Я где то на форуме уже приводил пример работы с объектом в глобальной переменной в многопотоке. Каждое свойство объекта - номер потока, значение - рандомная строка. Скрипт после установки значения спал случайное время и проверял изменилось ли значение. Если изменилось, то скрипт прерывался. В итоге я гонял 100 потоков 10 минут и ни одной ошибки не возникло

    Буду очень благодарен, если дашь линку в личку.

  • @mordor said in Как избавиться от состояния гонки?:

    @Fox said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни. Слушай, удали линку на свой проект, там в нём модули твои. что бы никто не подмутил, мало ли.

    Я где то на форуме уже приводил пример работы с объектом в глобальной переменной в многопотоке. Каждое свойство объекта - номер потока, значение - рандомная строка. Скрипт после установки значения спал случайное время и проверял изменилось ли значение. Если изменилось, то скрипт прерывался. В итоге я гонял 100 потоков 10 минут и ни одной ошибки не возникло

    Буду очень благодарен, если дашь линку в личку.

    линку в личку? В смысле ссылку на личный чат со мной? Или ты про пример скрипта?

  • Для этих целей есть Mysql.
    Хочешь серьёзную базу. Пора отвыкать от детского сада.

  • @Fox said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    @Fox said in Как избавиться от состояния гонки?:

    @mordor said in Как избавиться от состояния гонки?:

    @UserTrue said in Как избавиться от состояния гонки?:

    @mordor Не нужен никакой лок, этот пример демонстрирует, что нет гонки и работа происходит синхронно, в противном случае, потоки бы перетерли данные в этой переменной и это было бы видно в логе, я не просто так сделал такой вывод лога.

    И тут не имеет значения список тут или строка, я сделал через строку для упрощения примера.

    Вотже бл*тство, ты себе представить не можешь сколько раз я мудрил лок, потому что думал что данные будут пересекаться из-за этой херни. Слушай, удали линку на свой проект, там в нём модули твои. что бы никто не подмутил, мало ли.

    Я где то на форуме уже приводил пример работы с объектом в глобальной переменной в многопотоке. Каждое свойство объекта - номер потока, значение - рандомная строка. Скрипт после установки значения спал случайное время и проверял изменилось ли значение. Если изменилось, то скрипт прерывался. В итоге я гонял 100 потоков 10 минут и ни одной ошибки не возникло

    Буду очень благодарен, если дашь линку в личку.

    линку в личку? В смысле ссылку на личный чат со мной? Или ты про пример скрипта?

    Пример скрипта, или ссылку на тему где это обсуждается, было бы реально интересно почитать.

  • @FastSpace said in Как избавиться от состояния гонки?:

    Для этих целей есть Mysql.
    Хочешь серьёзную базу. Пора отвыкать от детского сада.

    Нафиг ты ее всем навязываешь? Она в 99% случаев нафиг не нужна и хватает БАСовской и в 1% тут уже на любителя, можно с БАСовской монго через дравер работать либо с другой БД хоть и mysql. С задачами которые для скриптов справится абсолютно любая БД!!!

  • @UserTrue Да по хорошему то счету, даже файла достаточно в большинстве случаев. mysql это скорее для веб-приложение где постоянно большой оборот данных.
    Чёт походу я за больное задел этот форум.

  • @UserTrue said in Как избавиться от состояния гонки?:

    Она в 99% случаев нафиг не нужна и хватает БАСовской и в 1% тут уже на любителя, можно с БАСовской монго через дравер работать либо с другой БД хоть и mysql. С задачами которые для скриптов справится абсолютно любая БД!!!

    Хватает, но не с тем скудным набором действий из раздела "База". Ноду придеться подключать, тот же самый гемор как и Mysql.
    Если выбирать между 2 геморами я выберу Mysql.

  • 0 Votes
    10 Posts
    753 Views
  • 1 Votes
    4 Posts
    2005 Views
  • 0 Votes
    2 Posts
    472 Views
  • 0 Votes
    3 Posts
    529 Views
  • 0 Votes
    5 Posts
    1139 Views