Node.js #6 Буфер и потоки (Buffer & Streams)

Поделиться
HTML-код
  • Опубликовано: 20 янв 2025

Комментарии • 77

  • @flepjack
    @flepjack Год назад +7

    Друг, спасибо тебе за это видео. Это самое понятное объяснение, какое только может быть. Пересматриваю его каждые +- пол года, когда работаю со стримами, и каждый раз ставлю лайк, который уже стоит👍

  • @lumiuko
    @lumiuko 5 месяцев назад +1

    Спасибо! Я обычно на англоязычном ютубе ищу материал, но даже там нет нормального объяснения. А здесь всё идеально

  • @Xeon83
    @Xeon83 3 года назад +3

    Мои поздравления! Вы наконец подобрали идеальную скорость подачи информации!

  • @An-cq6jx
    @An-cq6jx 2 года назад

    Чувак ты просто супер молодец! Как понятно все объяснил, таких мало в рунете. Огромное тебе спасибо, снимаю шляпу!

  • @LexasBY
    @LexasBY 3 года назад +2

    Спасибо большое за видосы! Ну просто очень своевременно! Сам сейчас в лабе и как раз вчера срез по Buffer & Streams сдал! ))

  • @RisDeep
    @RisDeep 3 года назад +14

    Спасибо. Было бы круто если бы было ещё больше реальных примеров использования с кодом

    • @YauhenKavalchuk
      @YauhenKavalchuk  3 года назад +3

      Во второй части курса будет больше практики

    • @vasiuta
      @vasiuta 2 года назад

      @@YauhenKavalchuk Вторая часть еще только в планах?

    • @MaksymTkachuk-k8j
      @MaksymTkachuk-k8j Год назад

      @@vasiuta тоже цікавить

  • @daymaker_trading
    @daymaker_trading 3 года назад +2

    Очень хороший урок. Спасибо!

  • @bahlulhasanli
    @bahlulhasanli 3 года назад +1

    The video was awesome. You explained it well with examples.

  • @ridl27
    @ridl27 3 года назад

    нормас, а с 2х ваще то что нужно! спс! и да, первый :D!

  • @qlmanlp
    @qlmanlp 2 года назад

    Благодарю, очень доходчиво и понятно стало

  • @AidosOmurzakov
    @AidosOmurzakov Год назад

    Объяснил чётко спасибо

  • @vasylp.4007
    @vasylp.4007 3 года назад +1

    лайк этому видео, еще до просмотра...))

  • @api-nsk
    @api-nsk 2 года назад

    Спасибо. Годное обучение

  • @ОльгаБайнова-ф4д
    @ОльгаБайнова-ф4д 3 года назад +1

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

    • @YauhenKavalchuk
      @YauhenKavalchuk  3 года назад

      Не уверен что такое можно сделать нативно, возможно понадобится дополнительный npm

  • @ruslan_lwow79
    @ruslan_lwow79 3 года назад

    Дякую , курси чіткі!

    • @YauhenKavalchuk
      @YauhenKavalchuk  3 года назад

      Спасибо большое за отзыв

  • @gyros9162
    @gyros9162 2 года назад

    Спасибо! Было бы классно услышать от вас про работу с потоками в циклах.
    Например, когда нам нужно из нескольких файлов записать данные в один файл (стили, например)

    • @YauhenKavalchuk
      @YauhenKavalchuk  2 года назад

      Спасибо за отзыв. Но курс закончен, не думаю что буду дополнять его новыми лекциями

    • @amelianceskymusic
      @amelianceskymusic 2 года назад

      ​@@YauhenKavalchuk Жаль, я тоже уже обыскался подобного материала, перенести данные из одного файла в другой могу и вроде все корректно, но стримы как буд то делают это параллельно, и никак не получается после каждого отдельного этапа чтение/запись добаить что -то по типу:
      Файл 1 открылся
      Файл 1 записался
      Файл 2 открылся
      Файл 2 записался
      Файл 3 открылся
      Файл 3 записался
      Получается только:
      Файл 1 открылся
      Файл 2 открылся
      Файл 3 открылся
      Файл 1 записался
      Файл 2 записался
      Файл 3 записался

  • @mikitanikolaev9212
    @mikitanikolaev9212 3 года назад +4

    Спасибо за видос. Но хочу обратить внимание на пару моментов.
    Чанк не обязательно должен быть буфером, можно в base64 кодировать. Буфер это просто бинарное представление данных в node.js. Stream в Nodejs !== Stream в HTTP. Стрим в ноде это просто класс предоставляющий возможность читать и писать почанково, а в HTTP нету стандарта, каждый свой придумывают как передавать почастям данные.

    • @YauhenKavalchuk
      @YauhenKavalchuk  3 года назад

      👍

    • @dimendroider7550
      @dimendroider7550 2 месяца назад

      Я тоже заметил, что чанк это совсем не буфер )))

  • @белка-у8б
    @белка-у8б 3 года назад +1

    Теперь за собес можно и не бояться))

  • @dimalukashenko4865
    @dimalukashenko4865 3 года назад

    Отличное видео!

  • @rayetzki
    @rayetzki 3 года назад +3

    Для обработки ошибок лучше использовать pipeline из того же пакета, , а не pipe, по-моему начиная с 12 Ноды доступен. У pipe есть утечки памяти при ошибках во время исполнения

  • @AAndreev1983
    @AAndreev1983 10 месяцев назад

    а что запускает чтение файла? В прошлом уроке было this.emit и это был вызов события и далее уже срабатывал logger.on. Тут же мы создаем поток чтения и назначаем его в переменную и тут же срабатывает readStream.on.... readStream это же прослушиватель? что его активирует, почему нет чтото вроде readStream.emit чтобы запустить чтение потока?

  • @ДаниярАбсат
    @ДаниярАбсат Год назад

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

  • @VladislavSnegurov
    @VladislavSnegurov 2 года назад +1

    На сколько я понимаю, пайп это не дуплексный поток чтения. Может в качестве абстракции для новичков, таковым его и можно считать, но как по мне это только больше вводит в заблуждение. По дуплексному каналу обе стороны могут одновременно читать и писать. В случае же с пайпом - это вектор в котором одно сторона постоянно пишет, а вторая может только читать. Это наглядно видно на примере с bash пайпами, где для дуплексного чтения есть специальные "named pipes"

  • @ivanmorozov6197
    @ivanmorozov6197 5 месяцев назад

    Возможно глупый вопрос, но можно ли каким то образом не вычитывать чанки в память, а писать сразу в файл? К чему я, если одновременно очень много пользователей начнут читать файл, не выжрет ли это всю оперативную память на сервере?

  • @obivanbeluii
    @obivanbeluii 3 года назад

    👍👍👍

  • @РостиславЕрмолаев-п5ф
    @РостиславЕрмолаев-п5ф 2 месяца назад

    аааааааааааааааааа ). Спасибо!

  • @elconrel9665
    @elconrel9665 2 года назад

    Подскажите, после прохождения данного курса можно считать свои знания по ноде базовыми ?

  • @ylvpro6878
    @ylvpro6878 3 года назад +1

    А где вы изучили node.js?

    • @YauhenKavalchuk
      @YauhenKavalchuk  3 года назад +1

      По таким же курсам, статьям, документацию листал

    • @ylvpro6878
      @ylvpro6878 3 года назад +1

      @@YauhenKavalchuk понял, большое спасибо

  • @stasostrin47
    @stasostrin47 3 года назад

    Про CORS будет информация?)

  • @dec232
    @dec232 Год назад

    Из-за чего может не сжиматься файл? Все вроде точно повторил, а созданный файл остается не сжатым.

    • @YauhenKavalchuk
      @YauhenKavalchuk  Год назад

      Сверьте с кодом из репозитория

  • @akuma8865
    @akuma8865 2 года назад

    Подскажите пожалуйста почему handleError вызывается дважды но срабатывает единожды?

    • @YauhenKavalchuk
      @YauhenKavalchuk  2 года назад +1

      Потому что как только он падает в первом случае, выполнение останавливается. Поэтому второй и не вызывается

    • @platinum356
      @platinum356 Год назад

      Нет смысла вешать обработчик события error дважды. Автор ошибся, сказав, что обработчик имеет смысл до pipe и после. Независимо от того, перед или после пайпа вы повесили обработчик ошибки, он вызовется.

  • @dimendroider7550
    @dimendroider7550 2 месяца назад

    Почему мы импортируем модуль 'fs' а не 'node:fs' ???

  • @rakhymbeksagyn2835
    @rakhymbeksagyn2835 3 года назад

    модуль "util" оказывается устарел (deprecated). Классический вариант "extends" лучше использовать. ES6

  • @kr4chinin771
    @kr4chinin771 2 года назад +1

    Распаковать данные из последнего примера можно с помощью создания потока const decompressStream = zlib.createGunzip().
    Нужно создать читающий поток из файла со сжатыми данными (const decompressReadStream = fs.createReadStream("директория-файла-со-сжатыми-данными")) и создать новый записывающий поток (const decompressWriteStream = fs.createWriteStream("директория-файла-для-записи-распакованных-данных")), далее с помощью схожей цепной структуры можно сначала распаковывать данные, а затем записать их в новый файл:
    decompressReadStream
    .pipe(decompressStream)
    .pipe(decompressWriteStream)
    На выходе получим распакованные данные в новом . txt файле (если захотите повторить этот код - лучше вынести его в чистый .js файл)