Задать вопрос
  • Как вывести строки с бд в зависимости от их количества с ограничением?

    @Vitsliputsli
    Наверное, потому что:
    PDOStatement::fetch — Извлечение следующей строки из результирующего набора
    в то время, как есть:
    PDOStatement::fetchAll — Выбирает оставшиеся строки из набора результатов
    Ответ написан
    Комментировать
  • Какие проблемы с сетью решаются низкоуровневой отладкой?

    @Vitsliputsli
    Подскажите, какие проблемы с сетью реально встречаются на практике, которые можно обнаружить и решить таким способом?

    Проблем много и разные.
    Касательно неправильного порядка доставки TCP-пакетов, то такое возможно при балансировке нагрузки на несколько каналов, которые работают с разной скоростью.
    Или, например, при использовании в сети шифрования, видел такое на Dionis DPS, из-за распараллеливания расшифровки.
    BPF ничего не решает, только помогает обнаружить. Насколько BPF позволяет легче диагностировать трудно сказать.

    Может, что-то можно эмулировать на виртуалках?

    А зачем? Есть же tc, с возможностью эмуляции различных сетевых проблем.
    Ответ написан
    Комментировать
  • Почему выдает ошибку bash: npm: command not found?

    @Vitsliputsli
    Ну раз bash пишет что команда "npm" не найдена, вероятно стоит установить npm.
    Ответ написан
  • Взаимосвязанные сайты?

    @Vitsliputsli
    У каждого сайта есть свой сервер, своя статика и своя база данных. И все эти сервера находятся далеко друг от друга.

    Например XDCR.
    Ответ написан
    2 комментария
  • Какой будет ответ var_dump(0 == "wow"); ??

    @Vitsliputsli
    Нет, не так.
    В 7 версии: т.к. сравниваем число и строку, то преобразовываем строку в число (int)"wow" = 0, и сравниваем результат: 0 и 0 - true.
    В 8 версии: т.к. сравниваем число и строку, то проверяем содержит ли строка число, в данном случае - нет, не содержит (что-то вроде is_numeric("wow")), а раз не содержит - false.

    Отсюда вывод, не стоит использовать подобные конструкции. Всегда пользуйтесь сравнением с учетом типов, если нужно, то приводите к нужному типу вручную. Такая конструкция возможна только в самом крайнем случае.
    Ответ написан
    2 комментария
  • Стоит ли использовать эти настройки для pdo?

    @Vitsliputsli
    Немного погуглив выяснил что
    $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
    лучше не использовать.

    Да, лучше, если подразумевается вообще не указывать. PDO сам выберет лучшую настройку для конкретной СУБД.
    Ответ написан
  • Что лучше выбрать MariaDB or Mysql?

    @Vitsliputsli
    Лучше для чего?
    В сложных нагруженных решениях используют сборку Mysql от Percona, т.к. выбран нормальный движок для таблиц и отличные инструменты мониторинга. Большинство из них разработаны Percona. Отличные имеется ввиду для Mysql, для других решений бывает и лучше, и это не значит что mysql говно, просто везде свои плюсы и минусы.
    Хз почему ChairfaceChippendale пишет, что Percona куда-то канула, на последнем хайлоуде живее всех живых. Да и решения ни куда не исчезают, даже если бы и канула.
    Ответ написан
  • Как убедиться что сообщение дошло websocket?

    @Vitsliputsli
    В чате кроме онлайн отправки сообщений должен быть механизм отложенного получения. После соединения клиент проверяет накопившиеся сообщения. Периодически клиент проверяет потерянные сообщения. Если у сообщений последовательные ID, то по пропускам клиент также определяет потерянные сообщения.
    Как вариант контроль не на стороне клиента, а на стороне сервера. Тогда клиент подтверждает получение. Но это больше взаимодействий и хранения данных на стороне сервера.
    Ответ написан
    Комментировать
  • Как составить запрос для удаления строк, если таких строк больше чем X?

    @Vitsliputsli
    ROW_NUMBER, либо используйте переменную.
    Ответ написан
    Комментировать
  • Вирусы это частое или редкое явление?

    @Vitsliputsli
    Именно так, вирусов практически нет. Наверное, потому что они теперь легко перехватываются антивирусами. Но не уменьшилось кол-во других вредоносных программ, те же трояны, которые расчитывают на невнимательность и неосторожность пользователя. Дошло до того, что теперь вирусами называют любой вредоносный код в том числе трояны.
    Ответ написан
    Комментировать
  • В чем проблема с битностью у auditd?

    @Vitsliputsli
    Перепутаны местами список и действие, и путь до файла нужно указывать. Примерно так:
    auditctl -a exit,always -F arch=b64 -S open -F path=/etc
    Ответ написан
    Комментировать
  • Потенциальные проблемы программиста без послешкольного образования?

    @Vitsliputsli
    Может произойти. Тем более неизвестно как все сложится в жизни.
    Не хочется тратить 5 лет, есть заочное образование, за относительно небольшие деньги, показываясь раз в год, можно получить полностью официальную бумажку.
    Ответ написан
    Комментировать
  • Как через PHP запустить Python скрипт через pipenv?

    @Vitsliputsli
    Как и любую другую внешнюю команду - через system, exec или другую команду, которая больше подойдет.
    Ответ написан
    Комментировать
  • Что такое API в PHP?

    @Vitsliputsli
    "API - это интерфейс, для работы с какой либо сущностью/объектом/классом/бд"

    В какой-то степени - да. Но я бы определил так:
    API - это контракт между системами, каким образом данные передаются от одной к другой, т.е. некая спецификация описывающая формат обмена. Благодаря наличию контракта каждая из систем может однозначно определить, что запросила или ответила другая система.

    Здесь есть важные моменты: обе системы в курсе о спецификации и она не оставляет возможности иного толкования.
    И, кстати, зачастую эти системы могут быть написаны на разных языках, или переписаны на другие языки, но формат обмена остается универсальным, и одним и тем же.
    Ответ написан
    Комментировать
  • Как передать на бекенд требования к API?

    @Vitsliputsli
    Многие фронтендеры относятся к беку, как к некой обертке для работы с базой данной. Когда такие становится лидом команды и начинают диктовать свои требования беку, начинается ад, проект даже с простым беком превращается в нечто монструозное, разваливающиеся на ходу. Но, так как снаружи бек не виден, руководство считает, что дело в отдельных тупых бек-разработчиках, которые артачатся, не хотят работать и увольняются.
    Судя по вашим фразам, вы скорее всего один из них. Так как уверены, что приложение - это то, что на фронте, что api - это хрень, которая завязана на отображении информации на фронте, что разработчики бека не нужны при разработке архитектуры и вообще пофиг, что они там делают, главное чтобы давали то, что хочет фронт.
    Но, раз вопрос задан, значит сомнения вас посещают. Поэтому: приложение это не только фронт, а зачастую фронт это не самая сложная его часть. Бек - это не обертка над базой данных, и если вы поменяете значение в базе, это не значит, что к примеру, в потоковом вещании сменится кодек (вот, кому-то может и смешно, а мне в такой ситуации ни фига не было весело). С помощью API получают данные, поэтому не важно, что там у вас напроектировали дизайнеры, или как эти данные выводит фронт, API должен быть универсальным и не зависить от того как вы отображаете данные, поэтому, к примеру, бек может вам дать для получения данных несколько универсальных запросов, а не один специальный. В общем, все гораздо сложнее, и ваш вопрос как состыковать фронт и бек перерастает в вопрос как формировать архитектуру проекта, и как управлять командой.
    Ответ написан
    17 комментариев
  • Php socket create ошибка соединения при множество запросов, как победить?

    @Vitsliputsli
    Смотрите логи ошибки соединения.
    Проверьте кол-во одновременных соединений, если примерно в районе 1000, то вы скорее всего наткнулись на лимит файловых дескрипторов.
    Дело в том, что php создает для каждого коннекта файл, лимит кол-ва файловых дескрипторов на один процесс по-умолчанию, чтото вроде 1024. Насколько помню, это лимит ОС и лимит php. Поэтому нужно увеличить лимит в Linux, и придется пересобрать php с большим кол-вом.
    Либо использовать любой другой язык, без подобных заморочек. Во всяком случае, на python и go, подобных проблем нет, они не используют файловые дескрипторы для каждого соединения.
    Ответ написан
    2 комментария
  • Golang и PHP, дань моде или необходимость?

    @Vitsliputsli
    Если в проекте есть критичные места, которые нужно ускорить, но упираемся в скорость работы интерпретатора php, то берём go.
    Go достаточно простой и высокопроизводительный язык. Но скорость разработки на нем значительно ниже, чем на php.
    Ответ написан
    4 комментария
  • Как защититься от двойного списания в многопоточном приложении?

    @Vitsliputsli
    Блокировки в базе - это всегда не очень хорошо, а с serializable производительность базы упадет в пол. Констрейнт как вариант, но поможет только для этой ситуации и получится, что логику перетащили в базу.
    Самый оптимальный вариант, просто поделить работу между отдельными потоками, т.е. конкретного пользователя обслуживает конкретный поток и никакой другой, тогда гонки не будет в принципе. Но это если у вас архитектура позволяет.
    Ответ написан
    Комментировать
  • Как протестировать производительность функций начинающему php-разработчику?

    @Vitsliputsli
    Этот разработчик имел ввиду, что вы "гоняете через аргументы" является свойством класса, и таковым и надо его сделать. Нет смысла это задавать извне, если это неизменяемая часть класса.
    А потому, скорее всего никакой речи о "борьбе за ресурсы" не было и в помине.
    Если вы предлагаете передачу объекта через аргумент функции заменить на создание еще одного объекта, значит вы плохо представляете, как и на что выделяется память. Оставьте это пока, разберитесь с зависимостями в коде.
    Вообще странная вещь для разработчика описывать код словами, там все так плохо, что из кода вообще ничего не понятно?
    Ответ написан
  • Почему Windows 10 не понимает символических ссылок Linux?

    @Vitsliputsli
    Не надо заставлять Windows это понимать. Не используйте ссылки в коде проекта, они там не нужны.

    цель символической ссылки - чтобы web-сервер Nginx понимал обращение по адресу символической ссылки к файлам, которые на самом деле "лежат в другом месте".

    Если вы используете ссылки на сервере, чтобы переключаться на новые версии кода, то это не имеет никакого отношения к самому коду. Если вы используете ссылки на сервере, чтобы построить какой-то роутинг, то вы явно что-то делаете не так.

    В крайнем случае, не работающая ссылка не отменяет, что файл существует по оригинальному пути.
    Ответ написан
    Комментировать