{"id":14275,"url":"\/distributions\/14275\/click?bit=1&hash=bccbaeb320d3784aa2d1badbee38ca8d11406e8938daaca7e74be177682eb28b","title":"\u041d\u0430 \u0447\u0451\u043c \u0437\u0430\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u044e\u0442 \u043f\u0440\u043e\u0444\u0435\u0441\u0441\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0440\u043e\u0434\u0430\u0432\u0446\u044b \u0430\u0432\u0442\u043e?","buttonText":"\u0423\u0437\u043d\u0430\u0442\u044c","imageUuid":"f72066c6-8459-501b-aea6-770cd3ac60a6"}

Node.js: карьерный обзор 2019 года

Микроисследование ИТ-специализированного кадрового агентства Spice IT Recruitment о текущей ситуации на рынке труда Node.js-разработчиков.

Мы в Spice IT уже десять лет занимаемся подбором ИТ-специалистов, поэтому знаем инсайты (и инсайдеров!) рынка каждой из профобластей.

Ведущий консультант Spice IT Юлия Артемова поговорила с тимлидами компаний, использующих Node.js в разработке, а Юлия Попова оформила результаты этих интервью в яркие иллюстрации.

Кроме того, в конце материала будет тест, (ладно, тут он тоже будет, вот он) с помощью которого можно спрогнозировать, за какое время у вас закроется вакансия разработчика вообще, и Node.js-разработчика в частности. Особенно полезен этот тест будет для ИТ-рекрутеров, а также для нанимающих менеджеров со стороны компаний.

По данным исследования Stackoverflow, Node.js, наряду с JavaScript, лидирует в рейтинге наиболее желанных и часто используемых технологий. А вот еще какие тренды мы выделили по результатам опросов наших респондентов.

Несмотря на то, что Node.js постоянно меняется, требования к разработчикам остаются — в общих чертах — неизменными.
Тимлиды как нанимающая сторона ждут от джуниоров базовых знаний JS, от мидлов — умения работать с фреймворками, а от синиоров — способности самостоятельно решать абстрактные задачи.

Медианные зарплаты начинаются от 50 тысяч рублей (для джуниоров) и достигают 250 тысяч рублей (для синиоров).

Востребованность разработчиков каждого из грейдов легко оценить по количеству офферов за две недели активного поиска.

Какие скиллы делают выше стоимость разработчиков на рынке труда:

  • RabbitMQ, Kafka.
  • Elastic Search.
  • Docker, Kubernetes.
  • Опыт с Highload.
  • Свободный английский.

Для мидлов зарплатная вилка при наличии вышеперечисленных навыков уверенно приблизится к 180 тысячам рублей. Для синиоров — к 250 тысячам рублей.

Прокачивать скиллы можно (и нужно!) с помощью постоянного самообразования. Вот несколько книг, горячо рекомендованных нашими респондентами к изучению.

Для джуниоров:

Для мидлов:

Из российских компаний Node.js в разработке используют (just to name a few): Rambler, «Яндекс», МТС, «Лаборатория Касперского», «ВКонтакте», EPAM, 2GIS, OneTwoTrip, «Сбербанк», Leroy Merlin, FxPro, Zecurion, LATOKEN, Waves, «Туту.ру», «Сравни.ру», Altarix, «Тинькофф», MERA, Profi.ru.

Из зарубежных (опять же just to name a few): PayPal, Netflix, Uber, LinkedIn, Ebay, Walmart, Medium, GoDaddy, Mozilla, Trello.

Если вы уже ищите или в скором времени планируете искать работу как Node.js-разработчик, наши респонденты советуют обратить внимание в первую очередь именно на эти компании.

В качестве бонуса (для тех, кто дочитал) мы составили несложный тест из 15 вопросов, честно ответив на которые, вы поймете, сколько времени у вас уйдет на закрытие вакансии разработчика.

0
132 комментария
Написать комментарий...
Anrey Myagkov

Сразу видно, что люди пишущие комменты про колбеки, ад в сложных проектах и прочую чушь, ничего кроме js на фронте в в проектах начала нулевых или по-свежее, но написанного Васей, пишущим на php и нежелающим вникнуть в область, не видели...

Ответить
Развернуть ветку
Влад Виолентий

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

Ответить
Развернуть ветку
Alexander Perlamutrov

Пакет нужен ровно один - либа для работы с базой. Где здесь хотя бы один колбек?

```

const conn = Pool.connect('DSN');

const user = await conn.query({

  text: 'SELECT * FROM users WHERE id=$1',

  values: [1],

  name: 'select_user'  // Prepared statement's name

});

```

И тут, внимание, киллер-фича - параллельное выполнение запросов к базе:

```

const [users, products] = await Promise.all([

  conn1.query(),

  conn2.query()

]);

```

И если в питоне так сделать можно при помощи дополнительных библиотек, то в PHP вообще не уверен.

Ответить
Развернуть ветку
Alex

Сомнительная фича, конечно. Тут только одно преимущество: если клиент использует пул подключений, то запросы уйдут по разным соединениям параллельно.

Но тут именно преимущество самого ивент лупа, а не клиента БД.

Ответить
Развернуть ветку
Alexander Perlamutrov

Да, это преимущество Node.js в целом. Фича очень крутая. Только подумайте, у вас один процесс на PHP может обрабатывать только один клиентский запрос одновременно, а один процесс на Ноде - 1000 клиентских запросов, если основное время при генерации ответа уходит на ожидание ответов от базы или внешних API.

Ответить
Развернуть ветку
Влад Виолентий

php-fpm, не?

Ответить
Развернуть ветку
Alexander Perlamutrov

Нет. PHP-FPM - это менеджер пула процессов. Но каждый процесс в пуле обрабатывает одновременно всего один запрос. Таким образом, если у вас сервер с 8 ядрами, вы можете поднять 8 процессов-воркеров, каждый из которых будет обрабатывать по одному запросу одновременно. Получается, что пропускная способность вашего сервиса - 8 конкурентных запросов. Например, если сервис ходит несколько раз в базу данных или какой-нибудь внешний API, и отвечает за 200мс, то вы сможете выжать из него 40 RPS.

Node.js базируется на эвент-лупе с неблокирующим IO. Все сетевые, файловые операции - неблокирующие. Поэтому даже в рамках одного процесса после того как он отправит запрос в базу, он не будет тупо ждать ответа как в PHP, а продолжит обрабатывать другие входящие запросы. То есть один процесс-воркер сможет обрабатывать от 1 (если сервис занимается CPU-вычислениями, никуда не ходит) до 1000 (если сервис ходит в базу и внешние API, а из вычислений только парсинг запроса и сериализация ответа) одновременных запросов. Таким образом в теории вы можете получить до 40000 RPS с 8-ядерного сервера.

Ответить
Развернуть ветку
Влад Виолентий

Если API отвечает 200 мс - значит его надо кешировать.

и как отметили в комментарии - есть reactphp, swoole

Ответить
Развернуть ветку
Alexander Perlamutrov

Ну и как, много проектов вы сделали на reactphp или swoole? А прелесть Node.js в том, что даже начинающий разработчик сделает свой сервис более производительным "из коробки". И для этого не нужно осваивать дополнительные фреймворки/библиотеки или изучать синтаксис го-рутин. Вот и вся разница.

Ответить
Развернуть ветку
129 комментариев
Раскрывать всегда