Оказывается LPI поменяли срок жизни своих сертификатов. Раньше раньше был равен 10 годам. Но видать поток на сертификацию мало мало затих и они сократили срок жизни до 5 лет 🙂
Ну вот, в следующем году надо будет все сдавать по новой.
На досуге задумался — нужна ли мне сертификация от RedHat?
Рубрика: Работа
Переход с Микрософт Офис на Опен Офис
Сейчас работаю с одним клиентом, переводим компанию с продуктов Микросотф, на бесплатные аналоги, в том числе и рабочие места. Традиционно возник вопрос об офисном пакете. Не для кого не секрет, что ОО и МсОфис отличаются друг от друга, добавляются особенности интерфейса, работы, баги и прочая. Причем, клиент это прекрасно понимает 🙂 и первое что они потребовали — сделать небольшой курс по переходу с МСОфис на ОО.
Честно говоря, я терпеть не могу читать пользовательские курсы, поэтому не взялся за работу над курсом. Поспрошал коллег. Оказывается такой курс уже есть. Более того, есть готовые курсы по обучению ОО с нуля.
Так что, если возникнет вопрос обучения Опен Офису с самого начала или вопрос перехода на ОО с Микрософт, обращайтесь, помогу 🙂
Дистанционный курс по Linux. Настройка Linux сервера, часть 2.
Наконец то появилось время и я ударными темпами начал писать третий дистанционный курс «Настройка Linux сервера, часть 2». Уже написал больше половины.
О чем будет рассказано на курсе.
Большая часть курса посвящена настройке почтового сервера. А это значит, что мы прикурутим антиспам, антивирус и прочие полезные плюшки. Будет рассказано о виртуальном хостинге нескольких почтовых серверов и много другого.
В результате, на выходе вы получите полностью готовый к употреблению почтовый сервер небольшой компании. Если у вас большая компания, то этот сервер можно будет развивать, расширять. Надо посмотреть на запросы слушателей, и возможно я расширю этот курс вопросами о создании группы почтовых серверов, выполняющих разные функции.
Кроме, собственно, почтового сервера, нам придется рассмотреть администрирование MySQL. Эта база данных будет использоваться для работы антиспам фильтра. Я решил не делать отдельного курса по MySQL и поэтому включил его во вторую часть.
Так же мы посмотрим на программу tinyca2, предназначенную для генерации SSL сертификатов. Все таки Николай Коршенин убедил меня, что эта графическая надстройка над openssl не есть зло 🙂
Если все пойдет по плану, то через неделю курс будет полностью готов.
И еще одна новость. Я почти договорился со своим коллегой о создании им дистанционного курса по Apache. Огромный плюс заключается в том, что человек, который будет делать этот курс — практик. У него есть свой развитый WEB хостинг и он много знает о реальных проблемах, возникающих при эксплуатации Apache. Кроме работы в народном хозяйстве, он заодно является хорошим преподавателем. Вообщем, продолжу переговоры, надеюсь, что все получится.
Open VPN и хитрый роутинг.
Это глава из учебника, предоставляемого к моим дистанционным курсам. (с) 2008, Артур Крюков www.kryukov.biz
После выпуска первой редакции этого учебника, у слушателей возникло много вопросов по применению VPN в реальных задачах. Эта глава была добавлена специально для того, что бы показать, как еще можно использовать Open VPN.
Рассмотрим задачу, возникшую у одного из слушателей.
Исходные данные.

Существует внутренняя сеть 192.168.1.0/24. Она выходит в Интернет через роутер с внутренним интерфейсом 192.168.1.1 и внешним интерфейсом 120.3.5.8. Этот и все другие IP адреса взяты совершенно случайно и никакого отношения к реальным серверам не имеют.
Где то «в замке у шефа» в буржуинском сегменте Интернет стоит сервер с IP 110.45.45.8, который тоже принадлежит нашей компании.
Задача 1.

Необходимо весь трафик, предназначенный на WEB сервера (80 порт) отправлять только через сервер 110.45.45.8. Трафик между нашей сетью и этим сервером должен быть зашифрован. Весь остальной трафик из нашей сети должен идти обычным образом.
Задача 2.

Необходимо весь исходящий трафик нашей сети, предназначенный для Интернет, оправлять через роутер 110.45.45.8. Трафик между нашей сетью и этим роутером должен быть зашифрован.
Что тут сказать, параноидальные задачи, но выполнимые. Итак, будем играть в Штирлица и шифроваться.
Настройка VPN.
Материал, описанный в этом разделе необходим для решения обеих задач.
Для шифрования трафика меду двумя серверами мы будем использовать Open VPN. Сервер, выводящий нашу компанию в Интернет, будет работать как VPN клиент. Сервер в Интернет всегда включен, поэтому он будет работать в качестве VPN сервера.
Open VPN настраивается так же как и в предыдущей главе, поэтому не буду повторять материалы этой главы. Просто покажу готовые конфигурационные файлы клиента и сервера.
Конфигурационный файл VPN сервера.
dev tap0
proto udp
mode server
comp-lzo
log-append /var/log/openvpn.log
daemon
ifconfig-pool 192.168.240.2 192.168.240.12
ifconfig 192.168.240.1 255.255.255.0
tls-server
dh /etc/openvpn/dh1024.pem
ca /etc/pki/CA/CA.crt
cert /etc/pki/tls/certs/server.pem
key /etc/pki/tls/private/server.key
port 5000
user nobody
group nobody
persist-tun
persist—key
verb 0
Необходимо подставить реальные файлы ключей и сертификатов.
Что изменилось в файле конфигурации сервера, по сравнению с предыдущей главой? Во-первых, используется 5000 порт, а не 1194. За время, прошедшее с момента написания первой главы, создатели программы стали рекомендовать использовать порт 5000. На самом деле номер порта может быть любой, но мы будем следовать рекомендациям отцов-основателей.
Конфигурационный файл Linux клиента.
remote 110.45.45.8 5000
dev tap
proto udp
ca /etc/openvpn/certs/CA.crt
cert /etc/openvpn/certs/client.pem
key /etc/openvpn/keys/client.key
client
tls-client
comp-lzo
user nobody
group nobody
ping 30
ping-restart 120
ping-timer-rem
persist-key
persist-tun
verb 0
В этом файле мы тоже заменили порт, куда будет подключаться клиент на 5000.
Посмотрим, что получится после настройки такого решения.

Таким образом, мы обеспечили шифрование при передаче данных между первым и вторым серверами. Но этого мало! Надо сделать так, что бы VPN сервер мог доставлять пакеты в сеть 192.168.1.0/24. Поэтому в конфигурации VPN клиента добавим команду push, которая внесет изменения в таблицу маршрутизации VPN сервера.
push "route 192.168.1.0 255.255.255.0 192.168.240.2"
В результате конфигурационный файл клиента будет выглядеть так:
remote 110.45.45.8 5000
dev tap
proto udp
ca /etc/openvpn/certs/CA.crt
cert /etc/openvpn/certs/client.pem
key /etc/openvpn/keys/client.key
client
tls-client
comp-lzo
user nobody
group nobody
push «route 192.168.1.0 255.255.255.0 192.168.240.2»
ping 30
ping-restart 120
ping-timer-rem
persist-key
persist—tun
verb 0
Теперь внимательно приглядимся к нашей схеме. У нас получилось два сегмента внутренних сетей:
- 192.168.1.0/24
- 192.168.240.0/24
И два! Целых два выхода в Интернет! Через роутер 192.168.1.1 и роутер 192.168.240.1.
Господа, как только у вас появляется больше чем один выход в Интернет, необходимо использовать дополнительные возможности, предоставляемые ядром Linux в области маршрутизации. Эти возможности очень хорошо описаны в документе Linux Advanced Routing & Traffic Control HOWTO:
- Английский оригинал: http://tldp.org/HOWTO/Adv-Routing-HOWTO
- Русский перевод: http://opennet.ru/docs/RUS/LARTC
Настоятельно рекомендую в дальнейшее подробно изучить данный HOWTO!
А теперь займёмся решением задач.
Решение задачи 1.
Напомню, что требуется сделать.

Нам необходимо весь трафик на WEB сервера (порт 80) отправлять в Интернет через удаленный сервер, через интерфейс с IP адресом 110.45.45.8.
Весь остальной трафик из нашей сети должен выходит в Интернет через локальный сервер, через интерфейс с IP адресом 120.3.5.88.
На удаленном сервере нам надо сделать только NAT преобразование. Все пакеты, пришедшие из сети 192.168.1.0/24 или 192.168.240.0/24 (а вдруг у вас на клиентском сервере работает прокси сервер Squid?) пропускать через SNAT.
Поэтому в firewall удаленного сервера надо добавить следующие правила:
iptables –t nat –A POSTROUTING –o eth0 –s 192.168.1.0/24 -j SNAT --to-source 110.45.45.8
iptables –t nat –A POSTROUTING –o eth0 –s 192.168.240.0/24 -j SNAT --to-source 110.45.45.8
Не забудьте разрешить прохождение этих пакетов через firewall.
iptables –A FORWARD –p tcp --dport 80 –i tap0 –j ACCEPT
Не забудьте разрешить перенос пакетов с одного сетевого интерфейса на другой.
echo 1 > /proc/sys/net/ipv4/ip_forward
В файле /etc/sysctl.conf отредактируйте строку.
net.ipv4.ip_forward = 1
C удаленным сервером все. Займемся локальным сервером. Наша задача отправлять пакеты предназначенные на 80 порт в Интернет через машину 192.168.240.1.
Добавить маршрут в таблицу маршрутизации? Не поможет, в таблице маршрутизации нельзя указывать порты.
Сделать DNAT? Тоже не поможет, нам нельзя менять IP назначения.
SNAT? Тоже ничего не даст.

Во всех случаях, перечисленных выше, пакет с локального сервера будет уходить по маршруту по умолчанию через интерфейс eth0.
Пришло время включить дополнительные возможности ядра Linux. А вы знаете, что в Linux можно сделать 256 таблиц маршрутизации? И 512 можно! и даже больше 🙂

Для решения нашей проблемы мы добавим еще одну таблицу маршрутизации.
В этой таблице сделаем маршрут по умолчанию на машину 192.168.240.1 через интерфейс tap0.
Все пакеты, приходящие на наш сервер на 80 порт из внутренней сети, а также все пакеты, которые генерируют программы, работающие на нашем сервере на 80 порт, будем передавать в новую таблицу маршрутизации. А там уровень IP все сделает сам.
Создадим новую таблицу маршрутизации с именем www.
echo 430 www >> /etc/iproute2/rt_tables
Таким образом, мы создали таблицу номер 430 с именем www. Номер и имя можно использовать любые. Главное, что бы они уже не использовались в вашей системе. Вы можете сначала посмотреть содержимое файла rt_tables при помощи программы cat.
cat /etc/iproute2/rt_tables
Добавим в таблицу www маршрут по умолчанию.
ip route add default via 192.168.240.1 dev tap0 table www
Таблица создана. Как заставить необходимые нам пакеты попадать именно в неё? Тут следует сделать два действия:
- При помощи iptables и действия MARK пометить пакет. Присвоить ему номер от 1 до 64.
- При помощи программы ip, все помеченные нужным нам номером пакеты перенаправить в таблицу www.
iptables –t mangle –A PREROUTING –i eth1 –p tcp --dport 80 -j MARK --set-mark 1
iptables –t mangle –A OUTPUT –p tcp --dport 80 –d ! 192.168.1.0/24 -j MARK --set-mark 1
Обратите внимание на то, что метки мы ставим в таблице mangle в цепочках PREROUTING (для пакетов, пришедших из внутренней сети) и OUTPUT (для пакетов, которые генерирует программное обеспечение, работающее на нашей машине), до того, как пакеты попадут в таблицу маршрутизации.
ip rule add fwmark 1 table www
Можете посмотреть какие пакеты, каким таблицам будут передаваться.
ip rule show
После перезагрузки компьютера, привязка к таблице и маршруты пропадут. Поэтому мы должны сделать так, что бы при старте они появились снова. Тут все зависит от дистрибутива. Самый простой способ воспользоваться файлом /etc/rc.d/rc.local (или /etc/rc.d/rc.local.local, зависит от системы, которую вы используете). В этом файле надо дописать правила:
ip route add default via 192.168.240.1 dev tap0 table www
ip rule add fwmark 1 table www
Сама таблица www создается только один раз.
Теперь займемся firewall.
Разрешаем хождение пакетов на 80 порт, через интерфейс tap0.
iptables –A FORWARD –p tcp --dport 80 –o tap0 –j ACCEPT
Остальными правилами разрешаете то, что должно выходить через интерфейс eth0. Я не буду писать эти правила. Посмотрите, как это делалось в разделе, посвященном firewall. Единственное добавление — теперь надо явно указывать output интерфейс при помощи параметра –o.
Последнее замечание — NAT преобразования. Нам необходимо делать NAT только на интерфейсе eth0. На интерфейсе tap0 ничего делать не надо. Там пакеты идут без преобразования.
Решение задачи 2.
А тут я поступлю немного хитрее. Я хочу, что бы вы сами решили эту задачу. Если все заработает, значит, вы все поняли правильно. Если не заработает, присылайте мне ваше решение. У нас будет тема для обсуждения.
Единственная подсказка — трафик на 22 порт удаленного сервера не пускайте через VPN. Если вдруг не получится, вы хоть сможете подключиться к удаленному серверу. И вторая причина — в этом соединении уже итак все зашифровано J.
Цены на мои дистанционные курсы по Linux
Устаканились цены на дистанционные курсы.
Посмотреть и обсудить можно тут.
Из-за жесточайшей нехватки времени, пока удалось договориться только с УЦ Навигатор.
Adobe Captivate 3
Открыл для себя чудо программу Adobe Captivate 3. Скачал, учусь пользоваться. Пока на триале, но думаю, не смотря на цену, купить ее официально.
Абалденный инструмент для создания интерактивных курсов!
Позволяет в реальном времени грабить экран с записью голосовых комментариев.
Шикарный механизм создания тестов, в том числе с эмуляцией!
На выходе flash презенташка.
Начал использовать Captivate при создании материалов для дистанционных курсов по Linux для школ. Отпадает необходимость в куче сопроводительной документации для программистов, делающих презенташки. Достаточно написать сам материал + видео лекция.
Чертовски позитивная программа! Я в восторге.
Вот такой вот черновик получился. Предупреждаю — это черновик, предназначеный для дальнейшей обработки. Кроме всего, у меня нет нормальной звуковой системы, писал на встроенный микрофон, поэтому шумы и прочая. Кстати, может посоветуете приличную внешнюю звуковую систему для ноута?
По поводу дистанционных курсов по Linux.
Более подробную информацию по дистанционным курсам по linux можно почитать на моем сайте http://www.kryukov.biz.
Курсы полностью готовы к работе.
Дистанционный курс по Linux. Часть 1.
Закончил писать методичку к дистанционному курсу по Linux: КУРС МОЛОДОГО БОЙЦА LINUX.
Краткое содержание курса:
- Стандарты UNIX.
- Дистрибутивы Linux.
- Как работать с Linux.
- Программы оболочки (shell).
- Файловые системы.
- Базовый набор программ.
- Переменные среды окружения.
- Псевдонимы.
- Стандартный ввод, вывод и вывод ошибки.
- Программы для работы с текстовыми файлами. Часть 2.
- Поиск файлов в файловой системе.
- Тестовые вопросы. Тест 1.
- Система помощи.
- Великий и могучий редактор vi.
- Система безопасности.
- Тестовые вопросы. Тест 2.
- Процессы.
- Тестовые вопросы. Тест 3.
- Основы программирования shell script.
Итого получилось 157 страниц, формата А4, 10 кеглем. Перевожу на русский язык — дофига информации 🙂
Этот курс рекомендуется тем, кто никогда не работал с linux или работал только с использованием графического интерфейса.
Курс не зависит от дистрибутива, поскольку в курсе рассказывается только про базовые вещи. своейственные всем дистрибутивам Linux и другим разновидностям UNIX (FreeBSD, Solaris, HP-UX и прочим).
Первая часть дистанционного курса…
Думаю завтра закончу дописывать материалы к первой части дистанционного курса. Уже 120 страниц селким почерком 🙂 Мало мало устал 🙂
Вообщем, на следующей неделе будут готовы два курса. Цены должны быть не большими. По поводу продажи уже договорился с несколькими центрами и крупным Интернет магазином.
Вторая часть дистанционного курса по Linux готова, опробована мною и бета тестерами :)
Напомню, что дистанционный курс по настройке Linux сервера, предусматривает демонстрацию пошаговой настройки Linux сервера. В отличии от очных курсов, в которых даются голые знания, мой дистанционный курс позволяет настроить реальный сервер с реальным доступом в Интернет, с реальным IP для решения реальных задач.
Основные особенности курса:
- Настраиваемый вами сервер находится в Интернет и имеет реальный IP адрес. Вы сразу попадаете в суровые условия злого Интернет.
- Настроенный сервер можно использовать для своих задач. Например, разместить на нем свой почтовый, WEB и прочие сервера.
- Сервер развертывается в виртуальной машине vmware, что позволяет перенести его на отдельный хостинг, или на свой сервер и продолжить использование его даже после окончания курса. Мы можем выслать DVD диски с вашей виртуальной машиной.
- Вы получаете доступ к закрытой конференции, в которой можете задавать свои вопросы преподавателю.
- Вы получаете доступ к голосовому порталу, в котором в режиме реального времени можете задавать свои вопросы преподавателю.
- Вы получаете подробное руководство на русском языке по настройке сервера, в котором кроме пошаговых инструкций представлено большое количество теоретического материала.
Программа второй части курса:
• Установка операционных систем.
o Установка CentOS.
o Установка ALT Linux.
• Первоначальная настройка сервера.
o Настройка сети.
o Обновление системы.
o Настройка ssh.
• Настройка firewall
o Внутреннее устройство.
o Пограмма iptables.
o Управление netfiltеr.
o Примеры использования.
• Создание инфраструктуры PKI
o Конфигурационный файл openssl.conf.
o Дополнительные файлы.
o Создание сертификата центра сертификации.
o Создание сертификата сервера
• Настройка DNS сервера.
o Пространство имён DNS.
o Принцип работы DNS.
o DNS сервер BIND
o Настройка клиента DNS.
o Настройка firewall для работы DNS сервера
o Настройка поддержки slave зоны
o Отладка.
o Зоны обратного преобразования.
• Настройка OpenVPN.
o Как это работает.
o Доступ ко внутренним сетям.
o Настройка сервера.
o Клиент Windows.
o Клиент Linux.
o Конфигурация сеть-VPN-сеть.
Ответы на пока еще не заданные вопросы.
Вопрос: Почему vmware?
Ответ: Это наиболее распространённый и надёжный продукт на рынке виртуализации. Запускается практически на любых ОС и без оных. Наличие бесплатных версий позволяет его использовать без каких либо отчислений производителю. На курса используется vmware server, виртуальные машины, созданные этим сервером можно использовать в любых продуктах компании vmware. Это позволяет перенести созданный вами сервер на любой хостинг или на свой собственный сервер.
Вторая причина, почему используется vmware заключается в том, что преподаватель может подключиться к вашей виртуальной машине и прямо на ваших глазах что либо показать или исправить. При этом вы будете видеть действия преподавателя.
Вопрос: Голосовой портал? Что имеется в виду?
Ответ: Это сервер ventrillo, позволяющий одновременно общаться большому количеству людей. Конечно, можно было использовать Skype или sipnet, но они не позволяют участвовать в разговоре большому количеству людей.
Вопрос: Преподаватель все время будет присутствовать в голосовом портале?
Ответ: Конечно нет 🙂 Только в строго определённое время.
Вопрос: Доступ к виртуальной машине ограничен по времени?
Ответ: Во время прохождения курса виртуальная машина доступна в любое время. Вы можете сами выбирать, когда будете работать с ней.
Вопрос: Я действительно могу разместить на виртуальной машине все что хочу?
Ответ: Не совсем, только то, что не противоречит законодательству Германии. Так же, возможность передавать данные в Интернет вы получите, только после того как преподаватель проверит ваши настройки Это необходимо, что бы вашей машиной не воспользовались спамеры.
Вопрос: А если я спамер и хочу воспользоваться вашей машиной и разослать спам?
Ответ: При попытке распространения недозволенной информации, в том числе и спама, ваша виртуальная машина будет выключена. Деньги в этом случае не возвращаются. Более того, мы будем вынуждены подать на вас в суд. Более подробно о таких неприятных ситуациях написано в договоре.
Вопрос: Почему курс разбит на такие маленькие части? Можно ведь сделать «все в одном»?
Ответ: Я подумал, что далеко не всем необходимо проходить весь курс целиком. Кого то могут интересовать только определенные вещи. Кого то интересует почтовый сервер, кого то WEB. Кто то используем MySQL. Вам ни кто не мешает пройти несколько маленьких курсов. Так же это позволит оптимизировать ваши денежные затраты.
Вопрос: Что будет в третье части курса?
Ответ: Настройка почтового сервера.
Вопрос: Где можно оплатить курс?
Ответ: Предварительная договорённость о чтении курса достигнута с двумя учебными центрами: Академия Корпоративных Систем и Навигатор. Более точную информацию я предоставлю в начале Сентября.
Вопрос: Мы учебный центр, мы можем продавать ваш курс нашим клиентам от своего имени?
Ответ: Можете, предварительно договорившись со мной. В принципе для предоставления курса клиентам под своим именем вам не потребуется создавать собственную инфраструктуру, вы можете пользоваться нашими серверами и преподавателями. Достаточно заключить с нами договор на техническую поддержку.
Вопрос: Курсы только по Linux?
Ответ: Не только. У нас есть возможность предоставить техническую поддержку для дистанционных курсов по Windows. Стандартный набор официальных курсов по 2003, 2008 серверу. Более подробно об этом можно узнать, написав письмо мне.