Как стать автором
Обновить

Java-программист в Петербурге. Обзор рынка труда с точки зрения соискателя. Часть 3/3. Какие бывают работодатели

Время на прочтение6 мин
Количество просмотров35K
Часть 1/3. Какие бывают 'плюшки'.
Часть 2/3. Подводные камни для «новичка».

Какие бывают работодатели. Характерные особенности.


Вместо краткого вступления, одну закономерность можно назвать сразу: чем длиннее и крупнее проект, тем древнее технологии. Хотите на практике освоить новые технологии — участвуйте в стартующих проектах длиной 3-6 месяцев.

  • Фирмы, работающие на Министерство обороны и подобные структуры.
    Секретность, используется относительно узкий набор технологий — которые сертифицированы в ФСБ. Например, Java 1.6 и Tomcat сертифицированы, а EJB-контейнеры не сертифицированы, вместо них может использоваться самописная недо-пародия. Что хорошего в самописных недо-пародиях — разработчик, что обычно рядом и доступен для общения, что плохого — какая-то мелкая функция, которая есть, но её пока (почти год) не использовали, но которая внезапно понадобилась тебе, — может просто тупо не работать (но можно заставить разработчика быстро починить).

  • Фирмы, разрабатывающие продукт на собственных, старых и кастомных платформах.
    Бывают и EJB 2.0 без аннотаций и собственные недо-ORM 1999 года выпуска (*)и прочие самописные недо-пародии и “системы, управляемые метаданными”. Самое плохое в этих платформах, с точки зрения человека, привыкшего оценивать платформы и языки в значительной степени по лёгкости рефакторинга (пишущие на PHP, Python, Ruby и NodeJS могут выказать недовольство, но я пишу в первую очередь про Java), — это отсутствие поддерживающих эти изобретения нормальных IDE-плагинов для редактирования этих управляющих метаданных не в сыром текстовом виде и недостаточный уровень средств отладки и диагностики этих систем. По последнему пункту — ну это как если бы виртуальная машина Java вместо бросания NPE с дампом стека просто бы падала из-за ошибки уже в самом своём бинарнике, вызванной попыткой всё же получить что-то там от объекта, который находился бы по этому неинициализированному указателю “в никуда” или «куда-то» или «непонятно куда» (через раз в новое место) (о безопасности, разумеется, при этом можно забыть), скупо что-то сообщая об этой вызванной входными данными ошибке в интерпретаторе — так что даже поиск ответа на вопрос “в каком месте метаданных (в данном случае в роли метаданных выступает программа на интерпретируемом данным интерпретатором языке) находится ошибка” может сам по себе оказаться нелёгкой задачей. Отдельный вопрос — качество кода с методами по 2000 строк и интенсивным переиспользованием переменных. Причина обычно проста: эти системы (точнее, их первые версии) написаны ещё до того, как понятие “качество кода” стало в России в ходу (а ещё и понятие «ORM» и представление о том как адекватно строить систему персистирования объектов).

  • Фирмы, работающие по заказам от гос- и муниципальных структур.
    Разные сочетания длительности проекта и новизны технологий. Практически неизбежна, на определённом этапе, интеграция через SOAP с серверами госведомств с геморроем на тему что делать с участком этой интеграции на стадии отладки и тестирования. Иногда строгий дресс-код с пиджаком и галстуком. Нередко требуется писать на других языках, кроме Java.

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

  • Фирмы, разрабатывающие софт (на Java) для работы на финансовых рынках.
    Ключевые требования к софту — быстрота (в частности, по части оптимизации под сборщик мусора) и многопоточность. Может требоваться разработка встроенного мета-языка то ли пере-настроек то ли недо-программирования.

  • Фирмы-оффшорные разработчики.
    Основное требование — встраиваться в бизнес-процессы заказчика. Для этого нужно не отличаться от заказчика на взгляд руководства заказчика, т.е. по крайней мере не отличаться от заказчика больше, чем одни его подразделения отличаются от других подразделений.

    Качество кода — особый “пойнт”. Писать код нужно лучшего качества, чем программисты самого заказчика. Основное требование к качеству — чтобы не было в коде ничего такого, к чему можно было бы придраться, в основном сходу: чтоб никто из штатных работников заказчика не мог просто так подойти, ткнуть в какое-нибудь место в коде и с полным на то правом сказать “а чо за хрень они тут написали”. Бывает, дело доходит до требований писать комментарии к геттерам и сеттерам. Ещё момент: нужна овер-коммуникация — чтобы заказчик был (у)спокоен. Несколько напоминает ситуацию обращения с “VIP-пациентом в психушке”, но именно этот “VIP-пациент” и платит деньги.

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

    Это опыт который стоит иметь. «Культура производства» тут обычно выше, чем в российских компаниях, потому что намного сильнее поставлены учёт и отчётность: тот, кто платит деньги, хочет знать, на что их потратили. Технологии тоже новее: ориентация на короткие проекты повышает формализованность и “свежесть” используемых технологий.

  • Подразделения иностранных компаний.
    В основном похоже на отечественные “Фирмы, разрабатывающие продукт на собственных, старых и кастомных платформах”, только несколько получше с формализацией, проработанностью решений, технологической дисциплиной и прочей культурой производства. Используемые технологии тоже новизной не блещут. Но платят обычно неплохо.

  • “ИТ-компании”, обслуживающие итернет-тотализаторы.
    “Хитрая” работа с БД — без domain-объектов, с domain-методами и “голыми” идентификаторами, на зато быстро. “Экзотические” и малораспространённые web-фреймворки. Большая “текучка новичков” (испытательный срок проходит около половины принятых на работу) и некоторая ориентация рабочего процесса на эту большую “текучку новичков”.

  • “Программистские” отделы не-ИТ-компаний.
    Бывает разное. Самое плохое, что вы будете подчиняться распорядку рабочего дня предприятия, а не тому, который удобен для работы программиста. Особенно же “веселит” ситуация с соответствующими отделами компаний, держащих во внутренней сети компании (единой для всех предприятие) клиентские базы и прочую «чувствительную» конфиденциальную информацию, и этого из-за замороченных на безопасности. Там “рулят” безопасники. С их точки зрения нет понятия “разработчик”, а есть только понятие “сотрудник”. Представления у безопасников такие: Рабочая среда настраивается один раз и по запросу обновляется сотрудниками хэлпдеск… Каждый должен заниматься своим делом — программист программировать на предоставленном инструменте, техподдержка — поддерживать актуальное состояние ПО и решать технические вопросы пользователей, системные администраторы — администрировать инфраструктуру, а сотрудник отдела ИБ — контролировать соблюдение условий безопасной работы IT-сервисов предприятия. Заметим: «программировать на предоставленном инструменте». Т.е. чтобы не висеть у программиста “гирей на ногах”, пресловутый «хэлпдеск» должен не хуже, чем программисты, разбираться в “предоставленном инструменте” — средах разработки, виртуальных машинах, средствах работы с базами данных типа SQL Developer и прочем инструментарии. Ведь такая же картина с уровнем знания софта имеется в отношении других “сотрудников” типа секретарей, инженеров, юристов, продажников и снабженцев. Далее вопрос: зачем с такими скиллами работать в техподдержке, если программистом с ними же заработать можно больше? Поэтому нормальная, в общем-то, «техподдержка» для нормального, в общем-то, программиста непременно будет «дубиноголовым вахтёром», постоянно мешающим работать.

    Из-за этого в таких компаниях постепенно приходят к разумному выводу, что лучше «внутри» ничего не разрабатывать, разработку отдавать “вовне”, а «внутри» только ставить задания подрядчику, взаимодействовать с ним и готовить для него специально обезличенные “игральные” данные для отладки.

    Но ради строчки в резюме (хотя кто ещё из знающих реальный расклад на неё “поведётся”?) поработать можно…

  • Фирмы, сдающие персонал в аутсорс (аутстаффинговые, в первой редакции не совсем точно названные «аутсорсинговые фирмы»).
    Могут заниматься не только сдачей персонала в аренду, а ещё и сами что-то разрабатывать. Ну тут как повезёт (на том проекте, куда «зааутсорсят»). Из минусов — практически никакой перспективы служебного роста (и по части профессионального роста перспективы слабые) и плоховато со стабильностью. Из возможных плюсов — могут «зааутсорсить» за границу, можно посмотреть IT-культуру разных народов, в этом варианте пока ждёшь визы или старта проекта — можно вообще не появляться на работе, только оставаться «в пределах досягаемости».


Вместо заключения.


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

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


  • Android-разработчики.
    «Тоже Java, хотя и не совсем Java». Растущий сектор рынка труда. Автор с этим сектором пока не соприкасался, хотя с технической стороной программирования по Android чуть-чуть знаком.

  • «Одноклассники», прочие социальные сети и другие высоконагруженные системы.
    NoSQL-базы данных, map-reduce-системы типа Hadoop, многоступенчатые собеседования с целью отобрать «лучших из лучших» (*). К этой же сфере относится часть сектора онлайн-игр — там через Hadoop с обработчиками «пропускаются» в реальном времени события, происходящие в игре (каждый отдельный игровой сервер генерирует свой поток событий).

  • Хостеры-сайтостроители-сайтодержатели с CMS.
    Как это ни могло бы на первый взгляд показаться странным, но CMS на Java всё же существуют. Как зарубежные лицензированные (с исходниками), так и полностью отечественные — в частности, на базе того самого «недо-ORM» 1999 года выпуска. Соответственно, и услуги Java-программиста там тоже бывают нужны — хотя бы для развития и модернизации CMS.



Часть 1/3. Какие бывают 'плюшки'.
Часть 2/3. Подводные камни для «новичка».
Теги:
Хабы:
Всего голосов 73: ↑53 и ↓20+33
Комментарии30

Публикации

Истории

Работа

Java разработчик
405 вакансий

Ближайшие события

27 августа – 7 октября
Премия digital-кейсов «Проксима»
МоскваОнлайн
20 – 22 сентября
BCI Hack Moscow
Москва
24 сентября
Конференция Fin.Bot 2024
МоскваОнлайн
24 сентября
Astra DevConf 2024
МоскваОнлайн
25 сентября
Конференция Yandex Scale 2024
МоскваОнлайн
28 – 29 сентября
Конференция E-CODE
МоскваОнлайн
28 сентября – 5 октября
О! Хакатон
Онлайн
30 сентября – 1 октября
Конференция фронтенд-разработчиков FrontendConf 2024
МоскваОнлайн
3 – 18 октября
Kokoc Hackathon 2024
Онлайн
7 – 8 ноября
Конференция byteoilgas_conf 2024
МоскваОнлайн