nuclight: (Default)
[personal profile] nuclight
Три недели назад Андрей Шетухин, руководитель отдела почты Rambler, сообщил о начале миграции своего почтового кластера (порядка 500 серверов) с FreeBSD на Linux (Debian/Ubuntu), поскольку FreeBSD перестала его устраивать. Дискуссия в комментах, которых уже более полутысячи, разгорелась нешуточная. В комментах также стало известно, что аналогичный переход планирует Яндекс на своем поисковом кластере, который в данный момент работает целиком на FreeBSD, а это примерно 25000-30000 серверов, и порядка 60% мощностей Яндекса. Такая потеря — это для FreeBSD уже серьезно. С такими тенденциями система, к радости ликующих подонков, станет таки умирать.

Очевидно, что подобные решения не принимаются на ровном месте, и существуют определенные причины, проблемы, которые мы, FreeBSD, можем начать исправлять, пока не стало слишком уж поздно. BSD-сообщество привыкло закрывать глаза на многие проблемы, считая их несущественными. Более так поступать нельзя — легко списать всё на тараканы в голове менеджмента и ничего не делать, вот только постоянное повторение такого образа действий приведет к тому, что лет через 5 работу BSD-администратора будет уже не найти (Вы такую перспективу себе хотите? Я лично — нет). Однако, с другой стороны, тот же Шетухин 3 месяца назад писал "Вывод простой: миграция на Linux нецелесообразна, так как затраты на нее не окупятся" о том, что разницы в производительности FreeBSD и Linux для их целей не выявлено. То бишь, следует отделить зерна от плевел и решать те проблемы, которые действительно есть.

Таким образом, имеется два утверждения (которые будут более подробно рассмотрены далее), причем оба истинные и друг другу не противоречат:

I. Конкретно в случае Рампочты уход с FreeBSD затеян из-за неадеквата руководства, внутри у них полный бардак (по словам инсайдеров).
II. У FreeBSD действительно есть серьезные проблемы, нам необходимо их решать, иначе нам каюк.

По второму вопросу — в следующем посте предполагается анализ, каковы еще проблемы FreeBSD и как их можно решить, с опросом мнения читателей. Но сначала — о том, почему держателям акций Рамблера стоит продавать их, пока курс еще хороший.

Часть I. Конкретно в случае Рампочты уход с FreeBSD затеян из-за неадеквата руководства, внутри у них полный бардак (по словам инсайдеров).

Что выяснилось в процессе обсуждений как в комментах к посту, так и в других местах? Например, то, что проблемы и претензии Рампочты к FreeBSD были вызваны во многом их собственной спецификой. А именно, это закрытый отдел, и они не используют наработки остальной части Рамблера. В условиях больших систем нормально организовывать работу ведь следует как? Делается собственная сборка системы, часть машин выделяется под компиляцию (сборку пакетов), часть под тестирование. Этот процесс требуется всегда, какой бы там дистрибутив не стоял — даже с самым бинарным будет сделан свой локальный репозиторий, в котором собираются пакеты под задачи фирмы. И распространяются пакеты аналогично. Может быть видоизменен инсталлятор для автоматизации разливки на новые машины кластера, и т.д.

Но у них, в отделе почты, свой инсталлятор, они не пользуются, например, тем, что сделано у работающего в соседнем отделе Глеба Смирнова, коммитера FreeBSD. Из высказанных претензий складывается впечатление, что администраторам Рамблер-почты неизвестно ни про freebsd-update(8) — средство бинарного апгрейда базовой системы, имеющееся в ней уже 5 лет (обновляет в две простые команды, "скачать" и "поставить"). Ни про portmaster, написанная на чистом /bin/sh утилита обновления пакетов, альтернатива portupgrade — претензия к которому была, что он тянет за собой язык Ruby.

Аргументов было много, внятный перечень (я тут свёл воедино из нескольких разных комментов) был таким:
Ок. Давайте осилим тиндербокс. Давайте осилим бинарные обновления базовой системы и пакетов. Давайте подтянем версию FreeBSD к текущей. Давайте забьем на тупизну ipfw и убогость pf по сравнению с iptables. Давайте все собирать древним как говно мамонта компилятором. Давайте жить на ufs2. Давайте сделаем еще миллион прекрасных в своей глупости вещей, лишь бы не уходить с труъ-системы на негодный Линукс.

Все это прекрасно, но моим админам не платят за название операционки. Им платят за то, чтобы все работало. Сделать так, чтобы все работало на Линуксе, объективно проще, чем на FreeBSD. Пройдет еще 3-5 лет, и фря станет системой исключительно для маргиналов.

1. Убить такое понятие как монолитная base sysem, сделать набор пакетов для base system и для ports.
Компилировать и патчить мир в 2011 году — уебанство. Кроме того, куча вещеий из base system не нужны большинству юзеров. Значит, их и ставить не надо. Тот же bind, который не запускается на 99.5% серверов. Хрена он там делает в base system?

2. Отказаться от сборки пакетов как от основного способа установки ПО.
Пакеты должны ставиться из репозитория, и только. Нужно что-то свое — делайте набор ПО чтобы подключить локальный репозиторий на машине.

3. Сделать -STABLE репозиторий с пакетами, регулярно обновляемыми патчами.
Да, это напрягает — искать патч к X.Y.Z версии одного пакета только потому, что другой пакет хочет только ее.

4. Разработать систему автообновлений, позволяющую с минимумом головной боли содержать up-to-date систему. Ключевое слово: АВТОобновлений.

5. Самое важное: все это должно быть "из коробки", без доустановки и чтения инструкций.

Я ничего против портов не имею, это наоборот, очень удобно и классно. А вот к менеджеру пакетов претензии есть.

Серьезные ли это причины? Серьезные, хотя разбираться мы с ними будем позже. Но, однако в другом месте встречаем признание: "Собственно, все пертензии к деплойменту — невозможность в автомате с учетом всех требуемых зависимостей поднять версию системы и/или переустановить те пакеты, которые требуются. Это — прямое следствие использования pkg_*."

Решаема такая проблема с FreeBSD? В принципе, решаема, но требует скриптования. Вполне понятно и желание не заниматься рутинной работой, которую уже сделали другие. Другое дело, что максимально её сложить с себя можно только, если кто-то это будет делать на оплачиваемой основе. Вполне резонно следующее мнение: "Удивительно, что Rambler, ища стабильность и уверенность + иметь возможность своих админов отпускать вечерами домой к семье выбрали опять черти что, а не коммерческий RedHAT, где они получат любую консультацию почему у них что-то не работает. А ведь для такой конторы как Рамблер стабильность должна быть на первом плане, а они ищут халявки. позор."

Тут-то уже закрадываются подозрения, что не во FreeBSD дело — ведь, как резонно отмечали, даже конкретно Debian не уменьшит работу админов до нуля как по волшебству. Подозрения закрадываются в том, что текущие админы Рампочты попросту не в состоянии адекватно управляться с FreeBSD. Так ли это? [livejournal.com profile] slonik_v_domene пишет по этому поводу:
Из админов ушел ровно один человек, было это в конце весны 2009 года. Причины, по которым мы расстались очень просты и печальны: мы не смогли работать друг с другом. Тем не менее, расставание прошло без ругани и взаимных истерик. И несмотря ни на что, к этому человеку я испытываю уважение за профессионализм и умение твердо отстаивать свои принципы, даже ценой рабочего места.

Далее находится (в IRC) сам этот ровно один человек, это был [livejournal.com profile] ospf_ripe, и комментирует заявление "FreeBSD сложно майнтейнить" так:
Wed 22:46:44 <@citrin> nuclight: не очень понятно что там маинтейнить, а миграция будет очень сложно и трудозатратной (до прихода slonik-v-domene я работал в Рампочте и представляю что там есть внутри)
Wed 22:52:18 <@citrin> обсуждать не хочется и смысла не вижу. собственно я и ушел оттуда из за того, что с Шетухиным сложно вести конструктивный диалог. Он любит все решения принимать сам, ни с кем не советуясь и не аргументируя свою точку зрения.

Аналогичной точки зрения придерживаются и другие сотрудники Рамблера. В частности, известно, что оттуда в свое время уволился и Максим Дунин ([livejournal.com profile] mdounin). Сам [livejournal.com profile] slonik_v_domene от комментариев насчет него отказался, а Глеб Смирнов высказался по этому поводу так:
Tue 16:17:37 <@glebius> ну, если бы Максим был здесь, то я думаю слоник бы не начал этого манёвра
Tue 16:17:56 <@glebius> потому как начальству будет видно, что это просто перестановка мебели
Tue 16:18:11 <@glebius> а сейчас понимающего начальства нет, так что можно попереставлять

[UPDATE:glebius@ поправляет, что это был не [livejournal.com profile] mdounin, а maxim@freebsd.org]

По непроверенным слухам, [livejournal.com profile] slonik_v_domene работал ранее в компании СУП (которой принадлежит ЖЖ) и был оттуда уволен за примерно такие же действия — взять и устроить революцию работающей системы без оснований.

Прямых подтверждений тому у нас нет, зато косвенных — валом. Например, мной был задан вопрос, чего не хватает FreeBSD, как нам можно её улучшить. Ответом был приведенный выше перечень, что именно стоило бы сделать. Однако последовавшее за этим обсуждение показало странные вещи. Глава Рампочты никак не хочет признаваться, в какие же именно затраты рабочего времени администраторов (то есть в конечном счете финансовые затраты) выливается та или иная проблема FreeBSD. Например, еще более-менее понятно, чем плох BIND в базовой системе, хотя даже по этому вопросу конкретику с цифрами я почему-то получил от другого человека. А вот чем администратору мешает наличие в базовой системе какой-нибудь мелкой утилиты, скажем, make — уму непостижимо. Если она не используется — она вообще не требует внимания админа, лежит себе да лежит. Если её требует кто-то по зависимостям — она всё равно будет поставлена по зависимостям, что во фре, что в дебиане. Если всё ставить вручную — наоборот, требуется время админа на расстановку галок в инсталляторе (или его эквиваленте), никакого выигрыша...

Такой отказ в назывании конкретики говорит о том, что причины не технические. А тут еще выясняется что? Что из Рамблера по-тихому, 3 месяца назад, ушел Игорь Сысоев, автор известного web-сервера nginx. Итого, из Рамблера ушло уже трое. Между тем, внимания заслуживает еще такая цитата:
> что подходы рампочты к администрированию конкретно fbsd, мягко говоря, плохие.

Ну, плохие и плохие. Будет Линукс вместо FreeBSD, будут хорошие подходы. Что-то возразить по существу описанных с портами проблем есть?

Изменятся ли подходы от смены систем? Ни разу, "внезапная революция в мосгах, бывает ли такое". Подходы зависят от людей. Заблуждение о том, что есть "серебряная пуля", инструмент, с которым все проблемы сразу решатся, к сожалению, популярно... В другом треде в обсуждении [livejournal.com profile] slonik_v_domene также заявлял о том, что предпочтительны системы, с которыми справится и новичок. Он считает, что "первопричина — это не люди, а системы. А люди — следствие". В действительности же — именно люди, ключевым является именно персонал, а не инструменты. Нет смысла останавливаться на этом подробно и переубеждать того, кто до понимания положения "кадры решают всё" еще не дорос. Я просто процитирую по этому вопросу классика:
Выдающиеся проектировщики. Главная проблема совершенствования искусства программирования заключена, как всегда, в людях. [...] Выбор правильного метода проектирования определяет различия между плохим и хорошим концептуальным проектом, но не между хорошим и выдающимся. Выдающиеся проекты создаются выдающимися проектировщиками. Создание программ является творческим процессом. Крепкая методология может придать силу и освободить творческий ум, но она не может воспламенить или вдохновить того, кто занят нудной работой.
И разница немалая — это как Сальери и Моцарт. Одно исследование за другим показывают, что лучшие проектировщики создают структуры, которые быстрее, меньше по размеру, проще, понятнее и разработаны меньшими усилиями. Различия между выдающимся и средним достигают порядка величины.
[...]
Как растить выдающихся проектировщиков? Место не позволяет обсуждать это пространно, но вот некоторые очевидные шаги:
  • Систематически и как можно раньше выявлять первоклассных проектировщиков. Лучшие — не всегда самые опытные.

  • Назначить наставника, ответственного за рост перспективного проектировщика и тщательно следить за его карьерой.

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

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

(с) Фредерик П. Брукс. "Мифический человеко-месяц или как создатся программные системы".


В Рамблере же всё происходит с точностью до наоборот. Кроме того, Андрей Богородский прокомментировал, что штатная сетка рампочты привела его в тихий ступор — с точки зрения риск менеджемента два человека администраторов недостаточно даже для текущего саппорта, что уж говорить о развитии (чтобы от болезней/свадеб/отпусков не зависеть, по КЗОТу для обеспечения круглосуточной работы должно быть минимум 5 человек на клетку).

[UPDATE: Эта ситуация относилась к 2008 году. Как сообщает А. Шетухин, сейчас сисадминов хватает для покрытия всех суток.]

В довершение ко всему, глава Рампочты еще и относится наплевательски к сообществу и исповедует паразитизм, считая, что его должны носить на руках уже за сам факт использования системы. Этика между тем проста: ему дали систему забесплатно, он ничем разработчикам не обязан, но и не имеет права требовать от них ничего, а уж тем более вставать в позу и оскорблять кого-то. Вот если бы помог хоть чем-то (тот же Яндекс, скажем, помогал)... но он хамски требует. И, не получив, уходя, он предпочитает обосрать всех и вся. Может быть, и специалисты из Рамблера сбегают из-за такого отношения руководства?..

Как бы там ни было, потеря уже невелика. "С таким подходом через 3-5 лет Рамблером не будет пользоваться никто, кроме маргиналов". Прощай, Рамблер! А мы пойдем дальше разбираться со своими проблемами сами.

Часть II. У FreeBSD действительно есть серьезные проблемы, или мы их решаем, или нам каюк.

опубликована отдельным следующим постом

From: [identity profile] poige.livejournal.com
В том же pf PBR сделан слегка «через-жопно». Если использовать «pass in quick on … route-to (out_if $out_if_gw)», то следовало бы ограничить область действия данного правила, так, чтобы пакеты с TTL < 2 не forward'ились (согласно RFC). Но, увы, дремучий ipfilter могёт, а pf — нет. Есть конечно, отдельная область, типа «stealth gateway», но по-хорошему, зачастую на практике надо чтоб tracert из локалки честно показывал первый хоп, а не высвечивал IP провайдера. Так что там про дизайн вы говорили?… :-)
From: [identity profile] ru-pchel.livejournal.com
Спокойно :)
Вот лично мое очень скромное мнение - firewall-ы переоценены. Ну вот лично мне абсолютно хватает в большинстве случаев какого нибудь банального пакетного фильтра, который закрывает порты, открывает доступы с определенных ip-адресов. Да, я могу согласиться, может задачи не те. Но когда я вижу что делает народ с firewall-ами, надувая щеки и творя разные непотребства (неочевидные непростые решение, которые может и показывают их iq и выжимают все из firewall-а, но часто не только не помогают чему либо, а просто мешая этому), меня начинает все это искренне удивлять.

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

И каждый раз при обсждении firewall-а вкупе с rambler почтой я задумываюсь, а зачем rambler почте на рядовых, казалось бы тазиках мощные firewall-ные правила? Они боятся угрозы из локальной сети rambler-а? Подлянку с других отделов или как? Или на firewall-е пишется сложная логика маршрутизации и манипулирования ip пакетами? Если первое - то уж лучше протоколы динамической маршрутизации, если второе - freebsd netgraph очень даже мне показался для таких случаев.

Все написанное выше есть мое глубочайшее и скромнейшее imho.

> Спокойно :)

Date: 2011-08-03 07:52 am (UTC)
From: [identity profile] poige.livejournal.com
Вам показалось :)

Re: > Спокойно :)

Date: 2011-08-03 07:59 am (UTC)
From: [identity profile] ru-pchel.livejournal.com
А я думаю, что это вам показалось, что под словами "человеческая фантазия презирающая дизайн" я имел ввиду вас. Я даже в мыслях не держал, а вот вы все приняли на свой счет. Интересно почему?
From: [identity profile] poige.livejournal.com
Нет-нет, ну что вы. :-)
From: [identity profile] slonik-v-domene.livejournal.com
>И каждый раз при обсждении firewall-а вкупе с rambler почтой я задумываюсь, а зачем rambler почте на рядовых, казалось бы тазиках мощные firewall-ные правила?

Простите, вы работаете у меня в отделе? Если нет, то откуда вы знаете про то, какие правила и где у меня используются?
From: [identity profile] ru-pchel.livejournal.com
Прощаю. Не работаю у вас в отделе. И про ваши правила firewall-ные ничего не знаю. И с вашим отделом безопасности знакомится не хочу. Я лишь высказал свое мнение. Подчеркнув что оно мое, скромное и личное. Но вас таки оно задевает. Таки почему?
From: [identity profile] slonik-v-domene.livejournal.com
>Не работаю у вас в отделе. И про ваши правила firewall-ные ничего не знаю.

Тогда с какого хрена вы позволяете себе писать комменты в стиле "а зачем rambler почте на рядовых, казалось бы тазиках мощные firewall-ные правила"?

>Подчеркнув что оно мое, скромное и личное. Но вас таки оно задевает. Таки почему?

Задевает? Б-же мой, ну что за глупости? Мне более интересно не мнение, а причины, форимирующие его. Вот я читаю, и вижу, что либо тут отметился очередной пикейный жилет, рассуждающий безо всяких фактов, либо потенциальный клиент СИЗО, который считает что владеет коммерческой тайной.

Ну так и кто же вы на самом деле?
From: [identity profile] poige.livejournal.com
ХЗ. Я вообще, бегло почитав «объяснительные» рэмблеристов, весьма скептически их воспринял. Но с другой стороны, я уже лет 7—10 знаю слабые места BSD, в которых силён Linux. Поэтому, уверен, что переход FreeBSD → Linux в целом более осмыслен, нежели наоборот. Хотя, не исключаю, что есть такие задачи, где BSD рулит, а Linux сосёт. Мне в этом плане проще — я не фанатег. ;-)
From: [identity profile] slonik-v-domene.livejournal.com
Ну так и я не фанатег. Это аффтар журнала сотоварищи сначала доказывал, что проблем нет, а потом написал, цитирую: "У FreeBSD действительно есть серьезные проблемы, нам необходимо их решать, иначе нам каюк.".

Это и есть типичная реакция фанатика - сначала гневное отрицание, затем - частичное признание проблем. Года через два-три, глядишь, дорастет до понимания. Или - не дорастет.

фанатеги

Date: 2011-08-19 10:52 pm (UTC)
From: [identity profile] nuclight.livejournal.com
Пиздеть-то не надо. Я туда с первым же комментом пришел спросить, в чем проблемы. Отрицали другие.
From: [identity profile] slonik-v-domene.livejournal.com
Я-то, как раз, сделал непредвзятый разбор полетов, что хорошо, и что плохо.
http://slonik-v-domene.livejournal.com/98273.html
From: [identity profile] ru-pchel.livejournal.com
Я почитав самое начало для себя уяснил что переход с FreeBSD на Debian вызван скорее политическими, чем техническими мотивами. А чтобы рассуждать о политике в компании Рамблер мне данных не хватает, да и бесмысленно это.

Ну поменяют одно на другое. Освоят еще немного денежных средств, наедятся граблей Linux-а, что им даст в следующий раз полное право сказать что Linux недостаточно хорош (или Debian недостаточно хорош) и перейти на что-то еще.
From: [identity profile] slonik-v-domene.livejournal.com
>Я почитав самое начало для себя уяснил что переход с FreeBSD на Debian вызван скорее политическими, чем техническими мотивами.

О причинах я написал в посте "FreeBSD vs Linux, разбор полетов". Но ведь чукча не читатель, так?

>Освоят еще немного денежных средств

О как. Вы еще и продуктовые планы c финансовыми показателями судя по всему видели, раз рассуждаете о деньгах

From: [identity profile] autoench.livejournal.com
Вы видели как у них шардинг сделан?) А теперь представьте, что похожие непотребства они творят и с помощью фаерволлов %)
From: [identity profile] http://users.livejournal.com/_slw/
ну хорошо. ну TTL у него 1. и что?
ситуация с PBR чем-то принципиально должна отличаться от просто роутинга или что?
From: [identity profile] poige.livejournal.com
Нет, не должна (в том-то и дело, соб-сно). Поэтому пакет с TTL 1 не должен вылететь за роутер. А с pass in route-to — вылетит, легко.
From: [identity profile] http://users.livejournal.com/_slw/
ну вылетит или нет мне проверять лень
ну вылетит и хер с ним.
хотя я сомневаюсь, как-то в мане не упомянуто, что route-to не уменьшает (увеличивает, лень смотреть когда TTL в стеке уменьшают) TTL. а чего бы пакету с TTL 0 покидать систему?
From: [identity profile] poige.livejournal.com
Я же уже сказал. pass in route-to для LAN значит, что tracert рисует следующий хост (провайдерский). «Умному достаточно» ©

IPFW

From: [identity profile] http://users.livejournal.com/_slw/ - Date: 2011-08-03 02:09 pm (UTC) - Expand

> от просто роутинга

Date: 2011-08-03 08:10 am (UTC)
From: [identity profile] poige.livejournal.com
Кстати, уточню — не роутинга, а форвардинга. Роутинг это построение пути пересылки (forwarding) пакетов (ну это так, для единства терминологии). :-)

Re: > от просто роутинга

Date: 2011-08-03 08:16 am (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
вот бабушке своей уточняй, заодно расскажешь ей что аппартные маршрутизаторы -- это фантастика.
а тут у нас именно роутинг. или у тебя PBR -- это форвардинг?
From: [identity profile] poige.livejournal.com
Сам процесс пересылки это forwarding. Routing это составление правил (правила) пересылки. Вроде не сложно, моя бабушка бы поняла, скорее всего. :-)

«Аппаратный роутер» это отнюдь не фантастика, а просто типичная глупость (aka marketing?), ибо, повторюсь, там везде есть софт. :-) Эпоха аналоговых ЭВМ аппаратных роутеров, увы, породить не успела. :-)

Кстати, сколько лет, тебе отрок? Успокоительные пилюли давно не давали?

Re: > от просто роутинга

Date: 2011-08-04 06:47 pm (UTC)
From: [identity profile] nil59.livejournal.com
это правильная, но непопулярная точка зрения :)

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

Re: > от просто роутинга

Date: 2011-08-04 07:36 pm (UTC)
From: [identity profile] http://users.livejournal.com/_slw/
главное -- договориться что есть nat.
а то то, что все вокруг называют nat в документации от кошкастых называется pat.
From: [identity profile] poige.livejournal.com
Ну те, кто знают что такое «динамический роутинг», и чем он отличается от статического, имеют все предпосылки для правильных выводов. А как там счЕтают народные массы, это дело десятое. Как говорится, «пишите правильно, даже если диктуют ошибочно» ©

February 2017

S M T W T F S
   1 234
567891011
12131415161718
19202122232425
262728    

Style Credit

Expand Cut Tags

No cut tags
Page generated Jun. 22nd, 2025 08:45 am
Powered by Dreamwidth Studios