Оглавление Сетевое конфигурирование ......................................................................................................................... 3 3 Установка прокси-сервера ....................................................... 3.1 Настройка Squid ............................................................................ 1 Базовая настройка сети ............................................................................................................................. 4 3.2 Упражнения.................................................................................... 1.1 Настройка сетевого интерфейса ......................................................................................................................... 5 3.3 Решения ......................................................................................... 1.2 TTY....................................................................................................................................................................... 11 Управление сетевыми клиентами ............................................. 1.3 Перезапуск ......................................................................................................................................................... 12 1.4 PPP – Протокол «точка-точка» .......................................................................................................................... 13 1 Настройка DHCP ....................................................................... 1.5 ARP ...................................................................................................................................................................... 17 1.1 Настройка DHCP ........................................................................... 1.6 Упражнения ......................................................................................................................................................... 20 1.2 Упражнения.................................................................................... 1.7 Решения .............................................................................................................................................................. 21 1.3 Решения ......................................................................................... 2 Дополнительные сетевые настройки. Поиск и 2 Настройка NIS ........................................................................... устранение неполадок ................................................................................................................................. 22 2.1 Настройка NIS................................................................................ 2.1 VPN ...................................................................................................................................................................... 2.2 Упражнения.................................................................................... 23 2.2 Поиск и устранение проблем ............................................................................................................................. 2.3 Решения ......................................................................................... 24 2.3 Упражнения ........................................................................................................................................................ 29 3 Настройка LDAP ........................................................................ 2.4 Решения .............................................................................................................................................................. 30 3.1 Настройка LDAP ............................................................................ Почта и новости ............................................................................................................................................ 31 3.2 Упражнения.................................................................................... 3.3 Решения ......................................................................................... 1 Использование Sendmail .......................................................................................................................... 32 4 Аутентификация PAM ............................................................... 1.1 Использование Sendmail .................................................................................................................................... 33 1.2 Упражнения ......................................................................................................................................................... 4.1 Настройка PAM .............................................................................. 38 1.3 Решения .............................................................................................................................................................. 4.2 Упражнения.................................................................................... 39 4.3 Решения ......................................................................................... 2 Управление почтовым трафиком ............................................................................................................ 40 Безопасность системы ................................................................ 2.1 Вступление .......................................................................................................................................................... 41 2.2 Настройка ............................................................................................................................................................ 42 1 Настройка маршрутизатора ..................................................... 2.3 Примеры .............................................................................................................................................................. 44 1.1 Настройка маршрутизатора .......................................................... 2.4 Упражнения ......................................................................................................................................................... 45 1.2 Упражнения.................................................................................... 2.5 Решения .............................................................................................................................................................. 46 1.3 Решения ......................................................................................... DNS .................................................................................................................................................................. 47 2 Защита FTP-серверов .............................................................. 1 Базовая настройка BIND .......................................................................................................................... 48 2.1 Настройка демона WU-FTPD ........................................................ 1.1 Настройка BIND ................................................................................................................................................. 2.2 Упражнения.................................................................................... 49 1.2 Упражнения ......................................................................................................................................................... 2.3 Решения ......................................................................................... 53 1.3 Решения .............................................................................................................................................................. 54 3 Безопасная оболочка (OpenSSH) ............................................ 2 Создание и поддержка зон DNS ............................................................................................................. 55 3.1 Настройка OpenSSH ..................................................................... 2.1 Создание зоны DNS ........................................................................................................................................... 3.2 Упражнения.................................................................................... 56 2.2 Упражнения ......................................................................................................................................................... 3.3 Решения ......................................................................................... 60 2.3 Решения .............................................................................................................................................................. 61 4 Поддержание безопасности системы ..................................... 3 Обеспечение безопасности DNS – сервера .......................................................................................... 62 4.1 Выполнение задач по поддержанию 3.1 Безопасность DNS .............................................................................................................................................. безопасности ....................................................................................... 63 3.2 Упражнения ......................................................................................................................................................... 4.2 Упражнения.................................................................................... 65 3.3 Решения .............................................................................................................................................................. 4.3 Решения ......................................................................................... 66 Web-сервисы ................................................................................................................................................. Устранение неполадок в работе сети ....................................... 67 1 Установка web-сервера ............................................................................................................................ 1 Поиск неисправностей в сети .................................................. 68 1.1 Установка и настройка Apache .......................................................................................................................... 1.1 Поиск неисправностей в работе сети .......................................... 69 1.2 Упражнения ......................................................................................................................................................... 74 Тест для закрепления знаний ..................................................... 1.3 Решения .............................................................................................................................................................. 75 1 Тест ........................................................................................... 2 Поддержка web-сервера .......................................................................................................................... 76 2 Ответы к тесту ........................................................................... 2.1 Виртуальные сервера ........................................................................................................................................ 77 3 Авторы ....................................................................................... 2.2 Apache и mod_ssl ................................................................................................................................................ 79 Словарь терминов ........................................................................ 2.3 Упражнения ......................................................................................................................................................... 85 2.4 Решения .............................................................................................................................................................. 86 Соглашения, используемые в курсе Новые команды описываются следующим образом: command [options] [files] где: command – название команды [...] - необязательные параметры options – ключи, используемые командой files – имена файлов, передаваемые как параметры Например : [root@test ] /# command parameter # comments about the command results : the command completed Символ «#» обозначает как комментарий, так и приглашение командной строки суперпользователя. Сетевое конфигурирование В этой главе 1.7 Решения ......................................................................................... Сетевое конфигурирование ......................................................................................................................... 3 2 Дополнительные сетевые настройки. Поиск и 4 1 Базовая настройка сети ............................................................................................................................. устранение неполадок ................................................................. 1.1 Настройка сетевого интерфейса ......................................................................................................................... 5 1.2 TTY....................................................................................................................................................................... 2.1 VPN ................................................................................................. 11 1.3 Перезапуск ......................................................................................................................................................... 2.2 Поиск и устранение проблем ........................................................ 12 1.4 PPP – Протокол «точка-точка» .......................................................................................................................... 2.3 Упражнения ................................................................................... 13 1.5 ARP ...................................................................................................................................................................... 2.4 Решения ......................................................................................... 17 1.6 Упражнения ......................................................................................................................................................... 20 1 Базовая настройка сети Ключевые файлы, термины и утилиты /sbin/route /sbin/ifconfig /sbin/arp /usr/sbin/arpwatch /etc 1.2 Настройка сетевого интерфейса Чтобы присоединить компьютер к локальной сети, необходимо настроить IPадрес и маску сети. Эти параметры используются для идентификации компьютера в сети. Если компьютер должен иметь доступ в другую сеть, необходимо указать маршрутизатор, через который этот доступ будет осуществляться. ifconfig С помощью утилиты ifconfig, можно вывести на экран или изменить параметры сетевого интерфейса. Перед использованием утилиты ifconfig должен быть загружен драйвер сетевой карты, и сама карта должна быть распознана драйвером. Команда ifconfig отображает либо все сконфигурированные интерфейсы, либо принимает имя интерфейса в качестве аргумента. [root@test root]# ifconfig eth0 Link encap:Ethernet HWaddr 00:40:F4:98:D2:D9 inet addr:192.168.0.42 Bcast:192.168.0.255 Mask:255.255.255.0 inet6 addr: fe80::240:f4ff:fe98:d2d9/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:0 errors:0 dropped:0 overruns:0 frame:0 TX packets:9 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:0 (0.0 b) TX bytes:618 (618.0 b) Interrupt:20 Base address:0xf000 lo Link encap:Local Loopback inet addr:127.0.0.1 Mask:255.0.0.0 inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:16436 Metric:1 RX packets:2476 errors:0 dropped:0 overruns:0 frame:0 TX packets:2476 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:558766 (545.6 Kb) TX bytes:558766 (545.6 Kb) [root@test root]# Команда ifconfig -a отображает все сетевые интерфейсы, включая не сконфигурированные. Чтобы настроить интерфейс с помощью DHCP, в вашей локальной сети должен быть DHCP сервер. Интерфейс настраивается командой dhclient : [root@test root]# dhclient Internet Software Consortium DHCP Client V3.0.1rc13 Copyright 1995-2002 Internet Software Consortium. All rights reserved. For info, please visit http://www.isc.org/products/DHCP Listening on LPF/eth0/00:40:f4:98:d2:d9 Sending on LPF/eth0/00:40:f4:98:d2:d9 Listening on LPF/lo/ Sending on LPF/lo/ Sending on Socket/fallback DHCPDISCOVER on eth0 to 255.255.255.255 port 67 interval 7 send_packet: Network is down DHCPDISCOVER on lo to 255.255.255.255 port 67 interval 5 DHCPOFFER from 192.168.0.254 DHCPREQUEST on eth0 to 255.255.255.255 port 67 DHCPACK from 192.168.0.254 bound to 192.168.0.30 -- renewal in 250 seconds. [root@test root]# Для конфигурирования интерфейса со статическим адресом, используется следующий синтаксис: [root@test root]# ifconfig eth0 192.168.0.42 netmask 255.255.255.0 [root@test root]# ifconfig eth0 Link encap:Ethernet HWaddr 00:40:F4:98:D2:D9 inet addr:192.168.0.42 Bcast:192.168.0.255 Mask:255.255.255.0 inet6 addr: fe80::240:f4ff:fe98:d2d9/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:0 errors:0 dropped:0 overruns:0 frame:0 TX packets:11 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:0 (0.0 b) TX bytes:1302 (1.2 Kb) Interrupt:20 Base address:0xf000 lo Link encap:Local Loopback inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:16436 Metric:1 RX packets:2479 errors:0 dropped:0 overruns:0 frame:0 TX packets:2479 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:559750 (546.6 Kb) TX bytes:559750 (546.6 Kb) [root@test root]# Маска подсети 255.255.255.0 не обязательна, так как такое значение используется по умолчанию. Сетевой интерфейс может иметь более одного IP адреса. Псевдонимы сетевых интерфейсов имеют имена: eth0:0, eth0:1, и т.п... [root@test root]# ifconfig eth0 192.168.0.42 [root@test root]# ifconfig eth0:1 192.168.0.43 [root@test root]# ifconfig eth0:2 192.168.0.44 [root@test root]# ifconfig eth0 Link encap:Ethernet HWaddr 00:40:F4:98:D2:D9 inet addr:192.168.0.42 Bcast:192.168.0.255 Mask:255.255.255.0 inet6 addr: fe80::240:f4ff:fe98:d2d9/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:2 errors:0 dropped:0 overruns:0 frame:0 TX packets:11 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:684 (684.0 b) TX bytes:1302 (1.2 Kb) Interrupt:20 Base address:0xf000 eth0:1 Link encap:Ethernet HWaddr 00:40:F4:98:D2:D9 inet addr:192.168.0.43 Bcast:192.168.0.255 Mask:255.255.255.0 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:2 errors:0 dropped:0 overruns:0 frame:0 TX packets:11 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:684 (684.0 b) TX bytes:1302 (1.2 Kb) Interrupt:20 Base address:0xf000 eth0:2 Link encap:Ethernet HWaddr 00:40:F4:98:D2:D9 inet addr:192.168.0.44 Bcast:192.168.0.255 Mask:255.255.255.0 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:2 errors:0 dropped:0 overruns:0 frame:0 TX packets:11 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:684 (684.0 b) TX bytes:1302 (1.2 Kb) Interrupt:20 Base address:0xf000 lo Link encap:Local Loopback inet6 addr: ::1/128 Scope:Host UP LOOPBACK RUNNING MTU:16436 Metric:1 RX packets:2479 errors:0 dropped:0 overruns:0 frame:0 TX packets:2479 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:559750 (546.6 Kb) TX bytes:559750 (546.6 Kb) [root@test root]# Таким образом, компьютер может стать мостом между несколькими подсетями, имея всего лишь одну сетевую карту. Активация интерфейса: [root@test root]# ifconfig eth0 up или [root@test root]# ifup eth0 Деактивация интерфейса: [root@test root]# ifconfig eth0 down или [root@test root]# ifdown eth0 Все эти команды конфигурируют сетевую карту только до следующей перезагрузки. Чтобы сохранить эту конфигурацию и после перезагрузки, необходимо воспользоваться графической утилитой или модифицировать указанный ниже файл: [root@test root]# cat /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 BOOTPROTO=static IPADDR=192.168.0.42 NETMASK=255.255.255.0 NETWORK=192.168.0.0 BROADCAST=192.168.0.255 GATEWAY=192.168.0.254 ONBOOT=yes MII_NOT_SUPPORTED=no WIRELESS_ENC_KEY="" [root@test root]# route С помощью команды route можно выводить на экран и конфигурировать таблицу маршрутизации ядра. Наиболее часто эту команду используют для установки маршрута по умолчанию, но с ее помощью можно также указать ядру, через какой маршрутизатор посылать пакеты для определенной сети. Чтобы вывести таблицу маршрутизации на экран, наберите route: [root@test root]# route Kernel IP routing table Destination Gateway 192.168.0.0 * 127.0.0.0 * default 192.168.0.254 [root@test root]# Genmask 255.255.255.0 255.0.0.0 0.0.0.0 Flags U U UG Metric 0 0 0 Ref 0 0 0 Use 0 0 0 Iface eth0 lo eth0 Также есть возможность не выполнять преобразование IP адресов в имена, что весьма полезно, так как DNS запросы в большинстве случаев работают очень медленно. Для этого используется флаг -n. [root@test root]# route -n Kernel IP routing table Destination Gateway 192.168.0.0 0.0.0.0 127.0.0.0 0.0.0.0 0.0.0.0 192.168.0.254 [root@test root]# Genmask 255.255.255.0 255.0.0.0 0.0.0.0 Flags U U UG Metric 0 0 0 Ref 0 0 0 Use 0 0 0 Iface eth0 lo eth0 Flags U U UG Metric 0 0 0 Ref 0 0 0 Use 0 0 0 Iface eth0 lo eth0 Чтобы указать маршрут по умолчанию: [root@test root]# route Kernel IP routing table Destination Gateway 192.168.0.0 * 127.0.0.0 * default 192.168.0.254 [root@test root]# Genmask 255.255.255.0 255.0.0.0 0.0.0.0 Если несколько интерфейсов сконфигурированы с одним и тем же IP-адресом, пакеты могут маршрутизироваться с помощью маски подсети в зависимости от того, какая подсеть к какому интерфейсу подсоединена. [root@test root]# route add -net 10.0.0.0 netmask 255.255.255.0 gw 192.168.0.253 [root@test root]# Новая таблица маршрутизации: [root@test root]# route -n Kernel IP routing table Destination Gateway 10.0.0.0 192.168.0.253 192.168.0.0 0.0.0.0 127.0.0.0 0.0.0.0 0.0.0.0 192.168.0.254 [root@test root]# Genmask 255.255.255.0 255.255.255.0 255.0.0.0 0.0.0.0 Flags UG U U UG Metric 0 0 0 0 Ref 0 0 0 0 Use 0 0 0 0 Iface eth0 eth0 lo eth0 Также есть возможность указать устройство, которое будет использоваться для маршрутизации пакетов: [root@test root]# route add -net 10.0.0.0 netmask 255.255.255.0 gw 192.168.0.253 dev eth1 [root@test root]# 1.1 TTY На заре компьютерной эры было слишком дорого иметь более одного компьютера в одной компании. Все работали с одним большим компьютером с помощью телетайпа, сокращенно: TTY. Сейчас это важная часть любой Unix системы. В наши дни существуют виртуальные терминалы, экранные консоли для входа в систему. Введение в getty getty - это программа, которая приветствует вас в консоли. Mandrake Linux release 10.0 (Official) for i586 Kernel 2.6.3-7mdk on an i686 / tty1 test login: Она запускается процессом init из /etc/inittab, и может работать на последовательном порту. Существует несколько утилит, разновидностей getty, с большим или меньшим набором возможностей: mingetty (малый размер, используется для виртуальных консолей) agetty mgetty (последовательные порты, факсы, голосовая почта, автоматическое определение протокола PPP) uugetty getty_em (упрощенная версия uugetty) fbgetty (альтернативный getty Linux) (сложная) (тоже, что и предыдущая, но с поддержкой видеобуферов1) Сообщение, выводимое на виртуальной консоли, можно изменить, отредактировав файл /etc/issue : [root@test root]# cat /etc/issue Mandrake Linux release 10.0 (Official) for i586 Kernel 2.6.3-7mdk on an i686 / \l [root@test root]# 1 Здесь и далее по тексту под этим термином будет пониматься framebuffer,-прим.ред. 1.1 Перезапуск Процесс init запускает несколько процессов getty. Для этих процессов указывается2 опция “respawn”, которая позволяет перезапустить процесс, если он прекратил свое выполнение. Эта опция очень полезна для виртуальных терминалов: после того как отработает процесс login, init запустит новый процесс getty, который будет ждать следующего входа в систему. Во время входа через виртуальную консоль процесс getty будет заменен на: getty login bash getty приветствует пользователя. Затем login проверяет его реквизиты (с помощью службы PAM). На последнем шаге login запускает оболочку прописанную в /etc/passwd; обычно это /bin/bash. 2 В файле /etc/inittab,-прим.ред. 1.1 PPP – Протокол «точка-точка» Протокол PPP используется для установления соединения между двумя компьютерами. Обычно этот протокол используется для связи по коммутируемым линиям с помощью обычного модема. Настройка Основной конфигурационный файл: /etc/ppp/options. Этот файл содержит значения по умолчанию, которые могут быть дополнены или переопределены опциями командной строки, либо в конфигурационном файле конкретного соединения. Последние создаются в каталоге /etc/ppp/peers/. Таким образом, можно иметь файл /etc/ppp/peers/sunrise для соединения с Интернетом по коммутируемой линии и файл /etc/ppp/peers/dsl-provider для ADSL соединения с помощью протокола PPPoE. Аутентификация Аутентификация может производиться различными способами: PAP (Password Authentication Protocol – протокол аутентификации по паролю) CHAP (Challenge Handshake Authentication Protocol - протокол аутентификации с предварительным согласованием вызова) MSCHAP (разновидность протокола CHAP от компании Microsoft; Linux может работать только как клиент) В случае протокола PAP аутентификация может, а в случае CHAP - обязана быть двусторонней. Обычно для аутентификации используется имя хоста. Если желательно использовать другую учетную запись, ее нужно указать с помощью опции name на клиенте в файле /etc/ppp/options: name username Файл паролей PAP/CHAP В зависимости от выбранного метода аутентификации пароли PPP хранятся одном из двух файлов. Поскольку файл содержит важную информацию, он должен иметь следующие права доступа: [root@test root]# ls -l /etc/ppp/chap-secrets /etc/ppp/pap-secrets -rw------- 1 root daemon 78 fév 27 01:27 /etc/ppp/chap-secrets -rw------- 1 root daemon 77 fév 27 01:27 /etc/ppp/pap-secrets [root@test root]# /etc/ppp/pap-secrets # Secrets for authentication using PAP # client server secret user1 * pw123 acceptable_local_IP_addresses Этот файл указывает демону pppd использовать пароль pw123 для локального имени user1 (которое не является настоящим именем хоста) при соединении с любым сервером. Поскольку локальный IP-адрес не указан, будет принят любой адрес. /etc/chap-secrets На стороне клиента: # Secrets for authentication using CHAP # client server secret acceptable local IP addresses user1 pppserver pw123 pppserver user1 pw001 На стороне сервера: # Secrets for authentication using CHAP # client server secret acceptable local IP addresses pppserver user1 pw123 user1 pppserver pw001 Команды pon Команда запускает ppp соединение. Если файл /etc/ppp/ppp_on_boot существует и может быть исполнен, то запускается этот файл. В противном случае будет использован файл /etc/ppp/peers/provider. Другое имя соединения может быть передано как аргумент. poff Команда останавливает ppp соединение. Если установлено несколько соединений, можно передать имя соединения в качестве аргумента. Либо можно использовать опцию -a и остановить все ppp соединения. plog Отображает последние несколько строк регистрационного журнала ppp. kppp Программа KDE для управления соединениями по коммутируемым линиям. Пример Сервер # /etc/ppp/pap-secrets toto * "pw123" 192.168.13.13 Чтобы запустить PPP сервер, наберите pppd /dev/ttyS0 38400 debug passive require-pap nodetach netmask 255.255.255.0 persist noipdefault 172.16.1.1:172.16.1.2 noauth Клиент # /etc/ppp/pap-secrets toto * pw123 Опции PPP # /etc/ppp/peers/provider noauth connect "/bin/true" defaultroute /dev/ttyS0 38400 nopersist name toto Чтобы запустить PPP на стороне клиента, наберите: pppd call provider 1.1 ARP Утилита arp может быть использована для просмотра и изменения ARPтаблицы ядра. [root@test root]# arp Address HWtype ARISTOTE ether [root@test root]# HWaddress 00:C0:9F:2F:7E:DD Flags Mask C Iface eth0 Чтобы установить соответствие между какой-нибудь IP-адресом и заданным MAC-адресов, выполните следующие команды: [root@test root]# arp -s 192.168.0.69 00:02:03:97:2F:7A [root@test root]# arp -a ARISTOTE (192.168.0.254) at 00:C0:9F:2F:7E:DD [ether] on eth0 ? (192.168.0.69) at 00:02:03:97:2F:7A [ether] PERM on eth0 [root@test root]# arpwatch Утилита arpwatch используется для мониторинга MAC-адресов и обнаружения случаев вторжения в процесс обмена данными или новых компьютеров, появившихся в локальной сети. С помощью syslog утилита регистрирует в журнале такие события, как изменение MAC-адреса для какого-либо IP адреса, либо появление нового MAC адреса в сети. Для запуска утилиты arpwatch используется либо сценарий/etc/init.d/arpwatch, либо команда arpwatch -d: Эта запись в журнале показывает, что в сети появился новый неизвестный MACадрес. [root@test root]# arpwatch -d From: arpwatch (Arpwatch) To: root Subject: new station hostname: ip address: ethernet address: ethernet vendor: timestamp: <unknown> 192.168.0.69 0:9:6b:17:8a:b0 IBM Corporation Monday, August 2, 2004 11:08:20 +0200 А сейчас изменился MAC-адрес: кто-то либо поменял сетевую карту, либо пытается нелегально получить доступ к какому-то хосту, используя технику ARP Spoofing. [root@test root]# arpwatch -d From: arpwatch (Arpwatch) To: root Subject: changed ethernet address hostname: ip address: ethernet address: ethernet vendor: old ethernet address: old ethernet vendor: timestamp: previous timestamp: delta: <unknown> 192.168.1.5 0:9:6b:17:8a:b0 IBM Corporation 0:9:6b:17:8a:b1 IBM Corporation Monday, August 2, 2004 11:46:29 +0200 Monday, August 2, 2004 11:45:52 +0200 37 seconds База данных MAC адресов хранится в файле /var/lib/arpwatch/arp.dat. Вы можете отредактировать этот файл и удалить некоторые строки, чтобы протестировать работу утилиты, заставив старые машины стать снова новыми: [root@test root]# cat /var/lib/arpwatch/arp.dat 0:6:1e:df:69:80 192.168.1.60 1091437640 0:c0:9f:2f:7e:dd 192.168.1.254 1091437597 Каждая строка содержит MAC адрес, IP адрес и метку даты/времени (timestamp). Метка даты/времени записывается в формате EPOCH (количество секунд, прошедших с 1 января 1970 года). Чтобы отобразить ее в читабельном виде, воспользуйтесь командой: [root@test root]# date -d '1970-01-01 1091438200 sec' +"%Y-%m-%d %T %Z" 2004-08-02 10:16:40 CEST 1.2 Упражнения Упражнение 1 : Настройте вашу сетевую карту на использование DHCP. Настройте вашу сетевую карту на использование статичного IP адреса. Измените маршрут по умолчанию. Сделайте свои изменения постоянными (работающими и после перезагрузки). Упражнение 2 : Какая программа getty используется в вашей системе? Настройте систему так, чтобы была возможность войти в нее с 11-й и 12-й консолей. Настройте систему так, чтобы в нее можно было войти с помощью модема, соединившись с терминалом, запущенным на последовательном порту. Упражнение 3 : Какой MAC-адрес у вашей сетевой карты? А у ваших соседей? Установите и запустите утилиту arpwatch для отслеживания изменений в вашей локальной сети. 1.1 Решения Решение 1 : Запустите dhclient ifconfig eth0 192.168.0.42 netmask 255.255.255.0 route del default gw route add default gw 192.168.0.254 Отредактируйте файл /etc/sysconfig/network-scripts/ifcfgeth0. Упражнение 2 : Посмотрите в файле /etc/inittab Отредактируйте /etc/inittab Упражнение 3 : ifconfig ping 192.168.0.x arp -a Следуйте инструкциям, приведенным в разделе arpwatch. 1 Дополнительные сетевые настройки. Поиск и устранение неполадок Ключевые файлы, термины и утилиты: /sbin/route /sbin/ifconfig /bin/netstat /bin/ping /sbin/arp /usr/sbin/tcpdump /usr/sbin/lsof /usr/bin/nc 1.2 VPN Определение VPN (Virtual Private Network – виртуальная частная сеть) – это технология передачи данных, использующая существующую инфраструктуру (Интернет) для создания виртуальных туннелей между хостами и сетями. Туннели могут быть зашифрованы, защищая, таким образом, данные, передаваемые по небезопасному соединению. Для создания VPN, один из хостов должен шифровать данные, а другой хост – дешифровать их перед маршрутизацией к непосредственному получателю. Технологии VPN Наиболее известные технологии: PPP поверх SSH (SSL) VTUN (UDP) IPSEC (протоколы AH, ESP, IPCOMP и IKE) PPTP (Microsoft) CIPE (Crypto IP Encapsulation) Утилиты Linux для настройки VPN OpenSwan (замена FreeSwan) OpenVPN vtun / vtund OpenSSH pptp-server 1.1 Поиск и устранение проблем Ping Ping - хорошо известная утилита диагностирования сети. [root@test root]# ping -c 1 192.168.0.254 PING 192.168.0.254 (192.168.0.254) 56(84) bytes of data. 64 bytes from 192.168.0.254: icmp_seq=1 ttl=128 time=0.347 ms --- 192.168.0.254 ping statistics --1 packets transmitted, 1 received, 0% packet loss, time 0ms rtt min/avg/max/mdev = 0.347/0.347/0.347/0.000 ms [root@test root]# Ping посылает ICMP-пакеты (ICMP_ECHO_REQUEST) и ожидает ответа (ICMP_ECHO_REPLY). Утилита используется для выяснения того, функционирует ли какой-либо хост. Netstat Утилита Netstat отображает сетевые соединения, таблицы маршрутизации, статистику по интерфейсам, «маскарадные» соединения 3 и участие в многоадресных рассылках данных: [root@test root]# netstat -tua Active Internet connections (servers and established) Proto Recv-Q Send-Q Local Address Foreign Address tcp 0 0 localhost:32768 *:* tcp 0 0 *:imaps *:* tcp 0 0 *:pop3s *:* tcp 0 0 *:ldap *:* tcp 0 0 *:submission *:* tcp 0 0 *:pop3 *:* ... [SNIP] ... tcp 0 0 *:https *:* tcp 0 0 *:ldaps *:* udp 0 0 *:10000 *:* udp 0 0 *:746 *:* udp 0 0 *:749 *:* udp 0 0 *:sunrpc *:* State LISTEN LISTEN LISTEN LISTEN LISTEN LISTEN LISTEN LISTEN 3 «Маскарад» («masquerade») - одна из технологий сетевой трансляции адресов (NAT), позволяющая подключить локальную сеть к внешней, используя лишь один «настоящий» IP-адрес (для шлюза),-прим.ред. udp 0 0 *:ipp [root@test root]# *:* Чаще всего с командой netstat используются следующие опции: -t : tcp-соединения -u : udp-соединения -a : отображает сокеты, ожидающие и не ожидающие соединения -n : не выполнять преобразование IP-адресов в имена traceroute Утилита traceroute отображает путь, проходимый пакетом для достижения хоста, которому он предназначается. Путь представляется как список маршрутизаторов, через которые прошел пакет. [root@test root]# traceroute www.lynuxtraining.com traceroute to www.lynuxtraining.com (80.74.141.177), 30 hops max, 38 byte packets 1 ARISTOTE (192.168.0.254) 0.429 ms 0.207 ms 0.138 ms 2 nas-9t-lyo-3.nas.gaoland.net (62.106.138.36) 153.738 ms 149.115 ms 150.032 ms 3 V36.core1.lyo.gaoland.net (62.39.1.33) 155.857 ms 143.076 ms 144.016 ms 4 V4094.core1.cbv.gaoland.net (212.94.160.1) 149.877 ms 143.129 ms 149.892 ms 5 V3994.cbv1-co-1.gaoland.net (212.94.162.210) 144.010 ms 143.354 ms 143.884 ms 6 above.FreeIX.net (213.228.3.234) 156.043 ms 167.703 ms 150.071 ms 7 ge12-0.cr2.cdg2.fr.above.net (208.184.231.234) 155.856 ms 155.256 ms 155.883 ms 8 so-0-2-0.cr1.fra1.de.above.net (64.125.31.138) 168.015 ms 173.700 ms 167.933 ms 9 pos1-0.er1a.fra1.de.above.net (216.200.116.129) 168.030 ms 167.754 ms 173.911 ms 10 216.200.114.246.reverse.not.updated.above.net (216.200.114.246) 180.092 ms 167.796 ms 173.941 ms 11 r1ffm.vianw.net (213.2.252.65) 167.942 ms 173.209 ms 173.825 ms 12 zrhth1001.ch.vianw.net (213.2.254.26) 174.036 ms 173.590 ms 173.914 ms 13 ch-tixzh-cr2.metanet.ch (80.74.134.13) 167.981 ms 179.829 ms 167.982 ms 14 arc80-74-141-177.ch-meta.net (80.74.141.177) 167.852 ms 172.765 ms 173.993 ms [root@test root]# tcpdump Утилита tcpdump предназначена для вывода на экран или в файл сетевого трафика. Утилита очень полезна для диагностики и устранения проблем, возникающих в сети. Для понимания выводимых утилитой данных необходимо хорошее знание сетевых протоколов. [root@test root]# tcpdump -i eth0 tcpdump: verbose output suppressed, use -v or -vv for full protocol decode listening on eth0, link-type EN10MB (Ethernet), capture size 96 bytes 23:16:09.728970 IP 192.168.0.42.32770 > ARISTOTE.domain: 25979+ A? test. (33) 23:16:09.729675 arp who-has 192.168.0.42 tell ARISTOTE 23:16:09.729695 arp reply 192.168.0.42 is-at 00:40:f4:98:d2:d9 23:16:09.729796 IP ARISTOTE.domain > 192.168.0.42.32770: 25979 NXDomain0/0/0 (33) 23:16:09.729897 IP 192.168.0.42.32770 > ARISTOTE.domain: 25980+ A? Ooip. (22) ... [SNIP] ... 23:16:10.924134 IP 192.168.0.42.32848 > arc80-74-141-177.ch-meta.net.http: P 1:353(352) ack 1 win 5840 <nop,nop,timestamp 8727910 839017376> 38 packets captured 38 packets received by filter 0 packets dropped by kernel [root@test root]# Существует возможность добавления фильтров, чтобы видеть только определенную часть трафика: [root@test root]# tcpdump -i eth0 dst www.lynuxtraining.com and port 80 tcpdump: verbose output suppressed, use -v or -vv for full protocol decode listening on eth0, link-type EN10MB (Ethernet), capture size 96 bytes 23:22:42.053767 IP 192.168.0.42.32870 > arc80-74-141-177.ch-meta.net.http: P 2566206792:2566207294(502) ack 3283895847 win 63712 <nop,nop,timestamp 9119099 839055676> ... [SNIP] ... 23:22:44.073759 IP 192.168.0.42.32870 > arc80-74-141-177.ch-meta.net.http: . ack 18825 win 63712 <nop,nop,timestamp 9121120 839056650> 23:22:44.085583 IP 192.168.0.42.32870 > arc80-74-141-177.ch-meta.net.http: . ack 18916 win 63712 <nop,nop,timestamp 9121132 839056661> 15 packets captured 24 packets received by filter 0 packets dropped by kernel [root@test root]# lsof Аббревиатура «lsof» расшифровывается как LiSt Open Files – «перечислить открытые файлы». Эта утилита выводит на экран файлы, открытые различными процессами: [root@test root]# lsof /dev/log COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME syslogd 1002 root 0u unix 0xcf360a00 4202 /dev/log [root@test root]# [root@test root]# lsof -i COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME portmap 988 rpc 3u IPv4 4167 UDP *:sunrpc portmap 988 rpc 4u IPv4 4186 TCP *:sunrpc (LISTEN) rpc.statd 1049 root 4u IPv4 4313 UDP *:804 rpc.statd 1049 root 5u IPv4 4291 UDP *:801 rpc.statd 1049 root 6u IPv4 4327 TCP *:807 (LISTEN) ypserv 1065 root 5u IPv4 4356 UDP *:819 ypserv 1065 root 6u IPv4 4361 TCP *:822 (LISTEN) rpc.ypxfr 1494 root 4u IPv4 4794 UDP *:823 rpc.ypxfr 1494 root 5u IPv4 4797 TCP *:825 (LISTEN) X 1546 root 1u IPv4 4948 TCP *:x11 (LISTEN) slapd 1563 ldap 7u IPv4 4938 TCP *:ldap (LISTEN) slapd 1563 ldap 8u IPv4 9766 TCP localhost:ldap>localhost:32872 (ESTABLISHED) slapd 1563 ldap 14u IPv4 685334 TCP localhost:ldap>localhost:33132 (ESTABLISHED) slapd 1563 ldap 16u IPv4 6181 TCP localhost:ldap>localhost:32785 (ESTABLISHED) slapd 1563 ldap 17u IPv4 6664 TCP localhost:ldap>localhost:32820 (ESTABLISHED) slapd 1563 ldap 23u IPv4 6675 TCP localhost:ldap>localhost:32822 (ESTABLISHED) ... [пропущено] ... named 3832 named 26u IPv4 9787 esd 3845 csahut 29u IPv4 9789 (CLOSE_WAIT) snort 4260 snort 5u IPv4 685333 >localhost:ldap (ESTABLISHED) [root@test root]# TCP localhost:rndc (LISTEN) TCP test:32873->test:squid TCP localhost:33132- nc Название утилиты nc происходит от NetCat. Это универсальная утилита для работы с протоколом TCP/IP. Примеры: Ожидание соединения на порту 23 [root@test root]# nc -l -p 2323 Инициирование соединения с портом 23 [root@test root]# nc -l -p 2323 Передача файла [root@server root]# nc -l -p 2121 > my_file [root@sclient root]# cat my_file | nc -q0 192.168.0.69 2121 Передача и упаковка каталога [root@server root]# nc -l -p 2121 | gzip -c -d | tar -x [root@sclient root]# tar -c my_dir | gzip -c | nc -q0 192.168.0.69 2121 Защищенная передача файла [root@server root]# nc -l -p 2121 | gpg –decrypt > my_file [root@sclient root]# cat my_file | gpg -c | nc -q0 192.168.0.69 2121 1.1 Упражнения Упражнение 1: Почему вам следует настроить VPN ? Упражнение 2 : Запустите команду ping и отследите ее и только ее пакеты с помощью tcpdump. Какой протокол использует утилита traceroute? Отфильтруйте эти пакеты с помощью tcpdump и распечатайте содержимое пакетов в шестнадцатеричном и ascii форматах. Воспользуйтесь netcat для передачи файлов. Запретите вашему компьютеру отвечать на ICMP-пакеты. 1.1 Решения Решение 1: Позволяет пользователям получить доступ к локальной сети откуда угодно, обеспечивая необходимый уровень безопасности Чтобы безопасно соединить несколько офисов Низкая цена решения Решение 2 : tcpdump -i eth0 icmp and src 192.168.0.42 and dst 192.168.0.69 tcpdump -i eth0 udp and src 192.168.0.42 and dst 192.168.0.69 Воспользуйтесь командами netcat, описанными в параграфе, посвященном этой утилите echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all Почта и новости В этой главе 2.1 Вступление .................................................................................... Почта и новости ............................................................................................................................................ 31 2.2 Настройка....................................................................................... 1 Использование Sendmail .......................................................................................................................... 32 2.3 Примеры ........................................................................................ 1.1 Использование Sendmail .................................................................................................................................... 33 2.4 Упражнения.................................................................................... 1.2 Упражнения ......................................................................................................................................................... 38 2.5 Решения ......................................................................................... 1.3 Решения .............................................................................................................................................................. 39 2 Управление почтовым трафиком ............................................................................................................40 1 Использование Sendmail Ключевые файлы, термины и утилиты: /etc/aliases sendmail.cw virtusertable genericstable Дата последнего изменения требований LPI (LPI Objective):24 августа 2001 года 1.2 Использование Sendmail Введение Sendmail – это одна из самых старых почтовых программ. Она была создана Эриком Оллмэном (Eric Allman) в 1979 году. Несмотря на некоторые ошибки, влияющие на безопасность, она широко используется в Интернете и установлена на большом числе почтовых серверов. Программа sendmail знаменита своим конфигурационным файлом sendmail.cf, который очень тяжело понять, когда редактируешь его впервые. Настройка Файл sendmail.cf нелегко редактировать, поэтому для настройки sendmail мы воспользуемся другим, гораздо более простым файлом sendmail.cm. Затем мы используем интерпретатор макро-языка m4, чтобы получить sendmail.cf на основе нашего варианта sendmail.mc. Пример файла sendmail.mc : [root@test majordomo-1.94.5]# cat /etc/mail/sendmail.mc divert(-1) dnl This is the macro config file used to generate the /etc/sendmail.cf dnl file. If you modify the file you will have to regenerate the dnl /etc/sendmail.cf by running this macro config through the m4 dnl preprocessor: dnl dnl m4 /etc/sendmail.mc > /etc/sendmail.cf dnl dn0l You will need to have the sendmail-cf package installed for this to dnl work. dnl dnl dnl dnl dnl dnl dnl ( Это файл с макросами настройки, используемыми для генерации файла /etc/sendmail.cf Если вы измените его, вам потребуется перестроить файл /etc/sendmail.cf с помощью запуска интерпретатора m4 командой: m4 /etc/sendmail.mc > /etc/sendmail.cf Пакет sendmail-cf должен быть установлен для того, чтобы это сработало) include(`/usr/share/sendmail-cf/m4/cf.m4')dnl define(`confDEF_USER_ID',``mail:mail'')dnl OSTYPE(`linux')dnl undefine(`UUCP_RELAY')dnl undefine(`BITNET_RELAY')dnl define(`confDOMAIN_NAME', `[email protected]')dnl define(`confTRUSTED_USERS',`majordomo')dnl define(`confALIAS_WAIT', `30')dnl define(`confTO_CONNECT', `1m')dnl define(`confTRY_NULL_MX_LIST',true)dnl define(`confDONT_PROBE_INTERFACES',true)dnl define(`PROCMAIL_MAILER_PATH',`/usr/bin/procmail')dnl dnl define delivery mode: interactive, background, or queued dnl определение режима доставки: интерактивный (i), фоновый (b), dnl или использующий очереди (q)) dnl define(`confDELIVERY_MODE', `i') MASQUERADE_AS(`localhost.localdomain')dnl FEATURE(`limited_masquerade')dnl FEATURE(`masquerade_envelope')dnl FEATURE(`smrsh',`/usr/sbin/smrsh')dnl FEATURE(mailertable)dnl dnl virtusertable: redirect incoming mail to virtual domain to particular user or domain dnl ( параметр virtusertable служит для перенаправления почты адресованной виртуальному домену на адрес конкретного домена или пользователя ) FEATURE(`virtusertable',`hash -o /etc/mail/virtusertable')dnl dnl genericstable: rewrite sender address for outgoing mail dnl (параметр genericstable служит для перезаписи адреса отправителя в исходящих письмах) dnl FEATURE(genericstable)dnl FEATURE(always_add_domain)dnl FEATURE(redirect)dnl FEATURE(use_cw_file)dnl ... [пропущено] ... (`confDONT_BLAME_SENDMAIL',`GroupWritableAliasFile,IncludeFileInGroupWritable DirPath') You have new mail in /var/spool/mail/root [root@test majordomo-1.94.5]# Пример sendmail.cf : [root@test majordomo-1.94.5]# cat /etc/mail/sendmail.cf ... [пропущено] ... Sfinal=4 R$+ :; <@> R$* <@> $@ $1 : $@ handle <list:;> handle <> and list:; # strip trailing dot off possibly canonical name # ( удаление замыкающий точки в вероятно канонических именах ) R$* < @ $+ . > $* $1 < @ $2 > $3 # eliminate internal code # ( исключение внутреннего кода ) R$* < @ *LOCAL* > $* $1 < @ $j > $2 # externalize local domain info # ( конкретизация информации о локальном домене ) R$* < $+ > $* $1 $2 $3 R@ $+ : @ $+ : $+ @ $1 , @ $2 : $3 canonical R@ $* $@ @ $1 defocus <route-addr> ... and exit # UUCP must always be presented in old form # ( UUCP всегда должен присутствовать в старом формате ) R$+ @ $- . UUCP $2!$1 [email protected] => h!u # delete duplicate local names # ( удаление дубликатов в локальных именах ) R$+ % $=w @ $=w $1 @ $2 ... [SNIP] ... SAddDomain R$* < @ $* > $* $@ $1 < @ $2 > $3 already fully qualified R$+ add local qualification $@ $1 < @ *LOCAL* > u%host@host => u@host Mlocal, P=/usr/bin/procmail, F=lsDFMAw5:/|@qSPfhn9, S=EnvFromL/HdrFromL, R=EnvToL/ HdrToL, T=DNS/RFC822/X-Unix, A=procmail -Y -a $h -d $u Mprog, P=/usr/sbin/smrsh, F=lsDFMoqeu9, S=EnvFromL/HdrFromL, R=EnvToL/HdrToL, D=$ z:/, T=X-Unix/X-Unix/X-Unix, A=smrsh -c $u [root@test majordomo-1.94.5]# Как правило, мы будем редактировать sendmail.mc и конвертировать его затем в sendmail.cf с помощью команды: [root@test majordomo-1.94.5]# m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf sendmail.mc Несколько полезных ключевых слов, которые по сути являются командами языка m4: divert : начала комментария. Комментарий продолжается до следующей команды divert include(`/usr/share/sendmail-cf/m4/cf.m4')dnl : использовать файл cf.m4 для генерации sendmail.cf OSTYPE(`linux')dnl : Определение операционной системы, на которой будет работать sendmail define(`confTRUSTED_USERS',`majordomo')dnl : установить значение переменной “confTRUSTED_USERS” равной “majordomo”. FEATURE(`smrsh',`/usr/sbin/smrsh')dnl : Одна из настроек sendmail. Настроек у этой программы огромное множество, и описать их всех в этом документе не представляется возможным. Почтовые псевдонимы Файл с описанием почтовых псевдонимов /etc/aliases (или /etc/mail/aliases) имеет следующий формат: bin: daemon: games: ingres: nobody: system: toor: uucp: root root root root root root root root В этом примере почтовые сообщения для таких адресатов, как например system или daemon будут перенаправлены в почтовый ящик пользователя root. Кроме того, можно запускать программу каждый раз, когда какой-то пользователь получает письмо. Эта возможность используется majordomo. Для этого используется следующий синтаксис: majordomo | /path/to/executable Можно перенаправить почту на другой адрес: user [email protected] Заметьте, что пользователи могут делать это самостоятельно, указав эту строчку в файле .forward в своём домашнем каталоге. Можно создать очень простой список рассылки: localadmins john, robert, paul Каждый раз после изменения этого файла необходимо запустить команду newaliases для того, чтобы изменения вступили в силу. [root@test root]# newaliases /etc/aliases: 29 aliases, longest 73 bytes, 855 bytes total [root@test root]# 1.3 Упражнения Упражнение 1 : Выполните базовую настройку Sendmail. Настройте свою систему так, чтобы она могла получать и отправлять письма sendmail, запущенным на компьютерах ваших соседей. Создайте почтовые псевдонимы 1.1 Решения Решение 1 : Используйте конфигурацию sendmail по умолчанию и укажите имя вашего почтового домена. Используйте команду mail. Письма можно посмотреть в /var/spool/mail Отредактируйте /etc/aliases 1 Управление почтовым трафиком Ключевые файлы, термины и утилиты: procmail 1.2 Вступление Procmail используется для сортировки, фильтрации входящей почты и выполнения других задач. Он может применяться как на стороне сервера, так и на стороне клиента, если вы предпочитаете не использовать специализированный почтовый агент. 1.3 Настройка Когда пользователь получает новую почту, агент передачи почтовых сообщений (MTA) проверяет файл .forward в домашнем каталоге пользователя. Если он обнаруживает там почтовый адрес, то вся почта перенаправляется на него. Иначе письма складываются в локальный почтовый ящик пользователя. .forward Файл .forward может быть использован в том числе для передачи почты в другую программу, такую как procmail. Это делается с помощью каналов, например вот так: "|IFS=' '&&exec /usr/bin/procmail -f-||exit 75 #ВАШЕ_ИМЯ" Путь должен указывать на исполняемый файл команды procmail. Используйте which procmail для того, чтобы узнать, где он находится. Комментарий важен для отладки, особенно если больше одного пользователя имеют свои procmail-сценарии. Некоторые MTA умеют использовать procmail по умолчанию, в этом случае файл .forward вам не понадобится. Нам не потребуется такая настройка, так как мы используем sendmail, а он по умолчанию запускает procmail в качестве программы для доставки писем: [root@test root]# grep procmail /etc/mail/sendmail.mc define(`PROCMAIL_MAILER_PATH',`/usr/bin/procmail')dnl FEATURE(local_procmail)dnl MAILER(procmail)dnl [root@test root]# .procmailrc Итак, поступившее письмо было перенаправлено программе procmail. Чтобы обработать его, procmail ищет свой конфигурационный файл .procmailrc в домашнем каталоге пользователя Пример файла .procmailrc: :0c: $HOME/mail.backup Эта настройка обозначает дописывание копии любого входящего письма к файлу $HOME/mail.backup. Копирование производится потому, что в первой строке указан флаг 'c', требующий скопировать письмо. После второго двоеточия можно указать имя файла блокировки. Если оставить это поле пустым, procmail автоматически создаёт файл блокировки lockfile. Если второе двоеточие отсутствует, файл блокировки не создаётся. Файл может содержать больше одной команды. Если .procmailrc не найден, или письмо не удовлетворяет ни одному их условий, оно добавляется к стандартному файлу входящей почты, как это происходит при обычной доставке. Формат .procmailrc Стартовая строка :0 с указанием нескольких флагов Условия Строка, начинающаяся с символа * Доставка файл или каталог, в который нужно передать почту, или строка начинающаяся с | или ! 1.1 Примеры Игнорирование писем :0 * ^From.*[email protected] /dev/null Письма с подходящим условию значением поля From будут сохранены в файл /dev/null. Запуск сценарии при получении почты :0 * !^FROM_DAEMON * !^FROM_MAILER * !^X-Loop: [email protected] | $HOME/bin/my.script Все письма будут переданы на вход указанному скрипту, за исключением писем от почтовых сервисов, почтовых программ, или писем, имеющих заголовок XLoop, содержащий [email protected]. Автоматический ответ :0 * ^FROM.*[email protected] | (formail -rk \ -A "X-Loop: [email protected]" ; \ echo "This is an automated response";\ echo "I am away from office, I will read your message later :)";\ echo "I'll be back on the 1st of september"; ) | /usr/sbin/sendmail -t -oi Команда formail может написать письмо в ответ на другое (-r), сохранив содержимое (-k). Полученное письмо будет перенаправлено команде sendmail, с указанием взять адрес корреспондента из поля заголовка “To:” (-t). Параметр -A добавляет дополнительные заголовки к письму. Заголовок X-Loop поможет избежать зацикливания, если у вашего корреспондента установлен такой же скрипт. 1.2 Упражнения Упражнение 1 : Настройте вашу систему на использование procmail Настройте ваш систему так, чтобы она автоматически отсылала ответы на все письма 1.1 Решения Решение 1 : Следуйте инструкциям этой главы Используйте команду formail DNS В этой главе 2.2 Упражнения.................................................................................... DNS .................................................................................................................................................................. 47 2.3 Решения ......................................................................................... 1 Базовая настройка BIND .......................................................................................................................... 48 3 Обеспечение безопасности DNS – сервера .......................... 1.1 Настройка BIND ................................................................................................................................................. 49 3.1 Безопасность DNS......................................................................... 1.2 Упражнения ......................................................................................................................................................... 53 3.2 Упражнения.................................................................................... 1.3 Решения .............................................................................................................................................................. 54 3.3 Решения ......................................................................................... 2 Создание и поддержка зон DNS ............................................................................................................. 55 2.1 Создание зоны DNS ........................................................................................................................................... 56 1 Базовая настройка BIND Ключевые файлы, термины и команды: /etc/named.conf /usr/sbin/ndc /usr/sbin/named-bootconf kill 1.2 Настройка BIND Аббревиатура «BIND» расшифровывается как «Berkeley Internet Name Domain». Данный продукт является наиболее распространенным среди DNS – серверов в Интернете и работает на операционных системах Linux, Unix, а также на платформах Windows. Существуют три главных ветви разработки BIND: Версия 4.х : старая версия, обновления только в части безопасности Версия 8.х : новое поколение BIND Версия 9.х : замена версии BIND 8 Для установки нового DNS – сервера Вам необходимо выбрать последнюю версию 9 – ого поколения. Файл /etc/named.conf - основной конфигурационный файл. На разных платформах его местоположение варьируется. Данный файл содержит директивы inlcude для других конфигурационных файлов, что упрощает их поддержку. В версиях 4.х использовался файл /etc/named.boot, которого нет в более поздних версиях. Для преобразования его в формат 8 и 9 версий воспользуйтесь утилитой named-bootconf. При настройке DNS – сервера необходимо создать файл, в котором определяются зоны. Обычно он размещается в директории /var/named/, но это настраивается в файле /etc/named.conf. Команда ndc больше не используется, вместо нее появилась команда rndc. Кэширующий сервер имен. Создайте этот файл /etc/named.conf: [root@test root]# cat > /etc/named.conf << EOF > controls { > allow { 127.0.0.1; }; > }; > > options { > directory "/var/named"; > pid-file "/var/named/named.pid"; > forwarders { 192.168.0.254; }; > }; > EOF [root@test root]# Перезапустите BIND : [root@test root]# /etc/init.d/named restart Остановка named: rndc: свзяь прервана: соединение не установлено [ OK Запуск named: [ OK [root@test root]# ] ] Отредактируйте файл /etc/resolv.conf для работы с вашим DNS – сервером. Теперь вы должны быть способны разрешать DNS – имена самостоятельно: [root@test root]# echo "nameserver 192.168.0.42" > /etc/resolv.conf [root@test root]# ping www.lynuxtraining.com PING www.lynuxtraining.com (80.74.141.177) 56(84) bytes of data. 64 bytes from arc80-74-141-177.ch-meta.net (80.74.141.177): icmp_seq=1 ttl=51 time=203 ms 64 bytes from arc80-74-141-177.ch-meta.net (80.74.141.177): icmp_seq=2 ttl=51 time=179 ms --- www.lynuxtraining.com ping statistics --2 packets transmitted, 2 received, 0% packet loss, time 1001ms rtt min/avg/max/mdev = 179.680/191.397/203.115/11.725 ms [root@test root]# Настройка RNDC Аббревиатура «RNDC» обозначает «Remote Name Daemon Control». Этот инструмент предназначен для управления удаленными (и конечно же, локальными) серверами служб доменных имен. Он использует заранее распределенные ключи (pre-shared keys) в качестве механизма авторизации. В BIND встроена команда rndc-confgen , результатом работы которой является создание конфигурационного файла для RNDC. root@test root]# rndc-confgen |tee /etc/rndc.conf # Начало файла rndc.conf key "rndc-key" { algorithm hmac-md5; secret "HDE+7c4aA5V470ghHlZfAw=="; }; options { default-key "rndc-key"; default-server 127.0.0.1; default-port 953; }; # Конец файла rndc.conf # Используйте следующие команды в файле named.conf, чтобы настроить список #разрешенных адресов так, как необходимо: # key "rndc-key" { # algorithm hmac-md5; # secret "HDE+7c4aA5V470ghHlZfAw=="; # }; # # controls { # inet 127.0.0.1 port 953 # allow { 127.0.0.1; } keys { "rndc-key"; }; # }; # Конец файла named.conf [root@test root]# Скопируйте вторую часть файла rndc.conf в файл named.conf и перезапустите службу BIND. Протестируйте BIND : [root@test root]# rndc -s 127.0.0.1 status number of zones: 2 debug level: 0 xfers running: 0 xfers deferred: 0 soa queries in progress: 0 query logging is OFF server is up and running [root@test root]# Запустите rndc без параметров , чтобы увидеть список доступных действий: [root@test root]# rndc Usage: rndc [-c config] [-s server] [-p port] [-k key-file ] [-y key] [-V] command command is one of the following: reload Reload configuration file and zones. reload zone [class [view]] Reload a single zone. refresh zone [class [view]] Schedule immediate maintenance for a zone. reconfig Reload configuration file and new zones only. stats Write server statistics to the statistics file. querylog Toggle query logging. dumpdb Dump cache(s) to the dump file (named_dump.db). stop Save pending updates to master files and stop the server. halt Stop the server without saving pending updates. trace Increment debugging level by one. trace level Change the debugging level. notrace Set debugging level to 0. flush Flushes all of the server's caches. flush [view] Flushes the server's cache for a view. status Display status of the server. *restart Restart the server. * == not yet implemented Version: 9.2.3 [root@test root]# 1.1 Упражнения Упражнение 1 : Настройте кэширующий сервер доменных имен. Настройте команду RNDC Просмотрите журналы службы доменных имен 1.1 Решения Следуйте инструкциям этой главы 1 Создание и поддержка зон DNS Ключевые файлы, термины и команды: содержимое /var/named синтаксис файла зоны форматы ресурсных записей dig nslookup host 1.2 Создание зоны DNS Теперь мы хотим стать авторизованным (authoritative) DNS-сервером для своей зоны. В этом примере мы создали зону под названием domain.org Для каждого домена необходимы два файла, путь к которым определяется в /etc/named.conf: Один для разрешения имен в IP-адреса. Другой для разрешения IP-адресов в имена. Добавьте в файл named.conf : zone "domain.org" { type master; file "zone/domain.org.zone"; }; zone "0.168.192.in-addr.arpa" { type master; file "zone/0.168.192.rev.zone"; }; Создайте два новых файла : Файл /var/named/zone/domain.org.zone : $TTL @ mail ns www 1H IN SOA 2004050403 1H 1H 1H 1D ) IN NS IN MX IN A IN A IN A smtp IN CNAME ns.domain.org root.domain.org. ( ; Serial ; Refresh ; Retry ; Expire ; Negative Cache TTL ns.domain.org. 10 mail.domain.org. 192.168.0.254 192.168.0.42 192.168.0.69 mail и файл /var/named/zone/0.168.192.rev.zone : $TTL 1H @ IN @ 42 69 254 IN IN IN IN IN SOA NS MX PTR PTR PTR ns.domain.org. root.domain.org. ( 2004050403 ; Serial 1H ; Refresh 1H ; Retry 1H ; Expire 1D ) ; Negative Cache TTL 10 ns.domain.org. mail.domain.org. ns.domain.org. www.domain.org. mail.domain.org. Файлы зон формируются из записей ресурсов (RR). Ключевые понятия: SOA (Источник полномочий) Управление различными временными параметрами, касающимися разрешения имени. NS (Сервер имен) Определяет серверы имен MX (Почтовый агент) Определяет почтовые сервера и их приоритет A: соответствие имени адресу PTR: соответствие адреса имени CNAME (каноническое имя): псевдонимы Проверьте синтаксис ваших конфигурационных файлов: [root@test root]# named-checkconf [root@test root]# named-checkzone domain.org /var/named/zone/domain.org.zone zone domain.org/IN: loaded serial 2004050403 OK [root@test root]# named-checkzone domain.org /var/named/zone/0.168.192.rev.zone zone domain.org/IN: loaded serial 2004050403 OK [root@test root]# Откройте на редактирование файл /etc/resolv.conf и добавьте в него запись о вашем DNS-сервере : [root@test root]# cat /etc/resolv.conf search domain.org nameserver 192.168.0.42 [root@test root]# Директива search позволить вам разрешать имена хостов без использования FQDN (полностью квалифицированного доменного имени) Протестируйте ваш DNS-сервер : [root@test root]# nslookup > mail Server: 192.168.0.42 Address: 192.168.0.42#53 Name: mail.domain.org Address: 192.168.0.254 > 192.168.0.69 Server: 192.168.0.42 Address: 192.168.0.42#53 69.0.168.192.in-addr.arpa > name = www.domain.org. Главный и подчиненный Сервер может быть подчиненным (slave) для одной зоны и главным (master) для другой. В первом случае, сервер работает как резервная копия DNS – сервера и отвечает на клиентские запросы , когда основной сервер не работает. Передача зоны от главного сервера к подчиненному выполняется автоматически. Для того, чтобы стать подчиненным для test.domain.org, добавьте следующее в файл named.conf на подчиненном сервере. zone "test.domain.org" { type slave; masters { 192.168.0.42; }; file "/var/named/zone/test.domain.org.zone"; }; Добавьте следующее в файл named.conf zone "test.domain.org" { type master; file "zone/test.domain.org.zone"; allow-transfert {192.168.0.69;}; }; на главном сервере: Перезагрузите подчиненный DNS – сервер. Передача зоны. Добавьте следующие строки в файл domain.org.zone : sub.domain.org. ns.sub.domain.org. IN IN NS A ns.sub.domain.org. 192.168.0.43 ; и эти строки в файл 0.168.192.rev.zone: sub.domain.org. 43 IN IN NS PTR ns.sub.domain.org. ns.sub.domain.org. Затем сделайте новый DNS – сервер авторизованным для зоны sub.domain.org 1.1 Упражнения Упражнение 1 : Создайте свою зону (без обратного зоны) Проверьте ее при помощи команд nslookup, dig или host Создайте обратную зону и протестируйте ее. Настройте ваш сервер так, чтобы он был главным для одной зоны и резервным для другой. 1.1 Решения Решение 1 : Следуйте инструкциям данной главы. 1 Обеспечение безопасности DNS – сервера Ключевые файлы, термины и команды: SysV init files или rc.local /etc/named.conf /etc/passwd dnskeygen 1.2 Безопасность DNS Безопасность DNS чрезвычайно важна для сети, поскольку каждый хост использует DNS. DNS – сервер должен отвечать на запрос клиента не слишком большим количеством информации, а только тем, что необходимо. Разные клиенты не могут запрашивать одну и ту же информацию у DNS – сервера. Сокрытие версии Множество инструментов, таких как nmap или amap, могут выдать версию DNS. Это не слишком безопасно, но вы можете обмануть хакера, изменив баннер, возвращаемый сервером и показав другую версию. Options { Version “None of your business”; }; Ограничение запросов В случае, если ваш DNS – сервер расчитан на работу только с внутренней сетью, то он и должен обрабатывать только внутрисетевые запросы. В этом случае, BIND позволяет ограничить ответы сервера в зависимости от IP – адреса клиента. Глобально: Options { Allow-query { 192.168.0.0/24; }; } Для зоны: Zone domain.org { Type slave; File “zone/domain.org.zone”; Allow-query { 192.168.0.0/24; }; }; Трансфер зоны Трансфер зоны происходит между DNS – серверами и их резервными копиями. Важно, чтобы загрузить себе зону могли только авторизованные подчиненные сервера, а не кто попало. На главном сервере: Options { Allow-transfer { 192.168.0.2; }; } На подчиненном сервере: Options { Allow-transfer { none; }; } Это может быть сделано сразу для всех зон, универсально, либо для каждой в отдельности. Прочее Не запускайте службу доменных имен от имени root. Используйте опцию -u, чтобы указать пользователя BIND, -g – для того, чтобы указать группу. Используйте опцию -t для определения директории chroot. В некторых дистрибутивах Linux есть пакет bind-chroot, который запускает BIND в chroot-окружении. 1.1 Упражнения Упражнение 1 : Обеспечьте безопасность вашего DNS-сервера. Проверьте трансфер зоны на резервный DNS – сервер с разных хостов. 1.1 Решения Решение 1 : Проверьте запрос на версию BIND при помощи следующей команды : [root@test root]# host -c CHAOS -t txt version.bind version.bind text "9.2.3" [root@test root]# Web-сервисы В этой главе 2.2 Apache и mod_ssl ........................................................................... Web-сервисы ................................................................................................................................................. 67 2.3 Упражнения.................................................................................... 1 Установка web-сервера ............................................................................................................................ 68 2.4 Решения ......................................................................................... 1.1 Установка и настройка Apache .......................................................................................................................... 69 3 Установка прокси-сервера ....................................................... 1.2 Упражнения ......................................................................................................................................................... 74 3.1 Настройка Squid ............................................................................ 1.3 Решения .............................................................................................................................................................. 75 3.2 Упражнения.................................................................................... 2 Поддержка web-сервера .......................................................................................................................... 76 3.3 Решения ......................................................................................... 2.1 Виртуальные сервера ........................................................................................................................................ 77 1 Установка web-сервера Ключевые файлы, термины и утилиты: access.log .htaccess httpd.conf mod_auth htpasswd htgroup 1.2 Установка и настройка Apache Введение Apache – это самый популярный web-сервер (65% всех web-серверов в мире работают под его управлением). Он является открытой реализацией протокола HTTP и известен своей надёжностью и безопасностью. Apache новых стабильных версий 2.x поддерживают многопоточность и становятся стандартным компонентом дистрибутивов Linux. Настройка Apache Основным файлом настройки является /etc/httpd/conf/httpd.conf . Иногда он расположен в каталоге /etc/apache/. Как правило, существуют и другие конфигурационные файлы, например modules.conf, который служит для загрузки модулей. В некоторых инсталляциях файл конфигурации может быть разбит на насколько частей, которые обычно находятся в каталоге /etc/httpd/conf. Корневым каталогом с документами web-сервера (т.н. Document Root, именно там находятся все файлы HTML или PHP) по умолчанию является /var/www/html. Состояние сервера Статусная страница, если она включена, доступна по адресу http://192.168.0.42/server-status4. Из соображений безопасности она не должна быть доступна из интернета. Пример: <Location /server-status> SetHandler server-status Order deny,allow Deny from all Allow from 127.0.0.1 Allow from 192.168.0.42 </Location> Информация о сервере Точно так же информационная страница, посвященная конфигурации сервера, если она включена, располагается по адресу http://192.168.0.42/server-info. Для включения этой опции необходимо загрузить модуль mod_info.c. Пример: <Location /server-info> SetHandler server-info Order deny,allow Deny from all Allow from 127.0.0.1 Allow from 192.168.0.42 </Location> 4 Конечно, имя сервера надо изменить в соответствии с вашими реалиями,-прим.ред. Авторизация при помощи .htaccess Для того, чтобы использовать аутентификацию, вам потребуется загрузить модуль mod_auth. Вот содержимое простого файла .htaccess, который нужно поместить в каталог, доступ к которому необходимо ограничить: AuthType Basic AuthName "Restricted Directory" AuthUserFile "/etc/httpd/passwd" require valid-user Файл, указанный в параметре AuthUserFile содержит пароли, его можно сгенерировать с помощью команды htpasswd. Этот файл должен находиться вне каталогов, доступных снаружи через web-сервер. Для того, чтобы создать файл паролей с паролем пользователя 'admin', выполните следующие команды : root@test root]# htpasswd -c /etc/httpd/passwd admin New password: Re-type new password: Adding password for user admin [root@test root]# Для добавления пароля пользователя к существующему файлу: [root@test root]# htpasswd /etc/httpd/passwd support New password: Re-type new password: Adding password for user support [root@test root]# Не позволяйте отправлять файлы .ht* пользователям web: <Files ~ "^\.ht"> Order allow,deny Deny from all Satisfy All </Files> Авторизация при помощи htdigest Этот метод авторизации более надёжный, чем предлагаемый .htaccess. Он работает практически так же, но использует файл htdigest вместо htpasswd. Примерное содержание файла .htaccess: AuthType Digest AuthName "Restricted Directory" AuthDigestFile "/etc/httpd/passwd_digest" require valid-user Для добавления пользователя в новый файл с паролями: [root@test conf]# htdigest -c /etc/httpd/passwd_digest "Restricted Directory" test Adding password for test in realm Restricted Directory. New password: Re-type new password: [root@test conf]# Mod_perl Для настройки mod_perl вам понадобится следующий фрагмент файла настройки (указаны параметры по умолчанию): ScriptAlias /cgi-bin/ /var/www/cgi-bin/ ScriptAlias /protected-cgi-bin/ /var/www/protected-cgi-bin/ <IfModule mod_perl.c> #Provide two aliases to the same cgi-bin directory, #to see the effects of the 2 different mod_perl modes #for Apache::Registry Mode Alias /perl/ /var/www/perl/ #for Apache::Perlrun Mode Alias /cgi-perl/ /var/www/perl/ </IfModule> Перейдите по указанному адресу для проверки работы CGI : http://192.168.0.42/cgi-bin/test.cgi Mod_PHP Для его настройки необходимо установить: apache2-mod_php php-ini Создайте файл /var/www/html/index2.php со следующим содержанием: [root@test html]# cat index2.php <? phpinfo(); ?> [root@test html]# Введите следующий адрес в адресной строке браузера: http://192.168.0.42/index2.php Вы должны увидеть страницу с информацией о версии установленного интерпретатора PHP и подключенных модулях расширения. Настройка apache Некоторые параметры: StartServers: число серверных процессов, запускаемых при старте MinSpareServers: минимальное число серверных процессов, которые могут простаивать MaxSpareServers: максимальное число серверных процессов, которые могут простаивать MaxClients: максимальное число серверных процессов, которые могут быть запущены одновременно MaxRequestsPerChild: максимальное число запросов, которое может обработать один серверный процесс MaxKeepAliveRequests: максимальное число запросов, поддерживаемых одновременно 1.1 Упражнения Упражнение 1 : Настройте Apache и проверьте состояние сервера и информацию о серверных настройках Настройте доступ в один каталог с использованием базовой авторизации, а в другой – с использованием digest-авторизации Настройте mod_perl, mod_php и проверьте их работу 1.1 Решения Решение 1 : Следуйте инструкциям из этой главы 1 Поддержка web-сервера Ключевые файлы, термины и утилиты: httpd.conf 1.2 Виртуальные сервера Для использования виртуальных серверов вам потребуется загрузить модуль mod_vhost. Виртуальные сервера на базе имени Виртуальный сервер может быть определён по полю URL HTTP запроса. Отредактируйте файл /etc/httpd/conf/vhosts/Vhosts.conf : NameVirtualHost 192.168.0.42 <VirtualHost 192.168.0.42> ServerName test.domain.org DocumentRoot /var/www/html </VirtualHost> <VirtualHost 192.168.0.42> ServerName vhost1.domain.org DocumentRoot /var/www/html/vhost1 </VirtualHost> <VirtualHost 192.168.0.42> ServerName vhost2.domain.org DocumentRoot /var/www/html/vhost2 </VirtualHost> Перезапустите Apache: [root@test root]# /etc/init.d/httpd restart Shutting down httpd2: Starting httpd2: [root@test root]# Создайте виртуальные сервера [root@test [root@test [root@test [root@test [root@test [root@test root]# html]# html]# html]# html]# html]# cd /var/www/html mkdir vhost1 mkdir vhost2 echo "vhost1" > vhost1/index.html echo "vhost2" > vhost2/index.html Вы должны увидеть разные сайты, когда обратитесь по адресам http://vhost1.domain.org и http://vhost2.domain.org. [ [ OK OK ] ] Виртуальные сервера на базе IP-адресов Отредактируйте файл /etc/httpd/conf/vhosts/Vhosts.conf : <VirtualHost 192.168.0.42> DocumentRoot /var/www/html/vhost1 Servername test.domain.org </VirtualHost> <VirtualHost 192.168.0.43> DocumentRoot /var/www/html/vhost2 Servername test.domain.org </VirtualHost> Перезапустите Apache: [root@test root]# /etc/init.d/httpd restart Shutting down httpd2: Starting httpd2: [root@test root]# [ [ OK OK ] ] Добавьте новый виртуальный IP-адрес: [root@test root]# ifconfig eth0:0 192.168.0.43 [root@test root]# Вы должны увидеть разные сайты, обратившись по адресам http://192.168.12.42 or http://192.168.0.43 1.3 Apache и mod_ssl Mod_ssl – это модуль apache, используемый для создания сайтов, доступных по протоколу https. Перед тем, как настраивать в apache поддержку HTTPS, необходимо создать сертификаты. HTTPS использует SSL (Secure Socket Layer) и требует наличия OpenSSL для генерации пары «публичный-частный ключ». HTTPS-сервер должен иметь сертификат, который будет отправляться браузеру клиента. Как правило, сертификаты продаются компаниями, выполняющими роль центров сертификации. Подготовка сертификатов и ключей с помощью сценария Установите пакет apache2-modssl. Проверьте, что openssl уже инсталлирован. Запустите сценарий /usr/lib/ssl/apache2-mod_ssl/gentestcrt.sh и следуйте инструкциям: root@test root]# /usr/lib/ssl/apache2-mod_ssl/gentestcrt.sh maketestcrt -- Create self-signed test certificate (Создание самоподписанного тестового сертификата) (C) 2001 Jean-Michel Dault <[email protected]> and Mandrakesoft Based on cca.sh script by Ralf S. Engelschall Will create server.key and server.crt in /root (Будем создавать server.key и server.crt в каталоге /root ) INITIALIZATION Generating custom Certificate Authority (CA) (Создание собственного центра сертификации) ______________________________________________________________________ STEP 1: Generating RSA private key for CA (1024 bit) (ШАГ 1: Создание частного ключа RSA для центра сертификации (1024 бита)) ... [пропущено] ... 2OtXXrvWs+n9oVvJStzueZXZTtDP+/kri2GZVZoFx4EVraXENqoePSf0XQJBAJFF +/EySjBCWjzmdqlGZlrxSx2hl+afS6fJh+Ku/LC/GbfTNkAWu8q/zgCAqlNZdBGp mw2cvRpEARRX1UqObgUCQEg9W5eoA29TwwC+9tEWKg+XcTu75h2w3CR6pdB4AQl0 YHOylsceiygo9Qu6zB6jAFMaSdOfdDjdtRh9auSxNfc= -----END RSA PRIVATE KEY----Certificate creation done! (Создание сертификата завершено!) [root@test root]# Подготовка сертификатов и ключей вручную В этом примере мы создадим свой собственный центр сертификации (Certificate Authority). Для начала мы создадим частный ключ для CA (Certificate Authority): [root@test root]# cd /etc/httpd/ [root@test httpd]# mkdir ssl && chmod 700 ssl [root@test httpd]# cd ssl [root@test ssl]# openssl genrsa -des3 -out my-ca Generating RSA private key, 512 bit long modulus ........++++++++++++ ...++++++++++++ e is 65537 (0x10001) Enter pass phrase for my-ca: (Введите секретную фразу для my-ca ) Verifying - Enter pass phrase for my-ca: (Повторите секретную фразу для my-ca ) Эта секретная фраза (passphrase) является паролем к нашему центру сертификации (Certificate Authority - CA). [root@test ssl]# openssl req -new -x509 -days 3650 -key my-ca.key -out myca.crt Enter pass phrase for my-ca.key: (Введите секретную фразу для my-ca.key ) You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ( Сейчас вам будут заданы вопросы по поводу информации, которая будет включена в ваш запрос на сертификат. То, что вы собираетесь ввести, называется Отличительным Именем (Distinguished Name) или DN. У него довольно много полей, но вы можете оставить некоторые из них пустыми. Некоторые поля имеют значения по умолчанию, чтобы ввести туда пустое значение нужно набрать '.'. ) ----Country Name (2 letter code) [AU]:CH State or Province Name (full name) [Some-State]: Locality Name (eg, city) []:Geneva Organization Name (eg, company) [Internet Widgits Pty Ltd]:LynuxTraining Organizational Unit Name (eg, section) []: Common Name (eg, YOUR name) []:user Email Address []:[email protected] [root@test ssl]# [root@test ssl]# openssl genrsa -des3 -out my-apache.key 1024 Generating RSA private key, 1024 bit long modulus ......................................................................++++++ ....++++++ e is 65537 (0x10001) Enter pass phrase for my-apache.key: (Введите секретную фразу для myapache.key ) Verifying - Enter pass phrase for my-apache.key: (Повторите секретную фразу для my-apache.key ) [root@test ssl]# Теперь мы удалим секретную фразу из сертификата сервера Apache, чтобы нам не приходилось вводить её каждый раз при старте: [root@test ssl]# openssl rsa -in my-apache.key -out my-apache.key Enter pass phrase for my-apache.key: (Введите секретную фразу для my-apache ) writing RSA key [root@test ssl]# Теперь мы можем создать запрос на подпись сертификата (Certificate Signature Request), чтобы подписать его в нашем CA: [root@test ssl]# openssl req -new -key my-apache.key -out my-apache.csr You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ( Сейчас вам будут заданы вопросы по поводу информации, которая будет включена в ваш запрос на сертификат. То, что вы собираетесь ввести, называется Отличительным Именем (Distinguished Name) или DN. У него довольно много полей, но вы можете оставить некоторые из них пустыми. Некоторые поля имеют значения по умолчанию, чтобы ввести туда пустое значение нужно набрать '.'. ) ----Country Name (2 letter code) [AU]:CH State or Province Name (full name) [Some-State]:Geneva Locality Name (eg, city) []: [root@test ssl]# openssl req -new -key my-apache.key -out my-apache.csr You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ( Сейчас вам будут заданы вопросы по поводу информации, которая будет включена в ваш запрос на сертификат. То, что вы собираетесь ввести, называется Отличительным Именем (Distinguished Name) или DN. У него довольно много полей, но вы можете оставить некоторые из них пустыми. Некоторые поля имеют значения по умолчанию, чтобы ввести туда пустое значение нужно набрать '.'. ) ----Country Name (2 letter code) [AU]:CH State or Province Name (full name) [Some-State]: Locality Name (eg, city) []: [root@test ssl]# openssl req -new -key my-apache.key -out my-apache.csr You are about to be asked to enter information that will be incorporated into your certificate request. What you are about to enter is what is called a Distinguished Name or a DN. There are quite a few fields but you can leave some blank For some fields there will be a default value, If you enter '.', the field will be left blank. ( Сейчас вам будут заданы вопросы по поводу информации, которая будет включена в ваш запрос на сертификат. То, что вы собираетесь ввести, называется Отличительным Именем (Distinguished Name) или DN. У него довольно много полей, но вы можете оставить некоторые из них пустыми. Некоторые поля имеют значения по умолчанию, чтобы ввести туда пустое значение нужно набрать '.'. ) ----Country Name (2 letter code) [AU]:CH State or Province Name (full name) [Some-State]: Locality Name (eg, city) []:Geneva Organization Name (eg, company) [Internet Widgits Pty Ltd]:LynuxTraining Organizational Unit Name (eg, section) []: Проверьте, что вы поместили полное доменное имя (FQDN) в поле “Common Name” ! Common Name (eg, YOUR name) []:test.domain.org Email Address []:[email protected] Please enter the following 'extra' attributes to be sent with your certificate request (Пожалуйста, укажите следующие дополнительные атрибуты, которые будут отправлены вместе с запросом на подпись сертификата) A challenge password []: An optional company name []: [root@test ssl]# И, наконец, мы подпишем сертификат Apache в нашем центре сертификации: [root@test ssl]# openssl x509 -req -in my-apache.csr -out my-apache.crt -sha1 -CA my-ca.crt -CAkey my-ca.key -CAcreateserial -days 36 Signature ok subject=/C=CH/ST= /L=Geneva/O=LynuxTraining/CN=test.domain.org/[email protected] g Getting CA Private Key (Получение частного ключа CA) Enter pass phrase for my-ca.key: (Введите секретную фразу для my-ca.key ) [root@test ssl]# ls my-apache.crt my-apache.csr my-apache.key my-ca.crt my-ca.key my-ca.srl [root@test ssl]# Изменяем права доступа: [root@test ssl]# chmod 0400 *.key [root@test ssl]# Настройка Apache Отредактируйте /etc/httpd/conf.d/41_mod_ssl.default-vhost.conf и укажите корректные пути к файлам сертификата ... [пропущено] ... SSLCertificateFile /etc/httpd/ssl/my-apache.crt ... [пропущено] ... SSLCertificateKeyFile /etc/httpd/ssl/my-apache.key ... [пропущено] ... SSLCACertificateFile /etc/httpd/ssl/my-ca.crt ... [пропущено] ... Перезапустите Apache: [root@test root]# /etc/init.d/httpd restart Shutting down httpd2: Starting httpd2: [root@test root]# [ [ OK OK Проверьте, как работает полученная конфигурация, обратившись по адресу https://test.domain.org или по адресу, указанному вами при конфигурации виртуального сервера. ] ] 1.4 Упражнения Упражнение 1 : Настройте в Apache виртуальные сервера, определяемые по имени Настройте в Apache виртуальные сервера, определяемые по IP-адресу Установите и настройте модуль SSL для web-сервера Apache 1.1 Решения Решение 1 : Следуйте инструкциям из этой главы 1 Установка прокси-сервера Ключевые файлы, термины и утилиты: squid.conf acl http_access 1.2 Настройка Squid Вступление Squid – это кэширующий прокси-сервер для систем на базе Unix. Он может выступать в качестве прозрачного прокси-сервера, поддерживает кэширование протоколов HTTP, FTP и других, а так же SSL и SNMP. Squid может настраиваться с помощью гибких списков контроля доступа (ACL). Он даже умеет кэшировать DNS-запросы. Прокси-сервер Squid может существенно увеличить скорость web-серфинга, кроме того его можно использовать вместе с утилитами вроде SquidGuard для фильтрации URL. HTTP прокси может работать двумя способами: нормальная работа Адрес прокси-сервера и его порт устанавливаются в настройках web-браузера. прозрачный прокси-сервер Брандмауэр или маршрутизатор перенаправляет весь HTTP-трафик (или трафик данных, передаваемых по другим протоколам) на прокси-сервер. В случае прозрачного прокси-сервера существуют два разных случая: Squid на маршрутизаторе Squid установлен на отдельном от маршрутизатора компьютере. Настройка Основной файл настройки – это /etc/squid/squid.conf. Он содержит огромнейшее число параметров, большая часть которых установлена по умолчанию. Squid прокси прекрасно работает в таком режиме. Вам необходимо установить параметр visible_hostname, или Squid не запустится. visible_hostname test.domain.org Для запуска Squid выполните следующую команду: [root@test root]# /etc/init.d/squid start init_cache_dir /var/spool/squid... Starting squid: [root@test root]# [ OK ] Списки контроля доступа (Access Control Lists) Списки контроля доступа (ACLs) позволяют вам ограничить доступ к проксисерверу. Общий формат ACL правила такой: # acl название_правила тип_правила строка_1 строка_2 ... Примеры различных типов правил ACL: # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # acl aclname src acl aclname src acl aclname dst acl aclname myip ip-address/netmask ... (clients IP address) (IP-адрес клиента) addr1-addr2/netmask ... (range of addresses) (диапазон IP-адресов) ip-address/netmask ... (URL host's IP address) (IP-адрес хоста, к которому обращается клиент) ip-address/netmask ... (local socket IP address) (локальный IP-адрес) .foo.com ... # reverse lookup, client IP (домен, определяется по IP клиента) acl aclname dstdomain .foo.com ... # Destination server from URL (имя сервера) acl aclname srcdom_regex [-i] xxx ... # regex matching client name (регулярное выражение, применяемое к домену клиента) acl aclname dstdom_regex [-i] xxx ... # regex matching server (регулярное выражение, применяемое к имени сервера) # For dstdomain and dstdom_regex a reverse lookup is tried if a IP # based URL is used. The name "none" is used if the reverse lookup # fails. # ( Если установлены правила dstdomain и dstdom_regex, а клиент # запрашивает ресурс по его IP-адресу, то прокси-сервер # выполняет поиск DNS-имени по IP. Если поиск оказывается # безуспешным, то используется имя "none". ) etc... acl aclname srcdomain acl aclname time [day-abbrevs] day-abbrevs: S - Sunday M - Monday T - Tuesday W - Wednesday H - Thursday F – Friday [h1:m1-h2:m2] Примеры ACL: acl acl acl acl acl acl acl acl acl acl acl acl acl acl acl acl all src 0.0.0.0/0.0.0.0 manager proto cache_object localhost src 127.0.0.1/255.255.255.255 to_localhost dst 127.0.0.0/8 SSL_ports port 443 563 Safe_ports port 80 # http Safe_ports port 21 # ftp Safe_ports port 443 563 # https, snews Safe_ports port 70 # gopher Safe_ports port 210 # wais Safe_ports port 1025-65535 # unregistered ports Safe_ports port 280 # http-mgmt Safe_ports port 488 # gss-http Safe_ports port 591 # filemaker Safe_ports port 777 # multiling http CONNECT method CONNECT Затем мы определяем параметр http_access, используя названия ACL: # Only allow cachemgr access from localhost http_access allow manager localhost http_access deny manager # Deny requests to unknown ports http_access deny !Safe_ports # Deny CONNECT to other than SSL ports http_access deny CONNECT !SSL_ports Эти строки определяют, что можно и что нельзя делать в процессе использования этого сервера как прокси. Еще один пример ограничения доступа (полезный) : acl our_networks src 192.168.0.0/24 http_access allow our_networks Прозрачный прокси-сервер Squid, установленный на маршрутизаторе Нам нужно перенаправить весь web-трафик (всё, что поступает на 80 порт) на стандартный порт Squid (3128). Это можно сделать с помощью следующих правил iptables: [root@test root]# iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 3128 [root@test root]# iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 443 -j REDIRECT --to-port 3128 [root@test root]# Здесь eth0 выступает в качестве интерфейса, через который клиенты обращаются к маршрутизатору. Прозрачный прокси-сервер Squid, установленный на отдельном компьютере Если Squid запущен на отдельном компьютере, то мы должны указать межсетевому экрану или маршрутизатору на необходимость перенаправления обращения к сервисам на компьютер, на котором установлен Squid: Добавьте следующие правила iptables на межсетевом экране или маршрутизаторе: [root@test root]# iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j DNAT --to 192.168.0.42:3128 [root@test root]# iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 443 -j DNAT --to 192.168.0.42:3128 [root@test root]# Здесь eth0 выступает в качестве интерфейса, через который клиенты обращаются к маршрутизатору, а 192.168.0.42 - это IP-адрес прокси-сервера. 1.1 Упражнения Упражнение 1 : Установите и настройте Squid как обычный прокси-сервер на порту 3128 Установите и настройте Squid как прозрачный прокси-сервер Проверьте работу прокси-сервера с помощью web-браузера 1.1 Решения Решение 1 : Следуйте инструкциям из этой главы Управление сетевыми клиентами В этой главе Управление сетевыми клиентами ............................................................................................................. 97 3 Настройка LDAP ........................................................................ 3.1 Настройка LDAP ............................................................................ 1 Настройка DHCP ....................................................................................................................................... 98 3.2 Упражнения.................................................................................... 1.1 Настройка DHCP ................................................................................................................................................. 99 3.3 Решения ......................................................................................... 1.2 Упражнения ....................................................................................................................................................... 102 4 Аутентификация PAM ............................................................... 1.3 Решения ............................................................................................................................................................ 103 4.1 Настройка PAM .............................................................................. 2 Настройка NIS ......................................................................................................................................... 104 4.2 Упражнения.................................................................................... 2.1 Настройка NIS ................................................................................................................................................... 105 4.3 Решения ......................................................................................... 2.2 Упражнения ....................................................................................................................................................... 113 2.3 Решения ............................................................................................................................................................ 114 1 Настройка DHCP Ключевые файлы, термины и утилиты dhcpd.conf dhcpd.leases 1.2 Настройка DHCP Аббревиатура «DHCP» расшифровывается как «Dynamic Host Configuration Protocol» – протокол динамической конфигурации компьютера локальной сети (далее «хоста»). Это протокол, предназначенный для автоматической конфигурации компьютеров локальной сети без риска появления совпадающих IP-адресов. С этим протоколом существенно упрощается настройка сети и ускоряется процедура добавления большого числа хостов в локальную сеть. Основной конфигурационный файл: /etc/dhcpd.conf. В нем определены все подсети DHCP, и настройки по умолчанию. Пример файла dhcpd.conf : [root@test root]# cat /etc/dhcpd.conf ddns-update-style none; subnet 192.168.0.0 netmask 255.255.255.0 { # default gateway option routers 192.168.0.254; option subnet-mask 255.255.255.0; option domain-name "domain.org"; option domain-name-servers 192.168.0.42; range 192.168.0.128 192.168.0.253; default-lease-time 21600; max-lease-time 43200; # static address for ns1 (ns1 is found with his MAC address) host ns1 { hardware ethernet 12:34:56:78:AB:CD; fixed-address 192.168.0.69; } } [root@test root]# Основные настройки: опция router : задает маршрут по умолчанию для клиента опция subnet-mask : задает значение для маски подсети, используемое по умолчанию на клиенте опция domain-name : задает доменное имя, используемое по умолчанию на клиенте опция domain-name-servers : задает DNS сервера, используемые по умолчанию клиентом range : задает пул адресов, зарезервированных для DHCP. Клиент, обращающийся за IP-адресом, получит один из адресов из этого пула. Default-lease-time : время, в течение которого клиент сможет пользоваться выделенным адресом, если только клиент не запросил определенное время истечения срока действия адреса. Max-lease-time : максимально возможный период в секундах, в течение которого можно пользоваться выделенным IP-адресом Запуск DHCP сервера: [root@test root]# /etc/init.d/dhcpd start Starting dhcpd: [root@test root]# [ OK ] Продолжительность жизни выделенных адресов Время жизни текущих выделенных адресов можно посмотреть в файле: [root@test root]# cat /var/lib/dhcp/dhcpd.leases lease 192.168.0.253 { starts 1 2004/08/16 13:54:06; ends never; binding state active; next binding state free; hardware ethernet 00:0e:a3:52:fd:01; } [root@test root]# 1.1 Упражнения Упражнение 1 : Установите и настройте DHCP-сервер в вашей локальной сети Протестируйте его работу на клиентских машинах 1.1 Решения Решение 1 : Следуйте инструкциям, описанным в этой главе 1 Настройка NIS Ключевые файлы, термины и утилиты: nisupdate, ypbind, ypcat, ypmatch, ypserv, ypswitch, yppasswd, yppoll, yppush, ypwhich, rpcinfo nis.conf, nsswitch.conf, ypserv.conf Срдержимое каталога /etc/nis/: netgroup, nicknames, securenets Makefile 1.2 Настройка NIS Введение Служба NIS (Network Information Service - сетевая информационная служба) была разработана компанией Sun. Ее цель – централизованное хранение информации о пользовательских учетных записях в локальной сети. Первоначально NIS назывался “Yellow Pages” - «желтые страницы», поэтому почти все имена команд начинаются с префикса “yp”. NIS использует несколько «карт» и может управлять пользователями (/etc/passwd), группами (/etc/group), паролями (/etc/shadows), хостами (/etc/hosts), сервисами (/etc/services) и т.п. Во время установки NIS создается домен NISDOMAIN. Клиенты NIS будут относиться к этому домену и использовать карты этого домена. Карты NIS хранятся в файле /var/yp/domain_name в формате DBM. Пример: Файл /etc/passwd /etc/group /etc/hosts Карта NIS Индексный Ключ passwd.byname Имя пользователя passwd.byuid Идентификатор пользователя (uid) group.byname Имя группы group.byuid Идентификатор группы (gid) hosts.byname Имя хоста hosts.byaddr IP-адрес хоста Настройка На сервере должен быть установлен пакет ypserv. Его основной конфигурационный файл: /etc/ypserv.conf. [root@test root]# cat /etc/ypserv.conf # # ypserv.conf In this file you can set certain options for the NIS server, # and you can deny or restrict access to certain maps based # on the originating host. # # See ypserv.conf(5) for a description of the syntax. # # Some options for ypserv. This things are all not needed, if # you have a Linux net. # Should we do DNS lookups for hosts not found in the hosts table ? # This option is ignored in the moment. dns: no # How many map file handles should be cached ? files: 30 # Should we register ypserv with SLP ? slp: no ... [пропущено] ... * * : * : * : shadow.byname : port : passwd.adjunct.byname : port # If you comment out the next rule, ypserv and rpc.ypxfrd will # look for YP_SECURE and YP_AUTHDES in the maps. This will make # the security check a little bit slower, but you only have to # change the keys on the master server, not the configuration files # on each NIS server. # If you have maps with YP_SECURE or YP_AUTHDES, you should create # a rule for them above, that's much faster. # * : * : * : none [root@test root]# На стороне клиента необходимо установить три пакета: portmap, ypbind и yp-tools. Основной конфигурационный файл NIS на клиентской машине - это /etc/yp.conf. Данный файл должен содержать имя домена NIS и имя сервера NIS. [root@test root]# cat /etc/yp.conf # /etc/yp.conf - ypbind configuration file # Valid entries are # #domain NISDOMAIN server HOSTNAME domain domain.org server test.domain.org # Use server HOSTNAME for the domain NISDOMAIN. # #domain NISDOMAIN broadcast # Use broadcast on the local net for domain NISDOMAIN # #ypserver HOSTNAME ypserver test.domain.org # Use server HOSTNAME for the local domain. The # IP-address of server must be listed in /etc/hosts. # [root@test root]# Импорт пользовательских учетных записей Затем, традиционные конфигурационные файлы UNIX могут быть импортированы в сервер NIS: [root@test root]# /usr/lib/yp/ypinit -m At this point, we have to construct a list of the hosts which will run NIS servers. test is in the list of NIS server hosts. Please continue to add the names for the other hosts, one per line. When you are done with the list, type a <control D>. next host to add: test next host to add: The current list of NIS servers looks like this: test Is this correct? [y/n: y] y We need a few minutes to build the databases... Building /var/yp/domain.org/ypservers... Running /var/yp/Makefile... gmake[1]: Entering directory `/var/yp/domain.org' Updating passwd.byname... Updating passwd.byuid... Updating group.byname... Updating group.bygid... Updating hosts.byname... Updating hosts.byaddr... Updating rpc.byname... Updating rpc.bynumber... Updating services.byname... Updating services.byservicename... Updating netid.byname... Updating protocols.bynumber... Updating protocols.byname... Updating shadow.byname... gmake[1]: Leaving directory `/var/yp/domain.org' test has been set up as a NIS master server. Now you can run ypinit -s test on all slave server. [root@test root]# Тестирование Запуск демонов: На сервере: [root@test root]# /etc/init.d/ypserv start Starting YP server services: [root@test root]# [ OK ] [ OK ] На клиентах: [root@test root]# /etc/init.d/ypbind start Binding to the NIS domain... Listening for an NIS domain server: test [root@test root]# Вы можете проверить учетные записи пользователей с помощью команды ypcat. [root@test root]# ypcat passwd nobody:x:65534:65534:Nobody:/:/bin/sh majordomo:x:502:2::/usr/local/majordomo-1.94.5:/bin/bash csahut:x:501:501:csahut:/home/csahut:/bin/bash [root@test root]# ypcat shadow.byname nobody:*:12630:0:99999:7::: majordomo:!!:12643:0:99999:7::: csahut:$1$KZ7PVhqL$dQT0aYJfaWMBP4QBU7uxB.:12630:0:99999:7::: [root@test root]# ypcat group csahut:x:501: kolab:x:60001: nogroup:x:65534: [root@test root]# Затем должен быть запущен сервис ypbind: [root@test root]# rpcinfo -u localhost ypbind program 100007 version 1 ready and waiting program 100007 version 2 ready and waiting [root@test root]# Использование библиотеки libc версии < 6 Укажите NIS в /etc/nsswitch.conf: passwd: group: shadow: compat compat compat Добавьте в /etc/passwd +:::::: в /etc/shadow +:::::: в /etc/group +::: Использование libc версии 6 Укажите NIS в /etc/nsswitch.conf (должно быть уже указано по умолчанию): [root@test root]# cat /etc/nsswitch.conf # # /etc/nsswitch.conf ... [пропущено] ... passwd: shadow: group: files nisplus nis files nisplus nis files nisplus nis ... [SNIP] ... [root@test root]# Тестирование Вы должны видеть пользователей NIS в конце вывода следующей команды. [root@test root]# getent passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/bin/sh ... [пропущено] ... uid:/bin/false nobody:x:65534:65534:Nobody:/:/bin/sh majordomo:x:502:2::/usr/local/majordomo-1.94.5:/bin/bash nisuser:x:502:502:nisuser:/home/nisuser:/bin/bash [root@test root]# Таким же образом можно получить с NIS-сервера список групп и «теневые» пароли. Для этого используются команды getent group и getent shadow. Теперь вы должны иметь возможность войти в систему, воспользовавшись учетной записью NIS. Программа rpc.yppasswdd Для того, чтобы иметь возможность поменять пароль с клиентской машины, на сервере должен быть запущен демон rpc.yppasswdd. [root@test root]# /etc/init.d/yppasswdd start Starting YP passwd service: [root@test root]# [ OK ] Программа rpc.ypxfrd Эта программа используется для эффективной синхронизации карт NIS на дополнительных серверах NIS (NIS slaves). Программа запускается следующим образом: [root@test root]# /etc/init.d/ypxfrd start Starting YP map server: [root@test root]# Затем запустите программу yppush. [ OK ] Некоторые команды NIS Узнать имя NIS-сервера можно командой: [root@test root]# ypwhich test [root@test root]# Показать доступные карты: [root@test root]# ypwhich -x Use "ethers" for map "ethers.byname" Use "aliases" for map "mail.aliases" Use "services" for map "services.byname" Use "protocols" for map "protocols.bynumber" Use "hosts" for map "hosts.byname" Use "networks" for map "networks.byaddr" Use "group" for map "group.byname" Use "passwd" for map "passwd.byname" [root@test root]# Узнать версию карты и сервера: [root@test root]# Domain domain.org Map passwd.byname The master server [root@test root]# yppoll passwd.byname is supported. has order number 1092670129. [Mon Aug 16 17:28:49 2004] is test. Проверить конфигурацию: [root@test root]# yptest Test 1: domainname Configured domainname is "domain.org" ... [пропущено] ... Test 9: yp_all nobody nobody:x:65534:65534:Nobody:/:/bin/sh majordomo majordomo:x:502:2::/usr/local/majordomo-1.94.5:/bin/bash csahut csahut:x:501:501:csahut:/home/csahut:/bin/bash All tests passed [root@test root]# 1.3 Упражнения Упражнение 1 : Установите сервер NIS и настройте его клиентов Проверьте работу аутентификации NIS 1.1 Решения Упражнение 1 : Следуйте инструкциям этой главы 1 Настройка LDAP Ключевые файлы, термины и утилиты: slapd slapd.conf 1.2 Настройка LDAP Введение Служба каталогов (Directory) - это сервис, предоставляющий возможности поиска данных любого вида. Подобно сервису DNS для имен хостов, каталог может хранить информацию о пользовательских учетных записях, номерах телефонов, email-адресах и даже фотографии. Протокол LDAP (Lightweight Directory Access Protocol – облегченный протокол службы каталогов) был разработан для замены старого сложного протокола X.500. Установка должна быть довольно простой, кроме того существует много утилит управления, покрывающих различные нужды. Структура DAP (X.500) Directory Access Protocol - Протокол доступа к каталогу DIT каталога Directory Information Tree - Информационное дерево dc Domain component - Часть домена dn Distinguished Name - Отличительное имя Base DN Откуда начинается поиск ou Organizational Unit - Организационная единица cn Common Name - Общеизвестное имя LDIF Формат обмена данными LDAP (Data Interchange Format) Object Class Определяет атрибуты Schema Определяет объекты классов Пример имени: dn: cn=John Doe,ou=Staff,dc=lynuxtraining,dc=com Этот dn является уникальным именем, идентифицирующим пользователя John Doe. Настройка В разделе разделе описана конфигурация OpenLDAP, широко известного свободного LDAP сервера. Основной конфигурационный файл сервера – это /etc/openldap/slapd.conf. Файл содержит различные схемы, поддерживаемые LDAP-сервером, некоторую информацию о процессе LDAP (PID, параметры командной строки, файлы журналов), основную структуру каталога (имя, формат и местоположение), опции менеджера LDAP и списки контроля доступа к каталогу. [root@test root]# cat /etc/openldap/slapd.conf include /etc/openldap/schema/core.schema include /etc/openldap/schema/cosine.schema ... [пропущено] ... pidfile argsfile replogfile /var/run/ldap/slapd.pid /var/run/ldap/slapd.args /var/lib/ldap/replog ... [пропущено] ... database suffix directory ldbm "dc=domain,dc=org" /var/lib/ldap rootdn rootpw "cn=manager,dc=domain,dc=org" "asd135" ... [пропущено] ... access to * by self write by group="cn=admin,dc=domain,dc=org" write by group="cn=maintainer,dc=domain,dc=org" write by * read stop [root@test root]# Существует другой файл - /etc/openldap/ldap.conf, в котором определяется, какому серверу будут посылаться LDAP-запросы, и какое дерево каталогов будет использоваться. Обычно этот файл находится на клиентских машинах. [root@test openldap]# cat ldap.conf BASE dc=domain,dc=org #HOST ldap.example.com ldap-master.example.com HOST test.domain.org #URI ldap://ldap.example.com ldap://ldap-master.example.com:666 URI ldap://test.domain.org ... [пропущено] ... [root@test openldap]# Утилиты LDAP slapadd : Утилита Slapadd используется для добавления элементов, заданных в формате обмена данными LDAP (LDIF) в базу данных демона slapd . Пример: [root@test root]# cat test.ldif dn: dc=domain, dc=org objectClass: organization objectClass: dcObject dc: domain o: domain dn: ou=users, dc=domain, dc=org objectClass: organizationalunit ou: users dn: cn=admin, dc=domain, dc=org objectClass: top objectClass: person userPassword:: asd135 cn: admin sn:administrateur [root@test root]# slapadd < test.ldif [root@test root]# slapcat : Утилита Slapcat используется для извлечения данных из базы данных демона slapd в формате LDIF. Пример: [root@test root]# slapcat dn: dc=domain,dc=org objectClass: organization objectClass: dcObject dc: domain o: domain structuralObjectClass: organization entryUUID: aad2cf46-8483-1028-8f23-bfa7c47790fe creatorsName: cn=manager,dc=domain,dc=org modifiersName: cn=manager,dc=domain,dc=org createTimestamp: 20040817102638Z modifyTimestamp: 20040817102638Z entryCSN: 2004081710:26:38Z#0x0001#0#0000 dn: ou=users,dc=domain,dc=org objectClass: organizationalunit ou: users structuralObjectClass: organizationalunit entryUUID: aad56238-8483-1028-8f24-bfa7c47790fe creatorsName: cn=manager,dc=domain,dc=org modifiersName: cn=manager,dc=domain,dc=org createTimestamp: 20040817102638Z modifyTimestamp: 20040817102638Z entryCSN: 2004081710:26:38Z#0x0002#0#0000 dn: cn=admin,dc=domain,dc=org objectClass: top objectClass: person cn: admin sn: administrateur structuralObjectClass: person entryUUID: aad569b8-8483-1028-8f25-bfa7c47790fe creatorsName: cn=manager,dc=domain,dc=org modifiersName: cn=manager,dc=domain,dc=org createTimestamp: 20040817102638Z modifyTimestamp: 20040817102638Z entryCSN: 2004081710:26:38Z#0x0003#0#0000 [root@test root]# slappasswd : Slappasswd используется для генерации пользовательского пароля (userPassword) в формате, пригодном для использования утилитой ldapmodify или директивой rootpw конфигурационного файла slapd.conf. Этот момент очень важен, поскольку пароль пользователя root хранится в конфигурационном файле slapd.conf в открытом виде. Пример: [root@test root]# slappasswd -h {SSHA} New password: Re-enter new password: {SSHA}r+LXQq5RT6HeEOdedOGx8F4tiNBfEfVU [root@test root]# ldapadd : Утилита ldapadd добавляет элемент в каталог LDAP. Пример: [root@test root]# ldapadd -f newentryjohndoe.ldif -h test.domain.org -x -D "cn=Manager,dc=domain,dc=org" -w asd135 adding new entry "uid=JohnDoe,ou=people,dc=domain,dc=org" [root@test root]# ldapmodify : ldapmodify модифицирует элемент каталога LDAP. Пример: [root@test root]# ldapmodify -f newentryjohndoe.ldif -h test.domain.org -x D "cn=Manager,dc=domain,dc=org" -w asd135 modifying entry "uid=JohnDoe,ou=people,dc=domain,dc=org" [root@test root]# ldapdelete : ldapdelete удаляет элемент каталога LDAP. Пример: [root@test root]# ldapdelete "uid=johndoe,ou=people,dc=domain,dc=org" -h test.domain.org -x -D "cn=Manager,dc=domain,dc=org" -w asd135 [root@test root]# ldapsearch : ldapsearch выполняет поиск элемента в каталоге LDAP. Пример: [root@test root]# ldapsearch "uid=johndoe" -h test.domain.org -x -D "cn=Manager,dc=domain,dc=org" -w asd135 # extended LDIF # # LDAPv3 # base <> with scope sub # filter: uid=johndoe # requesting: ALL # # JohnDoe, people, domain.org dn: uid=JohnDoe,ou=people,dc=domain,dc=org objectClass: posixAccount objectClass: shadowAccount objectClass: inetOrgPerson objectClass: sambaAccount cn: JohnDoe uid: JohnDoe uidNumber: 10001 ... [пропущено] ... displayName: John Doe smbHome: \\server\JohnDoe homeDrive: U: # search result search: 2 result: 0 Success # numResponses: 2 # numEntries: 1 [root@test root]# Утилиты миграции LDAP OpenLDAP обычно поставляется с набором сценариев, облегчающих процесс миграции на LDAP с других систем. Эти скрипты хранятся в каталоге /usr/share/openldap/migration/directory и, в частности, используются при миграции с NIS на LDAP. [root@test root]# cd /usr/share/openldap/migration/ [root@test migration]# ls CVSVersionInfo.txt* migrate_all_nisplus_online.sh* migrate_group.pl* migrate_profile.pl* migrate_aliases.pl* migrate_all_offline.sh* migrate_hosts.pl* migrate_protocols.pl* migrate_all_netinfo_offline.sh* migrate_all_online.sh* migrate_netgroup_byhost.pl* migrate_rpc.pl* migrate_all_netinfo_online.sh* migrate_automount.pl* migrate_netgroup_byuser.pl* migrate_services.pl* migrate_all_nis_offline.sh* migrate_base.pl* migrate_netgroup.pl* migrate_slapd_conf.pl* migrate_all_nis_online.sh* migrate_common.ph* migrate_networks.pl* migration-tools.txt migrate_all_nisplus_offline.sh* migrate_fstab.pl* migrate_passwd.pl* README [root@test migration]# Графические утилиты управления LDAP Программа : gq Web-интерфейс: ldap-account-manager (LAM) 1.3 Упражнения Упражнение 1: Установите и настройте сервер OpenLDAP Воспользуйтесь утилитой ldap-account-manager, чтобы создать пользователей и группы (отключите Samba в файле конфигурации LAM) Используйте каталог LDAP как репозиторий email адресов для вашего любимого почтового клиента 1.1 Решения Решение 1 : Следуйте инструкциям этой главы 1 Аутентификация PAM Ключевые файлы, термины и утилиты: /etc/pam.d pam.conf 1.2 Настройка PAM Введение Подключаемые модули аутентификации (PAM - Pluggable Authentication Modules) упрощают реализацию процедуры аутентификации для различных программ. Как правило, в системе Linux существует несколько программ, требующих аутентификации: login, su, ftpd, sshd, ... Поскольку все они используют библиотеки PAM, довольно легко настраивать новые механизмы аутентификации или исправлять проблемы с безопасностью в одном месте без необходимости перекомпиляции всех этих программ. Модули PAM допускают аутентификацию с помощью LDAP, Samba, смарт-карт, USB-ключей, баз данных SQL и т.п. Настройка Библиотеки PAM настраиваются в /etc/pam.d : [root@test pam.d]# ls chfn ftp kbdrate kppp login passwd ppp sieve squid chsh halt kde3 kscreensaver3 net_monitor pop reboot simple_root_authen sshd system-auth xserver cups imap other poweroff secure-mcserv smtp su webmin* [root@test pam.d]# sudo xdm kde3-np lmtp Все файлы выглядят примерно так: [root@test #%PAM-1.0 auth auth auth account password session session [root@test pam.d]# cat login required required required required required required optional pam.d]# pam_securetty.so pam_stack.so service=system-auth pam_nologin.so pam_stack.so service=system-auth pam_stack.so service=system-auth pam_stack.so service=system-auth pam_console.so В каждой строке указан тип модуля, управляющий флаг и используемая библиотека PAM вместе с ее опциями. Тип модуля Тип модуля может принимать одно из следующих значений: auth Модуль этого типа устанавливает, что пользователь именно тот, за кого себя выдает, предписывая приложению запросить у пользователя пароль или идентифицировать себя другим способом. account Этот модуль занимается управлением учетными записями. Обычно он используется для разрешения / запрещения доступа к сервису, основываясь на времени суток, имеющихся системных ресурсах (максимальном числе пользователей), проверке срока действия учетной записи и т.п. session Этот модуль отвечает за выполнение действий, производимых до или после того как пользователь получит какой-либо сервис. Такого рода действия включают регистрацию сведений об обмене данными с пользователем в журналах, монтирование каталогов и т.п. password Последний тип модуля служит для обновления ключа аутентификации (authentication token) пользователя. Обычно существует один такой модуль для каждого модуля типа auth, осуществляющего аутентификацию по схеме «вызов/отклик». Модули данного типа управляют паролями. Управляющий флаг Управляющий флаг служит для индикации того, как библиотека PAM будет реагировать на успешный или неуспешный результат работы модуля, с которым этот флаг ассоциирован. Приложение получает сводный отчет от библиотеки PAM об успешном или неуспешном выполнении. Порядок исполнения модулей совпадает с порядком их перечисления в конфигурационном файле сервиса PAM. Существует четыре управляющих флага: required Флаг означает, что для успешного завершения работы требуется успешное выполнение данного модуля. requisite Поведение похоже на флаг required, однако в случае неуспешного выполнения модуля управление возвращается приложению. Возвращаемое значение – это значение, ассоциированное с первым неудачно завершившимся модулем, имеющим флаг required или requisite. sufficient Успешное выполнение модуля достаточно для того, чтобы библиотека PAM считала, что тип модуля успешно выполнил свое предназначение. Неуспешное же выполнение не будет считаться фатальным для принятия решения об успешности выполнения типа модуля. optional Как и предполагает имя этого флага, успешное или неуспешное исполнение модуля не является критичным для пользовательского приложения. Как правило, PAM игнорирует такой модуль, когда определяет успешность выполнения всего стека модулей. Однако, в отсутствии какого-либо определенного успешного или неуспешного статуса выполнения предыдущего или последующего модуля, этот модуль будет определять статус значения, возвращаемого приложению. Модули библиотеки PAM Существует множество модулей PAM, среди них: pam_pwdb.so : традиционная аутентификация при помощи файла passwd pam_security.so : добавляет дополнительные ограничения (/etc/securetty) pam_mount.so : монтирует домашние каталоги во время входа в систему pam_usb.so : аутентификация с помощью USB-ключа pam_ldap.so : использует каталог LDAP для аутентификации в системе pam_smb.so : использует Samba для аутентификации в системе pam_mysql.so : аутентификация с помощью базы данных MYSQL pam_krb5.so : аутентификация с помощью протокола MIT Kerberos 5 pam_opensc.so : аутентификация с помощью смарт-карты ... Наиболее часто используемые опции модулей: Основные опции модулей: no_warn Запрещает модулю выдавать предупреждающие сообщения приложению. use_first_pass Модуль не должен запрашивать пароль у пользователя, вместо этого модуль должен использовать ранее набранный пароль (от предыдущего модуля auth). Если это не сработает, пользователь не пройдет аутентификацию (данная опция применима к модулям auth и password). try_first_pass Модуль должен попробовать аутентифицировать пользователя по ранее набранному паролю (от предыдущего модуля auth). Если аутентификация не удалась, пароль будет запрошен у пользователя. (Эта опция применима только к модулям auth). 1.1 Упражнения Упражнение 1 : Настройте свой демон sshd на использование аутентификации по протоколу ldap. 1.1 Решения Решение 1 : Изучите файл /usr/share/doc/pam_ldap-167/ Безопасность системы В этой главе Безопасность системы .............................................................................................................................. 136 3 Безопасная оболочка (OpenSSH) ............................................ 3.1 Настройка OpenSSH ..................................................................... 1 Настройка маршрутизатора ................................................................................................................... 137 3.2 Упражнения.................................................................................... 1.1 Настройка маршрутизатора ............................................................................................................................. 138 3.3 Решения ......................................................................................... 1.2 Упражнения ....................................................................................................................................................... 163 4 Поддержание безопасности системы ..................................... 1.3 Решения ............................................................................................................................................................ 164 4.1 Выполнение задач по поддержанию 2 Защита FTP-серверов ............................................................................................................................ 165 безопасности ....................................................................................... 2.1 Настройка демона WU-FTPD ........................................................................................................................... 166 4.2 Упражнения.................................................................................... 2.2 Упражнения ....................................................................................................................................................... 175 4.3 Решения ......................................................................................... 2.3 Решения ............................................................................................................................................................ 176 1 Настройка маршрутизатора Ключевые файлы, термины и утилиты /proc/sys/net/ipv4 /etc/services ipchains iptables routed 1.2 Настройка маршрутизатора Введение Чтобы сконфигурировать маршрутизатор для такой небезопасной сети, как Интернет, необходимо предпринять множество шагов. Прежде всего, определите, какие сервисы вам нужны и заблокируйте все остальное! Это минимизирует вероятность обнаружения уязвимости в вашей системе. Хорошей идеей будет регистрировать все отброшенные и отклоненные пакеты в журнале (и ограничить интенсивность этого процесса во избежание создания журнальных файлов слишком большого размера). Блокирование сканирования портов с помощью PortSentry Большинство сканирований портов может быть обнаружено с помощью утилиты portsentry компании Psionic Technologies (теперь Cisco). Демон portsentry прослушивает несколько известных портов и может заблокировать IP-адрес в случае обнаружения сканирования. Установка Portsentry: Скачайте архив с исходным кодом с web-сайта и установите утилиту вручную: [root@test root]# tar zxvf portsentry-1.2.tar.gz -C /usr/local/src/ portsentry_beta/ portsentry_beta/portsentry.c portsentry_beta/portsentry.h portsentry_beta/portsentry_io.c portsentry_beta/portsentry_io.h ... [SNIP] ... portsentry_beta/ignore.csh [root@test root]# cd /usr/local/src/portsentry_beta/ [root@test portsentry_beta]# make linux SYSTYPE=linux Making cc -O -Wall -DLINUX -DSUPPORT_STEALTH -o ./portsentry ./portsentry.c \ ./portsentry_io.c ./portsentry_util.c [root@test portsentry_beta]# [root@test portsentry_beta]# make install Creating psionic directory /usr/local/psionic Setting directory permissions Creating portsentry directory /usr/local/psionic/portsentry Setting directory permissions chmod 700 /usr/local/psionic/portsentry Copying files cp ./portsentry.conf /usr/local/psionic/portsentry cp ./portsentry.ignore /usr/local/psionic/portsentry cp ./portsentry /usr/local/psionic/portsentry Setting permissions chmod 600 /usr/local/psionic/portsentry/portsentry.ignore chmod 600 /usr/local/psionic/portsentry/portsentry.conf chmod 700 /usr/local/psionic/portsentry/portsentry Edit /usr/local/psionic/portsentry/portsentry.conf and change your settings if you haven't already. (route, etc) WARNING: This version and above now use a new directory structure for storing the program and config files (/usr/local/psionic/portsentry). Please make sure you delete the old files when the testing of this install is complete. [root@test portsentry_beta]# Настройка portsentry : Конфигурационный файл утилиты: /usr/local/psionic/portsentry/portsentry.conf. Укажите порты, на которых вы хотите запустить утилиту portsentry: TCP_PORTS="1,11,15,79,111,119,143,540,635,1080,1524,2000,5742,6667,12345,1234 6,20034,27665,31337,32771,32772,32773,32774,40421,49724,54320" UDP_PORTS="1,7,9,69,161,162,513,635,640,641,700,37444,34555,31335,32770,32771 ,32772,32773,32774,31337,54321" Заблокируйте сканирование UDP и TCP: BLOCK_UDP="1" BLOCK_TCP="1" Перенаправьте атакующий хост на null-маршрут: KILL_ROUTE="/sbin/route add $TARGET$ 192.168.66.66 или KILL_ROUTE="/sbin/route add -host $TARGET$ reject или KILL_ROUTE="/usr/local/bin/iptables -I INPUT -s $TARGET$ -j DROP Также можно запустить какой-нибудь скрипт в ответ на атаку. Однако такая конфигурация не рекомендуется. Хорошей идеей будет настроить игнорирование IP-адресов ваших DNS серверов и маршрутизаторов. Эти IP адреса должны быть помещены в файл /usr/local/psionic/portsentry/portsentry.ignore. Стартовый сценарий Portsentry: Данный скрипт называется /etc/init.d/portsentry : /!/bin/bash # # portsentry Start the portsentry portscan detector # # Authors: Craig Rowland <[email protected]>, Tim Powers <[email protected]> # and Matthias Saou <[email protected]> # # chkconfig: 345 98 05 # description: PortSentry Port Scan Detector is part of the Abacus Project \ # suite of tools. The Abacus Project is an initiative to release \ # low-maintenance, generic, and reliable host based intrusion \ # detection software to the Internet community. # processname: portsentry # configfile: /etc/portsentry/portsentry.conf # pidfile: /var/run/portsentry.pid # Source function library. . /etc/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ ${NETWORKING} = "no" ] && exit 0 # For this script to work on non english systems export LANG=C RETVAL=0 start () { # Set up the ignore file SENTRYDIR=/usr/local/psionic/portsentry FINALIGNORE=$SENTRYDIR/portsentry.ignore TMPFILE=$SENTRYDIR/portsentry.ignore.tmp # Testline is used to see if the initscript has already been run if [ -f $FINALIGNORE ] ; then cp -f $FINALIGNORE $TMPFILE testline=`grep -n "Do NOT edit below this" $TMPFILE | cut -delimiter=":" -f1` if [ -z "$testline" ] ; then echo > /dev/null # Do nothing else let headline=$testline-2 head -$headline $FINALIGNORE > $TMPFILE fi fi echo echo echo echo echo echo echo '#########################################' '# Do NOT edit below this line, if you #' '# do, your changes will be lost when #' '# portsentry is restarted via the #' '# initscript. Make all changes above #' '# this box. #' '#########################################' >> >> >> >> >> >> >> $TMPFILE $TMPFILE $TMPFILE $TMPFILE $TMPFILE $TMPFILE $TMPFILE echo '' >> $TMPFILE echo '# Exclude all local interfaces' >> $TMPFILE for i in `/sbin/ifconfig -a | grep inet | awk '{print $2}' | sed 's/addr://'` ; do echo $i >> $TMPFILE done echo '' >> $TMPFILE echo '# Exclude the default gateway(s)' >> $TMPFILE for i in `/sbin/route -n | grep ^0.0.0.0 | awk '{print $2}'` ; do echo $i >> $TMPFILE done echo '' >> $TMPFILE echo '# Exclude the nameservers' >> $TMPFILE for i in `/bin/cat /etc/resolv.conf | grep ^nameserver | awk '{print $2}'` ; do echo $i >> $TMPFILE done echo echo echo echo '' >> $TMPFILE '# And last but not least...' >> $TMPFILE '0.0.0.0' >> $TMPFILE '' >> $TMPFILE cp -f $TMPFILE rm -f $TMPFILE $SENTRYDIR/portsentry.ignore # Check for modes defined in the config file if [ -s $SENTRYDIR/portsentry.modes ] ; then modes=`cut -d "#" -f 1 $SENTRYDIR/portsentry.modes` else modes="tcp udp" fi for i in $modes ; do action $"Starting portsentry -$i: " /usr/local/psionic/portsentry/portsentry -$i RETVAL=$? done [ $RETVAL -eq 0 ] && touch /var/lock/subsys/portsentry return $RETVAL } stop() { echo -n $"Stopping portsentry: " killproc portsentry RETVAL=$? echo [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/portsentry return $RETVAL } # See how we were called. case $1 in start) start ;; stop) stop ;; status) status portsentry RETVAL=$? ;; restart) stop start RETVAL=$? ;; condrestart) if [ -f /var/lock/subsys/portsentry ]; then stop start RETVAL=$? fi ;; *) echo $"Usage: portsentry {start|stop|restart|condrestart|status}" exit 1 esac exit $RETVAL Использование Portsentry : portsentry может быть запущен с различными параметрами: -tcp :прослушивать порты из списка TCP_PORTS -udp :прослушивать порты из списка UDP_PORTS -stcp :режим «стелс»: прослушивать порты из списка TCP_PORTS, но не отвечать на соединения. -sudp :режим «стелс»: прослушивать порты из списка UDP_PORTS, но не отвечать на соединения. -atcp : Расширенный механизм обнаружения сканирования TCP портов: используется для мониторинга более 1024-х портов -audp : Расширенный механизм обнаружения сканирования UDP портов: используется для мониторинга более 1024-х портов [root@test root]# /etc/init.d/portsentry start Starting portsentry -tcp: Starting portsentry -udp: [root@test root]# [ [ OK OK ] ] Чтобы протестировать конфигурацию, запустите сканирование с другого хоста: [root@test root]# nmap -sS -v -O 192.168.0.42 Starting nmap 3.50 ( http://www.insecure.org/nmap/ ) at 2004-08-18 13:37 CEST Host test (192.168.0.42) appears to be up ... good. Initiating SYN Stealth Scan against test (192.168.0.42) at 13:37 Adding open port 80/tcp Adding open port 824/tcp Adding open port 6000/tcp ... [пропущено] ... Nmap run completed -- 1 IP address (1 host up) scanned in 6.834 seconds [root@test root]# Регистрация событий в журнале: Журналы утилиты portsentry можно просматривать в файле /var/log/syslog : Aug 18 13:32:58 test portsentry[5019]: attackalert: TCP SYN/Normal scan from host: 192.168.0.165/192.168.0.165 to TCP port: 72 Aug 18 13:32:58 test portsentry[5019]: attackalert: Host 192.168.0.165 has been blocked via wrappers with string: "ALL: 192.168.0.165" Aug 18 13:32:58 test kernel: ip_tables: (C) 2000-2002 Netfilter core team Aug 18 13:32:58 test portsentry[5019]: attackalert: Host 192.168.0.165 has been blocked via dropped route using command: "/sbin/iptables -I INPUT -s 192.168.0.165 -j DROP" Aug 18 13:32:58 test portsentry[5019]: attackalert: TCP SYN/Normal scan from host: 192.168.0.165/192.168.0.165 to TCP port: 23 Aug 18 13:32:58 test portsentry[5019]: attackalert: Host: 192.168.0.165/192.168.0.165 is already blocked Ignoring Aug 18 13:32:58 test portsentry[5019]: attackalert: TCP SYN/Normal scan from host: 192.168.0.165/192.168.0.165 to TCP port: 386 а также в /usr/local/psionic/portsentry/portsentry.history : 1092828778 - 08/18/2004 13:32:58 Host: 192.168.0.165/192.168.0.165 Port: 72 TCP Blocked Если выставить опции KILL_ROUTE значение iptables, portsentry добавит правило iptables, блокирующее хост, запустивший сканирование портов: [root@test root]# iptables -L Chain INPUT (policy ACCEPT) target prot opt source DROP all -- 192.168.0.165 destination anywhere Chain FORWARD (policy ACCEPT) target prot opt source destination Chain OUTPUT (policy ACCEPT) target prot opt source [root@test root]# destination Фильтрация сетевых пакетов Введение Пакетный фильтр анализирует сетевые пакеты и принимает решение о том, какие пакеты принять, а какие - нет. По сути это то, что делает межсетевой экран (брандмауэр)5. Для операционной системы Linux в данный момент используется межсетевой экран Netfilter / Iptables . Брандмауэр состоит из двух частей: Netfilter - это часть ядра, принимающая и посылающая пакеты. Вторая часть, iptables, - это пользовательская утилита, применяемая для настройки правил фильтрации. Netfilter / Iptables входят в состав ядра версии 2.4: ядро 2.0.x ipfwadm ядро 2.2.x ipchains ядро 2.4.x, 2.6.x iptables Диаграмма прохождения пакета: INPUT, FORWARD и OUTPUT - это так называемые цепочки правил. В случае, если адрес назначения пакета совпадает с адресом межсетевого экрана, применяются правила из цепочки INPUT. Когда пакет посылается с адреса брандмауэра куда-то наружу, применяются правила цепочки OUTPUT. Если пакет должен быть передан межсетевым экраном куда-то дальше (т.е. он поступил на его адрес, но на самом деле предназначается для другого хоста), применяются правила цепочки FORWARD. 5 Далее по тексты термины «межсетевой экран» и «брандмауэр» будут использоваться как синонимы,-прим.ред. Настройка ядра Чтобы заставить работать iptables, необходимо настроить ядро. Опции могут быть вкомпилированы в ядро или составлять отдельный модуль. CONFIG_PACKET CONFIG_NETFILTER CONFIG_IP_NF_CONNTRACK CONFIG_IP_NF_FTP CONFIG_IP_NF_IPTABLES CONFIG_IP_NF_MATCH_LIMIT CONFIG_IP_NF_MATCH_MAC CONFIG_IP_NF_MATCH_MARK CONFIG_IP_NF_MATCH_TOS CONFIG_IP_NF_MATCH_TCPMSS CONFIG_IP_NF_MATCH_STATE CONFIG_IP_NF_MATCH_UNCLEAN CONFIG_IP_NF_MATCH_OWNER CONFIG_IP_NF_FILTER CONFIG_IP_NF_TARGET_REJECT CONFIG_IP_NF_TARGET_MIRROR CONFIG_IP_NF_NAT CONFIG_IP_NF_TARGET_MASQUERADE CONFIG_IP_NF_TARGET_REDIRECT CONFIG_IP_NF_TARGET_LOG CONFIG_IP_NF_TARGET_TCPMSS Маршрутизация и фильтрация Когда пакет достигает сетевого интерфейса, он проходит несколько шагов, прежде чем будет передан локальному процессу, удален или передан на другой хост. Стадии обработки пакета: Межсетевой экран / маршрутизатор использует цепочку FORWARD для защиты локальной сети. Для защиты самого хоста используется цепочка правил INPUT. Отслеживание соединений Netfilter хранит сведения о состоянии тех соединений, для которых это понятие имеет смысл. Данная техника реализуется с помощью анализа пакетов в цепочках PREROUTING и OUTPUT. Типичное соединение может иметь следующие состояния: NEW ESTABLISHED RELATED INVALID Таблица соединений ядра может быть выведена на экран следующим образом: [root@test root]# cat /proc/net/ip_conntrack |more tcp 6 96 SYN_SENT src=127.0.0.1 dst=192.168.0.42 sport=50295 dport=307 [UNREPLIED] src=192.168.0.42 dst=127.0.0.1 spor t=307 dport=50295 use=1 ... [root@test root]# Здесь, первое значение – это имя протокола (tcp), второе – номер протокола (6) и третье – таймаут, сбрасываемый в значение по умолчанию с каждым переданным пакетом. Таймауты Состояние Таймаут NONE 30 минут ESTABLISHED 5 дней SYN_SENT 2 минуты SYN_RECV 60 секунд FIN_WAIT 2 минуты TIME_WAIT 2 минуты CLOSE 10 секунд CLOSE_WAIT 12 часов LAST_ACK 30 секунд LISTEN 2 минуты TCP Соединения протокола TCP устанавливаются в три приема: Клиент SYN Сервер ===> <=== ACK SYN/ACK ===> Следующие пакеты используются для корректного закрытия соединения TCP: Клиент FIN Сервер ===> <=== ACK FIN/ACK ===> Отослан пакет SYN /proc/net/ip_conntrack : tcp 6 117 SYN_SENT src=192.168.1.5 dst=192.168.1.35 sport=1031 dport=23 [UNREPLIED] src=192.168.1.35 dst=192.168.1.5 sport=23 dport=1031 use=1 Получен SYN/ACK /proc/net/ip_conntrack : tcp 6 57 SYN_RECV src=192.168.1.5 dst=192.168.1.35 sport=1031 dport=23 src=192.168.1.35 dst=192.168.1.5 sport=23 dport=1031 use=1 Финальный пакет ACK /proc/net/ip_conntrack : tcp 6 431999 ESTABLISHED src=192.168.1.5 dst=192.168.1.35 sport=1031 dport=23 src=192.168.1.35 dst=192.168.1.5 sport=23 dport=1031 use=1 После обмена еще несколькими пакетами соединение перейдет в состояние ASSURED. Когда TCP соединение закрывается, оно переходит в состояние TIME_WAIT /proc/net/ip_conntrack : tcp 6 114 TIME_WAIT src=192.168.10.2 dst=192.168.8.4 sport=35054 dport=5223 src=192.168.8.4 dst=192.168.10.2 sport=5223 dport=35054 [ASSURED] use=1 Соединение может быть переведено в состояние CLOSE пакетом RST. UDP Обмен данными по протоколу UDP осуществляется без установления соединения, что означает, что в инициировании или закрытии соединения нет необходимости. Первый пакет /proc/net/ip_conntrack : udp 17 20 src=192.168.1.2 dst=192.168.1.5 sport=137 dport=1025 [UNREPLIED] src=192.168.1.5 dst=192.168.1.2 sport=1025 dport=137 use=1 Ответ /proc/net/ip_conntrack : udp 17 170 src=192.168.1.2 dst=192.168.1.5 sport=137 dport=1025 src=192.168.1.5 dst=192.168.1.2 sport=1025 dport=137 use=1 После этого соединение рассматривается как установленное, поскольку были отмечены пакеты обоих хостов. Однако оно не будет помечено как ESTABLISHED поскольку формально в UDP не существует понятия установленного соединения. Еще несколько пакетов /proc/net/ip_conntrack : udp 17 175 src=192.168.1.5 dst=195.22.79.2 sport=1025 dport=53 src=195.22.79.2 dst=192.168.1.5 sport=53 dport=1025 [ASSURED] use=1 ICMP Пакеты ICMP используются для контроля и не устанавливают соединений. Существует несколько типов ICMP-пакетов, но только четыре из них приводят к генерации ответного пакета. ping Клиент Сервер ICMP Echo Request ===> <=== ICMP Echo Reply /proc/net/ip_conntrack: icmp 1 25 src=192.168.1.6 dst=192.168.1.10 type=8 code=0 id=33029 [UNREPLIED] src=192.168.1.10 dst=192.168.1.6 type=0 code=0 id=33029 use=1 Поскольку после ответа трафика больше нет, информация об ICMP-соединении удаляется сразу же после получения ответа. Таймаут ICMP может быть задан в файле: /proc/sys/net/ipv4/netfilter/ip_ct_icmp_timeout По умолчанию его значение равно 30 секунд, что должно быть достаточно в большинстве случаев. Контроль соединения Клиент SYN Маршрутизатор Сервер ===============> <=== ICMP Net unreachable Маршрутизатор рассматривает соединение как новое (состояние NEW), поскольку прошел пакет SYN. Пакет ошибки ICMP будет распознан как имеющий отношение к соединению и оно будет удалено из списка отслеживаемых. Нечто подобное происходит и с UDP соединениями: Клиент Маршрутизатор Сервер UDP пакет ===============> <=== ICMP Net prohibited Другие соединения Соединения таких протоколов как NETBLT, MUX, EGP обрабатываются также, как и UDP. Первый пакет переводит соединение в состояние NEW, а дальнейший обмен пакетами приводит к состоянию ESTABLISHED. Сложные протоколы Некоторые протоколы обмениваются такой информацией, как IP-адреса и номера портов, помещая ее в данные своих пакетов. Примеры таких протоколов: ICQ, IRC, FTP, Oracle, ntalk или H.323. В этом случае ядро не может так легко отслеживать соединение, поскольку информация о нем находится не в заголовке пакета. Чтобы такие протоколы работали, ядро вынуждено соответствующим образом анализировать трафик и отслеживать пакеты, имеющие отношение к соединению. Например, протокол FTP обычно использует два соединения. Первое из них – контрольная сессия на порту 21. Когда мы загружаем файл, клиент посылает номер порта на сервер и последний инициирует новое соединение со своего собственного 20-го порта (второе соединение - для данных) на указанный порт и передает данные. Клиент Маршрутизатор <=== RELATED === SYN/ACK Сервер SYN === ESTABLISHED ===> В пассивном режиме FTP-сервер сообщает клиенту, с каким портом нужно соединиться. Клиент соединяется со своего 20-го порта с указанным портом на сервере и получает запрошенные данные. Клиент SYN Маршрутизатор Сервер === RELATED ===> <=== ESTABLISHED === SYN/ACK Команда iptables Формат команды iptables: iptables [-t table] command [match] [target/jump] Таблицы У Netfilter есть три главных таблицы. Если ни одна из таблиц не указана опцией t, то по умолчанию будет использоваться таблица filter. Чтобы отобразить все правила какой-либо таблицы, используется опция -L: [root@test root]# iptables -t mangle -L Таблица filter Эта таблица осуществляет основную работу по фильтрации. Например, с помощью опции -j и целей ACCEPT и DROP пакеты могут быть приняты или отброшены соответственно. Таблица filter позволяет использовать почти все доступные цели. Правила могут содержать цели: DROP, LOG, ACCEPT, REJECT, ... . Набор доступных целей зависит от конфигурации ядра. [root@test root]# iptables -A INPUT -p tcp -j ACCEPT Таблица mangle Эта таблица правил позволяет модифицировать некоторые поля пакета данных, например, TTL (Time To Live – время жизни пакета), TOS (Type Of Service – тип сервиса), MARK. Поле TTL может использоваться для, сокрытия подсети. TOS и MARK в основном используются пользовательскими программами, такими как iproute2. Таблица nat Эта таблица используется для трансляции сетевых адресов (NAT). Адреса отправителя и получателя, указанные в пакете, могут быть изменены в этой таблице. В этой таблице не допускается фильтрация. Только первый пакет из потока данных попадет в эту цепочку правил. Остальные пакеты будут изменяться тем же способом автоматически. DNAT SNAT MASQUERADE Команды В iptables, правила могут быть добавлены, модифицированы и удалены. Добавление [root@test root]# iptables -A INPUT -p tcp --dport 80 -j DROP Удаление [root@test root]# iptables -D INPUT -p tcp --dport 80 -j DROP [root@test root]# iptables -D 1 Замена [root@test root]# iptables -R INPUT 1 -s 192.168.0.1 -j DROP Вставка [root@test root]# iptables -I INPUT 1 -p tcp --dport 80 -j ACCEPT Перечисление [root@test [root@test [root@test [root@test root]# root]# root]# root]# iptables iptables iptables iptables -L -L INPUT -v -L -n -L -t nat Сброс [root@test root]# iptables -F INPUT Политика по умолчанию для всей цепочки [root@test root]# iptables -P FORWARD DROP Обнуление [root@test root]# iptables -Z INPUT Новая цепочка [root@test root]# iptables -N tcp_traffic Удаление цепочки [root@test root]# iptables -X tcp_traffic Переименование цепочки [root@test root]# iptables -X tcp_traffic udp_traffic Поиск совпадений Ядро Linux ищет подходящее правило в таблицах netfilter для каждого пакета. Если правило подходит, действие, указанное в нем, выполняется. Неявные совпадения указываются опциями, заданными напрямую команде iptables. Для явных совпадений используется аргумент -m <match>. Основные опции для поиска совпадений Протокол: -p [root@test root]# iptables -A INPUT -p tcp ... [root@test root]# iptables -A INPUT -p udp ... [root@test root]# iptables -A INPUT -p icmp ... Адрес отправителя: -s [root@test root]# iptables -A INPUT -s 192.168.0.1 ... [root@test root]# iptables -A INPUT -s 192.168.0.0/24 ... [root@test root]# iptables -A INPUT -s ! 192.168.0.0/255.255.255.0 ... Адрес получателя: -d [root@test root]# iptables -A INPUT -d 192.168.0.1 ... [root@test root]# iptables -A INPUT -d 192.168.0.0/24 ... [root@test root]# iptables -A INPUT -d ! 192.168.0.0/255.255.255.0 ... Опции TCP Для того, чтобы правило совпадало с определенными TCP пакетами, протокол TCP должен быть указан в правиле: -p tcp. Порт отправителя [root@test root]# iptables -A INPUT -p tcp --sport ssh [root@test root]# iptables -A INPUT -p tcp --sport 22:80 [root@test root]# iptables -A INPUT -p tcp --sport ! :1024 Порт получателя [root@test root]# iptables -A INPUT -p tcp --dport ssh Флаги TCP [root@test [root@test [root@test [root@test root]# root]# root]# root]# iptables iptables iptables iptables -A -A -A -A FORWARD FORWARD FORWARD FORWARD -p -p -p -p tcp tcp tcp tcp --tcp-flags SYN,FIN,ACK SYN --syn --tcp-flags SYN,RST,ACK SYN --tcp-flags ! FIN FIN Опции UDP Чтобы правило совпадало с UDP пакетами в нем должна быть указана опция: -p udp. Порт отправителя [root@test root]# iptables -A INPUT -p udp --sport 53 Порт получателя [root@test root]# iptables -A INPUT -p udp --dport dns Опции ICMP Пакеты ICMP отфильтровываются правилом, в котором указана опция -p icmp. [root@test root]# iptables -A INPUT -p icmp --icmp-type echo-request [root@test root]# iptables -A INPUT -p icmp --icmp-type echo-reply Чтобы вывести полный список возможных опций фильтрации ICMP пакетов, выполните команду: [root@test root]# iptables -p icmp --help Ограничение интенсивности поступления пакетов Опция ограничения интенсивности может ограничить скорость поступления пакетов в единицу времени. Эта функция реализуется с помощью счетчика. Начальное значение счетчика уменьшается с каждым поступающим пакетом. Если счетчик достиг нуля, все последующие пакеты будут отбрасываться. Каждую секунду (например) значение счетчика увеличивается на единицу, позволяя таким образом пройти еще одному пакету. Опция используется для снижения негативного эффекта от атак затопления syn/ping пакетами (Syn/Ping Flood). Правило из следующего примера принимает пакеты с интенсивностью не более 5 штук в секунду. [root@test root]# iptables -A INPUT -m limit --limit 5/s Фильтрация по состоянию соединения Опция фильтрации по состоянию соединения используется для выделения состояний соединений, отслеживаемых ядром. Возможные состояния: NEW, ESTABLISHED, RELATED, INVALID. Такая фильтрация используется для того, чтобы пропускать новые соединения только в одну сторону, а в обратную сторону пропускать только трафик возвращаемый в ответ на эти соединения (ESTABLISHED;RELATED). [root@test root]# iptables -A INPUT -m state --state NEW,ESTABLISHED,RELATED Цели и переходы Цель в правиле указывает на то, что нужно сделать с удовлетворяющим ему пакетом. Целью может быть таблица, заданная пользователем или стандартная цель ядра, например ACCEPT или DROP, принимающая пакет (позволяющая пакету пройти дальше) или отбрасывающая пакет (останавливающая обработку пакета) соответственно. Цель ACCEPT Пакет принимается и остальные правила цепочки текущей таблицы не будут к нему не применяются. Цель DROP Пакет отбрасывается и более не обрабатывается. Цель REJECT Цель REJECT работает подобно цели DROP, с тем отличием, что отправитель пакета получит ICMP сообщение сигнализирующее об ошибке. Цель REJECT можно использовать только в цепочках INPUT, FORWARD и OUTPUT. Цель DNAT DNAT (Destination Network Address Translation – трансляция адреса получателя) используется для изменения IP-адреса получателя пакета. Цель DNAT может использоваться только в цепочках PREROUTING и OUTPUT таблицы nat. [root@test root]# iptables -t nat -A PREROUTING -p tcp -j DNAT --todestination 192.168.1.111 Адрес отправителя в поступающих обратно пакетах автоматически транслируется в оригинальный. Цель SNAT SNAT (Source Network Address Translation – трансляция адреса отправителя) используется для изменения IP-адреса отправителя пакета. Цель SNAT может использоваться только с цепочкой POSTROUTING таблицы nat. [root@test root]# iptables -t nat -A POSTROUTING -p tcp -j SNAT --to-source 192.168.1.1 Получаемые обратно пакеты будут автоматически оттранслированы в оригинальный адрес. Цель MASQUERADE Поведение цели masquerade подобно SNAT, однако в этом случае Netfilter самостоятельно решает, какой адрес отправителя нужно использовать, основываясь на маршруте по умолчанию. Такое поведение позволяет реализовывать NAT с динамическими IP-адресами, получаемыми от Интернетпровайдера или DHCP-сервера. Цель MASQUERADE доступна только в цепочке POSTROUTING таблицы nat. [root@test root]# iptables -t nat -A POSTROUTING -j MASQUERADE Цель MASQUERADE очищает информацию обо всех отслеживаемых соединениях в случае деактивации сетевого интерфейса. Цель REDIRECT Цель REDIRECT изменяет порт назначения пакета. Таким образом, пакет останется в пределах того же хоста, но будет передан на другой порт. [root@test root]# iptables -A INPUT -j REDIRECT --to-port 3128 Цель MIRROR Это в чистом виде экспериментальная цель. С ее помощью можно менять местами адреса отправителя и получателя. Используйте с осторожностью :-) Цель RETURN Проход пакета по цепочке правил прекратится, как только пакет достигнет правила с этой целью. Цель QUEUE Пакеты будут попадать в очередь для обработки пользовательскими программами. Цель MARK С помощью этой цели можно поставить метку на пакет с целью его дальнейшей обработки. Как Netfilter, так и пользовательские программы могут выявлять пакеты, помеченные таким образом, для выполнения с ними специальных действий. iptables -A INPUT -j MARK --set-mark 1 Цель LOG С помощью этой цели пакет попадает в журнал syslog. [root@test root]# iptables -A INPUT -j LOG --log-prefix " Dropped INPUT: " Цель ULOG Эта цель существует для предоставления возможностей регистрации пакетов в пользовательских программах, например, для занесения их в базу данных. Пример межсетевого экрна Сценарий, настраивающий правила iptables. Пример: #!/bin/bash echo 1 > /proc/sys/net/ipv4/ip_forward DMZ=10.0.0.0/24 IPTABLES="/sbin/iptables" $IPTABLES -F $IPTABLES -F -t nat $IPTABLES -P INPUT DROP $IPTABLES -P FORWARD DROP echo "accept localhost internal traffic" $IPTABLES -A INPUT -i lo -s localhost -j ACCEPT ... echo "accept ssh from $DMZ on eth1" $IPTABLES -A INPUT -s $DMZ -i eth1 -p tcp --dport 22 -j ACCEPT ... iptables -L -v -n iptables -L -v -n -t nat 1.1 Упражнения Упражнение 1 : Установите утилиту portsentry, чтобы заблокировать сканирование портов. Создайте сценарий, запускаемый в ответ на атаку, который будет перенаправлять сканирование портов на сам атакующий хост (эмуляция цели MIRROR) Упражнение 2 : Настройте свою систему на отбрасывание всех входящих пакетов кроме SSH и SMTP. Настройте «маскарадинг» всего исходящего трафика. Настройте перенаправление HTTP-пакетов на другой хост. Настройте регистрацию всех отклоненных пакетов в файле /var/log/kern.log и на 9-ой консоли. 1.1 Решения Решение 1 : Следуйте инструкциям, описанным в этой главе. KILL_ROUTE="/sbin/iptables -t nat -A PREROUTING -s $TARGET$ -j DNAT --to-destination $TARGET$ Упражнение 2 : используйте опции --dport 22, --dport 25 и -j DROP используйте опцию -j MASQUERADE используйте опции -j DNAT --to-destination используйте опции цели LOG и модифицируйте файл /etc/syslog.conf 1 Защита FTP-серверов Ключевые файлы, термины и утилиты: ftpaccess, ftpusers, ftpgroups /etc/passwd chroot 1.2 Настройка демона WU-FTPD Введение Во время создания протокола передачи файлов (FTP - File Transport Protocol) никто не думал о безопасности. Сегодня, во времена большой популярности Интернет и существования небезопасных беспроводных технологий передачи данных протокол FTP должен быть заменен на более безопасный протокол передачи файлов, например, sftp. В случаях, когда такая замена неприемлема, можно поместить открытые ftpсессии в отдельную корневую файловую систему (chroot jail) – упрощенную копию нормальной системы. Утилита Wuarchive-ftpd, известная как WU-FTPD - это ftp-демон для Unix-систем, разработанный в Университете Вашингтона Крисом Майерсом (Chris Myers) и, позднее, Брайаном О'Коннором (Bryan D. O'Connor). Этот демон не считается особо безопасным FTP-сервером, так что если вам нужен действительно защищенный продукт, стоит взглянуть на демон vsftpd («very secure ftp server» – «очень безопасный ftp сервер»). Настройка Wu-ftpd Основные конфигурационный файлы демона Wu-ftpd находятся в /etc : /etc/ftpusers /etc/ftpaccess /etc/ftpconversions /etc/ftphosts Файл ftpusers содержит список пользователей, которым запрещен доступ к вашему FTP-серверу. Как вы могли догадаться, пользователь root должен быть указан в этом файле. Вам таже нужно убедиться, что и другие особые пользователи, такие как lp, shutdown, mail, и т.п. также перечислены в нем. Пример: [root@test root]# cat /etc/ftpusers root bin daemon adm lp sync shutdown halt mail news uucp operator games nobody [root@test root]# Файл ftpaccess используется для настройки таких параметров, как безопасность, пользователи и т.п. На самом деле, это основной конфигурационный файл. Некоторые из интересных настроек, которые вы можете указать здесь: loginfails [число] Здесь «число» – это количество неудачных попыток входа в систему, которое пользователь может сделать, прежде чем его учетная запись будет полностью заблокирована. shutdown [имя файла] Здесь «имя файла» – это имя файла, появление которого на диске приведет к автоматическому останову FTP сервера, без необходимости закрытия порта в файле /etc/inetd.conf с последующим рестартом демона inetd. [root@test root]# cat /etc/ftpaccess class all real,guest,anonymous * email root@localhost loginfails 5 readme readme README* README* login cwd=* message /welcome.msg message .message login cwd=* compress tar chmod delete overwrite rename all all guest,anonymous guest,anonymous guest,anonymous guest,anonymous yes yes no no no no log transfers anonymous,real inbound,outbound shutdown /etc/shutmsg passwd-check rfc822 warn [root@test root]# Файл ftpconversions существует для обеспечения переконвертации файлов на лету, например автоматической декомпрессии файлов во время скачивания. Пример: [root@test root]# cat /etc/ftpconversions :.Z: : :/bin/compress -d -c %s:T_REG|T_ASCII:O_UNCOMPRESS:UNCOMPRESS : : :.Z:/bin/compress -c %s:T_REG:O_COMPRESS:COMPRESS :.gz: : :/bin/gzip -cd %s:T_REG|T_ASCII:O_UNCOMPRESS:GUNZIP : : :.gz:/bin/gzip -9 -c %s:T_REG:O_COMPRESS:GZIP : : :.tar:/bin/tar -c -f - %s:T_REG|T_DIR:O_TAR:TAR : : :.tar.Z:/bin/tar -c -Z -f %s:T_REG|T_DIR:O_COMPRESS|O_TAR:TAR+COMPRESS : : :.tar.gz:/bin/tar -c -z -f - %s:T_REG|T_DIR:O_COMPRESS|O_TAR:TAR+GZIP [root@test root]# Файл ftphosts используется для разрешения или запрещения доступа к серверу определенным учетным записям с различных хостов. Синтаксис, используемый в этом файле: allow/deny login Пример: # Example host access file # # Everything after a '#' is treated as comment, # empty lines are ignored allow deny bartm fred somehost.domain otherhost.domain 131.211.32.* host Организация защиты FTP-сервера Изменение текста предупреждающего сообщения Изменение текста приветствия Защита, запрет и ограничение пользовательских учетных записей Защита анонимного доступа Зашита анонимной выгрузки данных на сервер Текст приглашения FTP Хорошей идеей является изменение предупреждающего сообщения, выдаваемого клиентам FTP-сервера, поскольку это позволяет скрыть от них, какой именно сервер FTP их обслуживает. Добавьте следующую строку в файл /etc/ftpaccess: banner /etc/banners/warning.msg Содержимое файла, может выглядеть примерно так: Hello, all activity on ftp.example.com is logged. Текст приветствия FTP После в систему всем пользователям показывается текст приветствия. По умолчанию приветствие включает информацию о версии сервера, которая будет полезна хакерам, пытающим идентифицировать слабые места в системе. Чтобы изменить этот текст, добавьте следующую директиву в файл /etc/ftpusers: greeting text Welcome to XYZ FTP server Анонимный доступ Наилучшим способом настройки анонимного доступа к FTP-серверу считается организация специальной корневой файловой системы (chroot jail): вместо того, чтобы позволить полный доступ к системе, такая файловая система ограничит действия пользователя только заданным каталогом. Другими словами, после анонимного входа в такую систему, пользователь будет иметь доступ только к домашнему каталогу учетной записи ftp и не более того. Важно не давать вашим FTP-пользователям учетных записей с оболочкой Linuxсистемы. В этом случае, если по какой-либо причине кто-то смог выбраться из специальной корневой системы, он не будет иметь возможности исполнить какиелибо программы, поскольку не будет иметь оболочки bash. Создание корневой файловой системы для демона wu-ftpd выполняется довольно легко. Создайте каталог для пользователя ftp: [root@test root]# mkdir /home/ftp [root@test root]# chown -R ftp.ftp /home/ftp Смените его домашний каталог в файле /etc/passwd : ftp:x:76:76:system user for WU-FTPD:/home/ftp:/bin/false Протестируйте анонимный ftp : [user@test user]$ ftp localhost Connected to localhost. 220-Hello, all activity on ftp.example.com is logged. 220220 Hello you 530 Please login with USER and PASS. 530 Please login with USER and PASS. KERBEROS_V4 rejected as an authentication type Name (localhost:user): ftp 331 Guest login ok, send your complete e-mail address as password. Password: 230 Guest login ok, access restrictions apply. Remote system type is UNIX. Using binary mode to transfer files. ftp> ls 200 PORT command successful. 150 Opening ASCII mode data connection for directory listing. total 16 drwxr--r-2 76 76 4096 Aug 18 15:40 incoming drwxr-xr-x 2 76 76 4096 Aug 18 15:40 pub 226 Transfer complete. ftp> cd / 250 CWD command successful. ftp> ls 200 PORT command successful. 150 Opening ASCII mode data connection for directory listing. total 16 drwxr--r-2 76 76 4096 Aug 18 15:40 incoming drwxr-xr-x 2 76 76 4096 Aug 18 15:40 pub 226 Transfer complete. Ftp>^D [user@test user]$ Анонимная выгрузка Если вы хотите разрешить выгрузку данных на сервер для анонимных пользователей, вам необходимо позаботиться о дополнительной защите. Прежде всего, нам нужно определиться с каталогом для выгрузки. Обычно такой каталог называется incoming, давайте назовем его /home/ftp/incoming. Чтобы избежать переполнения диска, нам необходимо создать отдельную файловую систему для каталога incoming и смонтировать ее в /home/ftp/incoming. Таким образом, даже если файловая система будет полностью заполнена, это никак не отразится на свободном пространстве корневой файловой системы. Далее нам нужно разрешить закачку в файле /etc/ftpaccess : upload /home/ftp /incoming yes ftp ftp 0440 nodirs Как правило, запрет создания каталогов является хорошей идеей. Те, кто ищет на FTP-серверах каталоги с возможностью записи для распространения Warez'а и тому подобных материалов, любят создавать поддиректории с очень длинными именами. Протестируйте выгрузку файлов на сервер: [user@test user]$ ftp localhost Connected to localhost. 220-Hello, all activity on ftp.example.com is logged. 220220 Hello you 530 Please login with USER and PASS. 530 Please login with USER and PASS. KERBEROS_V4 rejected as an authentication type Name (localhost:user): ftp 331 Guest login ok, send your complete e-mail address as password. Password: 230 Guest login ok, access restrictions apply. Remote system type is UNIX. Using binary mode to transfer files. ftp> ls 200 PORT command successful. 150 Opening ASCII mode data connection for directory listing. total 16 drwxr--r-2 76 76 4096 Aug 18 15:40 incoming drwxr-xr-x 2 76 76 4096 Aug 18 15:40 pub 226 Transfer complete. ftp> put gq.png local: gq.png remote: gq.png 200 PORT command successful. 553 gq.png: Permission denied on server. (Upload) ftp> cd incoming 250 CWD command successful. ftp> put gq.png local: gq.png remote: gq.png 200 PORT command successful. 150 Opening BINARY mode data connection for gq.png. 226 Transfer complete. 49841 bytes sent in 0.043 seconds (1.1e+03 Kbytes/s) ftp> mkdir test 550 test: Permission denied on server. (Upload dirs) ftp>^D [user@test user]$ 1.1 Упражнения Упражнение 1 : Установите wu-ftpd Смените предупреждающий и приветствующий текст Настройте ftp-сервер со сменой корневой файловой системы Настройте анонимную выгрузку файлов 1.1 Решения Решение 1 : Следуйте инструкциям этой главы 1 Безопасная оболочка (OpenSSH) Ключевые файл, термины и утилиты: /etc/ssh/sshd_config ~/.ssh/identity.pub и identity ~/.ssh/authorized_keys .shosts .rhosts 1.2 Настройка OpenSSH Введение OpenSSH - это бесплатная реализация безопасной оболочки (secure shell). Эта утилита является заменой старых и небезопасных утилит rsh, rlogin, telnet, ftp, ... SSH предоставляет возможности оболочки поверх безопасного зашифрованного канала передачи данных. Файлы могут передаваться с помощью утилит scp или sftp SSH предоставляет возможности маршрутизации протокола X11 Прозрачный вход в систему с аутентификацией при помощи публичных ключей sshd Сервер SSH – демон sshd - обычно устанавливается вместе с пакетом ssh. Конфигурация находится в файле /etc/ssh/sshd_config. Некоторые настройки безопасности: ... Port 22 Protocol 2 HostKey /etc/ssh/ssh_host_rsa_key HostKey /etc/ssh/ssh_host_dsa_key UsePrivilegeSeparation yes ... LoginGraceTime 600 PermitRootLogin no StrictModes yes ... #AuthorizedKeysFile %h/.ssh/authorized_keys ... IgnoreRhosts yes PermitEmptyPasswords no ssh Конфигурационный файл ssh клиента: /etc/ssh/ssh_config. X11Forwarding может быть установлен по умолчанию. Вход в систему через SSH [root@test root]# ssh 192.168.0.69 Password: Last login: Mon Jul 29 16:36:57 2004 from 192.168.0.42 [root@test1 root]# Пользователь для утилиты ssh может быть указан двумя способами [root@test root]# ssh -l root 192.168.0.69 [root@test root]# ssh [email protected] Если не указано имя пользователя, будет использоваться текущая учетная запись На удаленном хосте могут быть выполнены команды [root@test root]# ssh 192.168.0.69 ls /usr/share/doc scp / sftp Файлы можно копировать с помощью scp, утилиты безопасного копирования. [root@test root]# scp some-file.tar.gz user@remote: [root@test root]# scp some-file.tar.gz user@remote:/home/user [root@test root]# scp -r something/ user@remote:/tmp/ OpenSSH предоставляет утилиту подобную ftp - sftp, которая позволяет перемещаться по каталогами на удаленном сервере. [user@test user]$ sftp [email protected] Connecting to 192.168.0.206... Password: sftp> ls /mnt /mnt/. /mnt/.. /mnt/floppy /mnt/slash /mnt/usbstorage sftp> [user@test user]$ Безопасность Данные шифруются Нужно использовать только протокол версии 2, протокол версии 1 считается небезопасным Для идентификации на каждой машине существует ключ хоста [root@test root]# cat /etc/ssh/ssh_host_rsa_key -----BEGIN RSA PRIVATE KEY----MIICWwIBAAKBgQDLI9tAuoCgm959RaJSXMnh8UIj008r6Pg40nKuVfcsZ+nVTseY EeT0YWg8ulDUlJlDg9J+432ZRkmw3lup0U/9oMGJ8lrofK17xExH8gsHcLTiKwrZ pOXrVD19H+9B4kRnMSVeVqPcgENsHeijxp7NoZldxm5Ia17MVUUdQ6PbvQIBIwKB gAubpiD0tuSbMUj8qjCXloHwh2/C7pTLe+X9ZaOP4j0NQI/YnbDrFGW8bFs92Luw uE0AN+n+XvLQ0QLK4KqePxW0m4Itx2UeJXejoG3TUO6loct1sJnwtvZj/JSuZpv/ 9WCMrprFOOKl8b2g830U69gR8ZMwCHYhTRilcmLJUYWLAkEA5wZIlsW/RzqxJe18 FjSp1DgRLnF2pmvbJtE7+oYNXXccZTo27rLGboydjXQR7LmgtV0h9P4u5DWz3wp5 ZWgnwQJBAOEZ2zpzv6XjHO7nSenODUntaHEG3Qn4OFeoFzllioWHMS37kuyNl7mw WA/PhOvF57I4rAjcBkBj6Sbo4xspEv0CQQCearVus3vZEk2WWbQse+IrHyG5cl/9 FsIpPwSOh86mfY/QYm7PkIgRSnqqI7SFEZLFgbDigmlMB5FIfDX8ZK2LAkEAzc5/ S2KDVdb14b2FaAzY8yIzmonuqgeD+F8rLSmjOEEXBXhL0PZ8F3yoSPg/A3Mc+rd4 t6SYAFtY0x4Rd+sKCwJASvw6wMKi3EZhb4Ii3ZeG9wWMiZuWFVluzggKz7E80IJa Sn1TIzl9mnOo8/E5VoH171QOFETv1/rloIDH5QoJJw== -----END RSA PRIVATE KEY----[root@test root]# Подписи известных хостов сохраняются в домашнем каталоге пользователя: [user@test user]$ cat .ssh/known_hosts 192.168.0.206 ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAIEAz66o+3HSw83k8l0G/hi9x9NeqDZNAHoY43lE2F1JtcypJQifd N9maSrGFuUispNb1vvz69BgHdtZ1c67+EftgsGH7NCcjgFGg7AeLpdj6TVp8C0K5dLwmqIlaOdCV6 OaLyohhucpZxWRCREN1ezt0mNysdUobLP3vrPjCmqJLN8= [user@test user]$ Если во время установления ssh-соединения было определено, что подпись изменилась, SSH выводит следующее предупреждающее сообщение: [user@test user]$ ssh 192.168.0.206 @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY! Someone could be eavesdropping on you right now (man-in-the-middle attack)! It is also possible that the RSA host key has just been changed. The fingerprint for the RSA key sent by the remote host is 17:9b:fe:36:98:6f:60:75:69:47:e2:43:46:09:f6:3c. Please contact your system administrator. Add correct host key in /home/user/.ssh/known_hosts to get rid of this message. Offending key in /home/user/.ssh/known_hosts:1 Password authentication is disabled to avoid man-in-the-middle attacks. X11 forwarding is disabled to avoid man-in-the-middle attacks. Password: Вход в систему с помощью открытого ключа Механизм PKI (Public Key Infrastructure – инфраструктура открытых ключей) может использоваться вместо обычной авторизации с помощью пароля. На стороне клиента должна быть сгенерирована пара ключей – открытый и закрытый. Открытый ключ публикуется, т.е. закачивается на сервер. Если SSH обнаруживает открытый ключ, он использует этот метод аутентификации и возвращается к методу аутентификации паролем только в случае неудачи. Пара ключей может быть защищена особым паролем – он должен иметь длину минимум 25 символов, и не должен содержать нелатинских символов (представьте, что на каникулах вам придется воспользоваться иностранной клавиатурой). Если пароль не указан, вход в систему будет выполняться без пароля. Это позволяет автоматизировать различные задачи. DSA, версия 2.0 [user@test user]$ ssh-keygen -t dsa Generating public/private dsa key pair. Enter file in which to save the key (/home/user/.ssh/id_dsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/user/.ssh/id_dsa. Your public key has been saved in /home/user/.ssh/id_dsa.pub. The key fingerprint is: bb:ff:f2:c1:70:0e:80:1b:23:63:ea:a2:52:c6:64:86 user@test [user@test user]$ Каталог .ssh/ на сервере должен иметь права доступа 700. Скопируйте открытый ключ на удаленный хост или добавьте его к файлу, если он уже существует и содержит другие ключи. [user@test user]$ ssh [email protected] "mkdir .ssh; chmod 700 .ssh" Warning: Permanently added '192.168.0.206' (RSA) to the list of known hosts. Password: Warning: No xauth data; using fake authentication data for X11 forwarding. /usr/bin/X11/xauth: creating new authority file /home/user/.Xauthority [user@test user]$ scp .ssh/id_dsa.pub [email protected]:/home/user/.ssh/authorized_keys Password: id_dsa.pub 100% 599 1.7MB/s 00:00 [user@test user]$ Проверьте аутентификацию с открытым ключом: [user@test user]$ ssh [email protected] Warning: No xauth data; using fake authentication data for X11 forwarding. Linux socrate 2.6.5 #8 Sun Apr 4 15:29:35 CEST 2004 i686 GNU/Linux user@socrate:~$ RSA, версия 2.0 [user@test user]$ ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/home/user/.ssh/id_rsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/user/.ssh/id_rsa. Your public key has been saved in /home/user/.ssh/id_rsa.pub. The key fingerprint is: 7f:2b:75:4d:dc:01:06:63:e9:90:dc:a0:71:67:a2:40 user@test [user@test user]$ Каталог .ssh/ на сервере должен иметь права доступа 700. Скопируйте открытый ключ на удаленный хост или добавьте его к файлу, если он уже существует и содержит другие ключи. [user@test user]$ scp .ssh/id_rsa.pub [email protected]:/home/user/.ssh/test_pub_key id_rsa.pub 100% 219 2.6MB/s 00:00 [user@test user]$ ssh [email protected] cat .ssh/test_pub_key >> .ssh/authorized_keys Warning: No xauth data; using fake authentication data for X11 forwarding. [user@test user]$ Настройка маршрутизации X-протокола На сервере в файле /etc/ssh/sshdconfig должна присутствовать строка: X11Forwarding yes На клиенте мы должны использовать опцию -X: [user@test user]$ ssh -X [email protected] Warning: No xauth data; using fake authentication data for X11 forwarding. Linux socrate 2.6.5 #8 Sun Apr 4 15:29:35 CEST 2004 i686 GNU/Linux Last login: Wed Aug 18 19:15:29 2004 from 192.168.0.42 user@socrate:~$ 1.1 Упражнения Упражнение 1 : Когда вы аутентифицируетесь на новом сервере с помощью SSH, как вы можете узнать, что «отпечаток» ключа, предоставленный вам, корректен? Как вы можете в этом убедиться? Работает ли асимметричная аутентификация с утилитой scp ? Настройте вашу систему на использование алгоритма шифрования RSA и протокола SSH 2 для удаленного входа в систему Используйте утилиты scp и sftp с асимметричной аутентификацией 1.1 Решения Решение 1 : Проверив отпечаток сервера у его администратора (например, по телефону). Да Следуйте инструкциям этой главы 1 Поддержание безопасности системы Ключевые файлы, термины и утилиты: Tripwire telnet nmap 1.2 Выполнение задач по поддержанию безопасности Введение Безопасность – это не состояние и не результат, а непрекращающийся процесс. Это означает, что администратор должен просматривать файлы журналов каждый день, устанавливать обновления для системы, применять патчи, в частности, устраняющие проблемы с безопасностью, запускать сканеры, выявляющие потенциальные уязвимости (такие как Nessus), запускать системы обнаружения вторжений (на уровне хоста, такие как Tripwire или на уровне локальной сети как Snort) и т.п... Работа администратора по обеспечению безопасности занимает полный рабочий день. Основы Kerberos Введение: Kerberos - это механизм аутентификации, созданный в MIT (Massachusets Institute of Technology – Массачусетский Технологической Институт). Этот механизм использует сильное шифрование данных и аутентификацию для удостоверения обмена данными между клиентом и сервером или приложениями. Каждое приложение, которое хочет использовать механизм аутентификации Kerberos, должно иметь встроенную поддержку Kerberos. Большинство приложений, таких как клиенты telnet или ftp были переписаны с поддержкой kerberos. Важно знать, что локальные приложения вашей компании могут потребовать доработки, чтобы сделать их совместимыми с kerberos. Как это работает: Клиент (или сервис, или пользователь) посылает запрос на получение билета (авторизации для клиента, позволяющей использовать определенный сервис в течение определенного периода времени) на сервер Kerberos, именуемый KDC (Key Distribution Center – центр распределения ключей – этот сервер содержит базу паролей клиентов). KDC генерирует билет (TGT : Ticket Granting Ticket), шифруя его паролем клиента, и отсылает обратно. Клиент расшифровывает билет и использует его для доступа к сервису. Настройка: Kerberos использует следующие конфигурационные файлы: /etc/kerberos/krb5kdc/kdc.conf /etc/kerberos/krb5kdc/kadm5.acl Затем нужно предпринять следующие шаги: Создать базу данных с помощью основной утилиты Kerberos: kdb5_util Добавить администраторов Kerberos с помощью kadmin Запустить демоны Kerberos: /etc/rc.d/init.d/kadmin /etc/rc.d/init.d/kprop /etc/rc.d/init.d/krb524 /etc/rc.d/init.d/krb5kdc /etc/rc.d/init.d/krb5server Создать хосты и сервисы в базе KDC с помощью kadmin Установить Kerberos на клиентские машины Быть в курсе Очень важно регулярно просматривать главные списки рассылки, посвященные безопасности. В них публикуется информация о новых уязвимостях. Существует несколько списков рассылки, относящихся к безопасности: BugTraq (www.securityfocus.com) - наиболее известный список рассылки, посвященный компьютерной безопасности. Почти все уязвимости попадают в этот список, иногда с инструкциями по их эксплуатации или описанием. CERT / CC (Computer Emergency Response Team / Coordination Center www.cert.org) - Центр экспертизы безопасности Интернета. Обрабатывает информацию об уязвимостях, поддерживая базу данных, а также предоставляют услуги по обучению в области безопасности (сертификация и т.п.) CIAC (www.ciac.org) - консультативная служба компьютерных сбоев, поддерживаемая Министерством Энергетики США. Выполняет почти ту же работу, что и CERT/CC, но для Министерства Энергетики. Выявление открытых почтовых ретрансляторов Открытый почтовый ретранслятор (open relay) - это почтовый сервер, принимающий соединения от всех и вся. Такие серверы используются спамерами для рассылки спама. Проверка на то, что сервер является открытым релеем, довольно проста: [user@test user]$ telnet localhost 25 Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. 220 [email protected] ESMTP Sendmail 8.12.11/8.12.11; Wed, 18 Aug 2004 22:06:55 +0200 HELO test 250 [email protected] Hello localhost [127.0.0.1], pleased to meet you mail from: [email protected] 250 2.1.0 [email protected]... Sender ok rcpt to: [email protected] 250 2.1.5 [email protected]... Recipient ok DATA 354 Enter mail, end with "." on a line by itself test open relay . 250 2.0.0 i7IK6tPp009873 Message accepted for delivery ^] telnet> Connection closed. [user@test user]$ Почтовый сервер должен принимать «заказ» на отправку почты только от известных пользователей. В наши дни, почтовые сервера по умолчанию настроены на запрет открытой ретрансляции. Системы обнаружения вторжений Tripwire : Tripwire - это утилита обнаружения вторжений. Эта программа осуществляет мониторинг изменений ключевых файлов, отслеживая контрольные суммы, размеры, и т.п. Tripwire выявляет и генерирует отчеты об изменениях в тысячах стратегически важных системных файлов. Если утилита обнаружила измененный файл, то вы решаете, является ли это изменение результатом нормальных действий в системе. Если это так, модифицируйте базу Tripwire, чтобы это изменение перестало попадать в отчет. Если же изменение не является результатом нормальной деятельности, исследуйте его на предмет потенциального взлома. Настройка: Два конфигурационных файла: /etc/tripwire/twcfg.txt ROOT POLFILE DBFILE REPORTFILE SITEKEYFILE LOCALKEYFILE EDITOR LATEPROMPTING LOOSEDIRECTORYCHECKING MAILNOVIOLATIONS EMAILREPORTLEVEL REPORTLEVEL MAILMETHOD SYSLOGREPORTING MAILPROGRAM =/usr/sbin =/etc/tripwire/tw.pol =/var/lib/tripwire/$(HOSTNAME).twd =/var/lib/tripwire/report/$(HOSTNAME)-$(DATE).twr =/etc/tripwire/site.key =/etc/tripwire/$(HOSTNAME)-local.key =/bin/vi =false =false =true =3 =3 =SENDMAIL =false =/usr/sbin/sendmail -oi -t Здесь мы задаем главные настройки Tripwire. /etc/tripwire/twpol.txt ... [пропущено] ... @@section GLOBAL TWROOT=/usr/sbin; TWBIN=/usr/sbin; TWPOL="/etc/tripwire"; TWDB="/var/lib/tripwire"; TWSKEY="/etc/tripwire"; TWLKEY="/etc/tripwire"; TWREPORT="/var/lib/tripwire/report"; HOSTNAME=localhost; @@section FS SEC_CRIT = $(IgnoreNone)-SHa ; SEC_SUID = $(IgnoreNone)-SHa ; set SEC_BIN = $(ReadOnly) ; SEC_CONFIG = $(Dynamic) ; infrequently but accessed often SEC_LOG = $(Growing) ; change ownership SEC_INVARIANT = +tpug ; permission or ownership SIG_LOW = 33 ; security impact SIG_MED = 66 ; significant security impact SIG_HI = 100 ; points of vulnerability # Critical files that cannot change # Binaries with the SUID or SGID flags # Binaries that should not change # Config files that are changed # Files that grow, but that should never # Directories that should never change # Non-critical files that are of minimal # Non-critical files that are of # Critical files that are significant ... [SNIP] ... ( rulename = "Kernel Administration Programs", severity = $(SIG_HI) ) { /sbin/adjtimex /sbin/ctrlaltdel /sbin/depmod /sbin/insmod /sbin/insmod.static /sbin/insmod_ksymoops_clean /sbin/klogd /sbin/ldconfig /sbin/minilogd /sbin/modinfo -> -> -> -> -> -> -> -> -> -> $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) $(SEC_CRIT) ; ; ; ; ; ; ; ; ; ; #/sbin/nuactlun #/sbin/nuscsitcpd /sbin/pivot_root /sbin/sndconfig /sbin/sysctl -> $(SEC_CRIT) ; -> $(SEC_CRIT) ; -> $(SEC_CRIT) ; -> $(SEC_CRIT) ; -> $(SEC_CRIT) ; } Здесь мы задаем то, какие атрибуты и для каких файлов мы собираемся проверять. Каждый файл является объектом, для которого задается маска свойств : Свойство Атрибут объекта Свойство Атрибут объекта a Время доступа p Права и режим доступа b Число занятых на диске блоков r ID устройства, на которое указывает дескриптор (допустимо только для файлов устройств) c Время создания/изменения дескриптора файла s Размер файла d ID устройства, на котором находится дескриптор файла t Тип файла g ID группы, владельца файла u ID владельца файла i Номер дескриптора C Хэш CRC-32 l Файл увеличивается в размере H Хэш Haval m Время модификации M Хзш MD5 n Число ссылок S Хзш SHA В Tripwire существует набор предопределенных переменных – комбинаций свойств: Переменная Маска свойств Что делает $(ReadOnly) +pinugtsdbmCM-rlacSH Переменная ReadOnly подходит для доступных всем файлов, которые, тем не менее, должны оставаться доступными только для чтения. $(Dynamic) +pinugtd-srlbamcCMSH Dynamic подходит для мониторинга каталогов и файлов, которые имеют тенденцию к изменению. $(Growing) +pinugtdl-srbamcCMSH Переменная Growing подходит для файлов, которые должны только увеличиваться в размере. $(Device) +pugsdr-intlbamcCMSH Device хорош для устройств или других файлов, которые Tripwire не должен пытаться открыть. $(IgnoreAll) -pinugtsdrlbamcCMS IgnoreAll отслеживает присутствие или отсутствие файла, но не проверяет другие свойства. $(IgnoreNone) +pinugtsdrbamcCMSH-l IgnoreNone проверяет все свойства, и предоставляет разумный начальный вариант для задания вашей собственной маски. (Например, mymask = $(IgnoreNone) -ar;). Имейте в виду, что свойство l (растущий файл) не отслеживается маской $(IgnoreNone). Третий конфигурационный файл: /etc/tripwire/twinstall.sh. Этот скрипт должен быть запущен после установки. [root@test tripwire]# ./twinstall.sh ---------------------------------------------The Tripwire site and local passphrases are used to sign a variety of files, such as the configuration, policy, and database files. Passphrases should be at least 8 characters in length and contain both letters and numbers. See the Tripwire manual for more information. ---------------------------------------------Creating key files... ... [пропущено] ... ---------------------------------------------Signing policy file... Please enter your site passphrase: Wrote policy file: /etc/tripwire/tw.pol A clear-text version of the Tripwire policy file /etc/tripwire/twpol.txt has been preserved for your inspection. This implements a minimal policy, intended only to test essential Tripwire functionality. You should edit the policy file to describe your system, and then use twadmin to generate a new signed copy of the Tripwire policy. [root@test tripwire]# На следующем шаге необходимо инициализировать базу tripwire: [root@test tripwire]# tripwire --init Please enter your local passphrase: Parsing policy file: /etc/tripwire/tw.pol Generating the database... *** Processing Unix File System *** ... [пропущено] ... Wrote database file: /var/lib/tripwire/test.twd The database was successfully generated. [root@test tripwire]# Теперь мы можем проверить систему с помощью этой базы: [root@test tripwire]# tripwire --check ... [пропущено] ... Tripwire(R) 2.3.0 Integrity Check Report Report generated by: Report created on: Database last updated on: Thu Aug 19 11:06:11 2004 Never ============================================================================= Report Summary: ============================================================================= Host name: Host IP address: Host ID: Policy file used: Configuration file used: Database file used: Command line used: test Unknown IP None /etc/tripwire/tw.pol /etc/tripwire/tw.cfg /var/lib/tripwire/test.twd tripwire --check ============================================================================= Rule Summary: ============================================================================= ----------------------------------------------------------------------------Section: Unix File System ----------------------------------------------------------------------------Rule Name Modified --------Invariant Directories Temporary directories * Tripwire Data Files Critical devices Severity Level Added Removed -------------- ----- ------- ------- 66 33 100 100 0 0 1 0 0 0 0 0 0 0 0 0 ... [SNIP] ... ----------------------------------------------------------------------------*** End of report *** Tripwire 2.3 Portions copyright 2000 Tripwire, Inc. Tripwire is a registered trademark of Tripwire, Inc. This software comes with ABSOLUTELY NO WARRANTY; for details use --version. This is free software which may be redistributed or modified only under certain conditions; see COPYING for details. All rights reserved. Integrity check complete. [root@test tripwire]# После проверки tripwire генерирует отчет с именем – временем запуска. Этот отчет находится в каталоге /var/lib/tripwire/report : [root@test root]# ls /var/lib/tripwire/report/ test-20040819-110611.twr [root@test root]# Если обнаруженные изменения - результат нормальной работы системы, то мы можем обновить базу. Если это не так, мы должны проверить, что система не была взломана. Обновление базы tripwire: [root@test tripwire]# /usr/sbin/tripwire --update --twrfile /var/lib/tripwire/report/test-20040819-110611.twr Please enter your local passphrase: Wrote database file: /var/lib/tripwire/test.twd [root@test tripwire]# Snort : Введение: Snort - это система обнаружения вторжений с открытым исходным кодом, способная выполнять анализ трафика в реальном времени и регистрацию пакетов в IP-сетях. Утилита может выполнять анализ протоколов, поиск определенного содержимого и может быть использована для обнаружения различных атак и зондирований, таких как переполнение буфера, сканирование портов, атак на CGI, зондирований SMB, попыток определения операционной системы и многого другого. Snort также может быть использован для прослушивания трафика: [root@test root]# snort -v Running in packet dump mode Log directory = /var/log/snort Initializing Network Interface eth0 --== Initializing Snort ==-Initializing Output Plugins! Decoding Ethernet on interface eth0 --== Initialization Complete ==--*> Snort! <*Version 2.1.0 (Build 9) By Martin Roesch ([email protected], www.snort.org) 08/19-12:15:15.663264 0.0.0.0:68 -> 255.255.255.255:67 UDP TTL:128 TOS:0x0 ID:17587 IpLen:20 DgmLen:328 Len: 300 =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ 08/19-12:15:19.668662 0.0.0.0:68 -> 255.255.255.255:67 UDP TTL:128 TOS:0x0 ID:17589 IpLen:20 DgmLen:328 Len: 300 =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ 08/19-12:15:21.192426 ARP who-has 192.168.0.254 tell 192.168.0.42 08/19-12:15:21.192587 ARP reply 192.168.0.254 is-at 0:C0:9F:2F:7E:DD 08/19-12:15:21.192598 192.168.0.42:33122 -> 199.107.65.177:80 TCP TTL:64 TOS:0x0 ID:34789 IpLen:20 DgmLen:60 DF ******S* Seq: 0x2D71BAF6 Ack: 0x0 Win: 0x16D0 TcpLen: 40 TCP Options (5) => MSS: 1460 SackOK TS: 10370323 0 NOP WS: 0 =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ ... [пропущено] ... более подробный вывод: [root@test root]# snort -vde Running in packet dump mode Log directory = /var/log/snort Initializing Network Interface eth0 --== Initializing Snort ==-Initializing Output Plugins! Decoding Ethernet on interface eth0 --== Initialization Complete ==--*> Snort! <*Version 2.1.0 (Build 9) By Martin Roesch ([email protected], www.snort.org) 08/19-12:16:23.135164 0:40:F4:98:D2:D9 -> 0:C0:9F:2F:7E:DD type:0x800 len:0x62 192.168.0.42 -> 4.2.2.1 ICMP TTL:64 TOS:0x0 ID:0 IpLen:20 DgmLen:84 DF Type:8 Code:0 ID:35600 Seq:1 ECHO F7 7D 24 41 E3 0F 02 00 08 09 0A 0B 0C 0D 0E 0F .}$A............ 10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F ................ 20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F !"#$%&'()*+,-./ 30 31 32 33 34 35 36 37 01234567 =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ 08/19-12:16:23.441050 0:C0:9F:2F:7E:DD -> 0:40:F4:98:D2:D9 type:0x800 len:0x62 4.2.2.1 -> 192.168.0.42 ICMP TTL:244 TOS:0x0 ID:17833 IpLen:20 DgmLen:84 DF Type:0 Code:0 ID:35600 Seq:1 ECHO REPLY F7 7D 24 41 E3 0F 02 00 08 09 0A 0B 0C 0D 0E 0F .}$A............ 10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F ................ 20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F !"#$%&'()*+,-./ 30 31 32 33 34 35 36 37 01234567 =+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ Настройка: Мы хотим запустить snort в режиме демона, обнаруживающего внешние вторжения. Главный конфигурационный файл snort /etc/snort/snort.conf : #-------------------------------------------------# http://www.snort.org Snort 2.1.0 Ruleset # Contact: [email protected] #-------------------------------------------------# $Id: snort.conf,v 1.133 2003/12/18 17:05:07 cazz Exp $ # ################################################### # This file contains a sample snort configuration. # You can take the following steps to create your own custom configuration: # # 1) Set the network variables for your network # 2) Configure preprocessors # 3) Configure output plugins # 4) Customize your rule set # ################################################### ... [пропущено] ... Эти комментарии отражают главные шаги настройки Snort: Задание локальной сети: мы сообщаем snort наш IP-адрес, а также, что является нашей сетью, а что внешней Настройка процессоров: процессоры - это расширения snort выполняющие какие-либо действия. Например, существуют процессоры, декодирующие HTTP-трафик. Как правило, работа процессоров занимает существенную часть процессорного времени. Настройка подключаемых модулей вывода данных: позволяют выбрать, осуществлять ли регистрацию данных в текстовом файле, базе данных SQL или где-либо еще. Настройка набора правил: правила задают то, что должен отслеживать snort. Правила помещаются в несколько файлов, в зависимости от их типа. В этом месте мы должны выбрать, что мы хотим отслеживать (например, деактивируйте мониторинг сервера IIS, если его нет в вашей сети) Правила Snort обычно находятся в /etc/snort/rules : [root@test root]# ls /etc/snort/rules/ attack-responses.rules experimental.rules shellcode.rules web-cgi.rules backdoor.rules exploit.rules smtp.rules web-client.rules bad-traffic.rules finger.rules snmp.rules web-coldfusion.rules chat.rules ftp.rules sql.rules web-frontpage.rules ddos.rules icmp-info.rules telnet.rules web-iis.rules deleted.rules icmp.rules tftp.rules web-misc.rules dns.rules imap.rules virus.rules web-php.rules dos.rules info.rules web-attacks.rules x11.rules [root@test root]# local.rules p2p.rules misc.rules policy.rules multimedia.rules pop2.rules mysql.rules pop3.rules netbios.rules porn.rules nntp.rules rpc.rules oracle.rules rservices.rules other-ids.rules scan.rules Простое правило выглядит следующим образом: alert tcp $EXTERNAL_NET any -> $HOME_NET 21 (msg:"FTP CWD ..."; flow:to_server,established; content:"CWD"; nocase; content:"..."; classtype:bad-unknown; sid:1229; rev:5;) Это правило означает, что snort должен подать сигнал тревоги, если он получит пакет, пришедший из внешней сети и адресованный нашей локальной сети, предназначенный для порта FTP и содержащий строку “CWD”. Чтобы запустить демон snort: [root@test root]# /etc/init.d/snortd start Starting snort: [root@test root]# [ OK ] 1.1 Упражнения Упражнение 1 : Изучите основы kerberos Посетите списки рассылки, посвященные компьютерной безопасности Проверьте почтовый сервер на доступность спамерам Упражнение 2 : Установите и настройте tripwire Настройте конфигурационный файл Измените какой-нибудь файл и запустите проверку: tripwire –check Упражнение 3 : Настройте Snort Протестируйте snort, выполнив какие-нибудь простые атаки, отслеживайте записи в файлах журналов 1.1 Решения Решение 1 : http://www.securityfocus.com/archive/1 http://www.cert.org/ http://www.ciac.org/ciac/index.html Следуйте инструкциям этой главы Решение 2 : Следуйте инструкциям этой главы Устранение неполадок в работе сети В этой главе 1.1 Поиск неисправностей в работе сети .......................................... Устранение неполадок в работе сети ..................................................................................................... 205 1 Поиск неисправностей в сети ................................................................................................................206 1 Поиск неисправностей в сети Ключевые файлы, термины и утилиты: /sbin/ifconfig /sbin/route /bin/netstat /etc/network || /etc/sysconfig/network-scripts/ system log files such as /var/log/syslog && /var/log/messages /bin/ping /etc/resolv.conf /etc/hosts /etc/hosts.allow && /etc/hosts.deny /etc/hostname || /etc/HOSTNAME /sbin/hostname /usr/sbin/traceroute /usr/bin/nslookup /usr/bin/dig /bin/dmesg host 1.2 Поиск неисправностей в работе сети Когда у вас возникает проблема в работе сети, лучше всего искать её, последовательно рассматривая все уровни сетевой топологии. Например: mii-tool или ethertool, проверка того, что сетевой кабель подключен к сетевой карте Проверка локального IP-адреса с помощью ping Запуск ping для IP-адреса маршрутизатора, для DNS-сервера, ... Запуск ping по имени компьютера Обращение с помощью telnet или netcat к серверу Проверка наличия трафика на маршрутизаторе Запуск ping для компьютера вне локальной сети Обращение с помощью telnet или netcat к серверу, расположенному вне локальной сети Наблюдайте за журналами syslog и другими регистрационными файлами на своём компьютере и серверах в процессе выполнения проверок.. Всегда проверяйте содержимое /var/log/syslog и /var/log/message Тест для закрепления знаний В этой главе Тест для закрепления знаний ...................................................................................................................208 1 Тест .........................................................................................................................................................209 2 Ответы к тесту .........................................................................................................................................212 3 Авторы .....................................................................................................................................................213 1 Тест A) Как вывести на экран текущее содержимое кэша ARP ? 1. netstat -arp 2. arp -a 3. arp -l 4. cat /proc/arp B) Вы хотите запретить доступ к вашему внутреннему HTTP-серверу из внешней сети. Какое правило iptables следует добавить на межсетевом экране ? 1. iptables -A FORWARD -p tcp -s ! $LOCAL_NET -d $WEB_SERVER --dport 80 -j DROP 2. iptables -A INPUT -p tcp -s $LOCAL_NET -d $WEB_SERVER -dport 80 -j DROP 3. iptables -A INPUT -p tcp -s not $LOCAL_NET -d $WEB_SERVER --dport 80 -j DROP 4. iptables -A FORWARD -p tcp -s not $LOCAL_NET -d $WEB_SERVER --dport 80 -j DROP C) В чем состоит разница между параметрами «requisite» и «require» в технологии PAM ? 1. Нет разницы 2. require более строг 3. requisite более строг D) Какой файл необходимо изменить, чтобы перенаправить системный журнал в /dev/tty12 ? 1. /etc/securetty 2. /etc/inittab 3. /etc/syslog.conf 4. /etc/sysconfig/tty E) Как называется сервер репликаций OpenLDAP ? 1. slapd 2. slapd-slave 3. smackd 4. slurpd F) При подключении к вашему DNS-серверу по SSH, вы получили сообщение: “WARNING : REMOTE HOST AUTHENTICATION HAS CHANGED”. Что произошло ? 1. Вы забыли перезапустить демон SSH после установки 2. Вы переустановили сервер OpenSSH, очистив все его конфигурационные файлы 3. Ваш SSH-клиент не совместим с SSH-сервером 4. Это бывает лишь с серверами в других сетях G) Вам необходимо установить DHCP-сервер на предприятии, где вы работаете. DHCP будет использоваться всеми машинами, но сервера должны получать статичные IPадреса. Как DHCPD распознает эти сервера ? 1. По их IP-адресу 2. По их имени хоста 3. По их MAC-адресу 4. Присвоить статичные IP-адреса машинам невозможно. DHCP всегда выдает динамические IP-адреса. H) Ваш DNS-сервер выдает ошибку при старте. Какую утилиту вы используете для того, чтобы проверить конфигурационные файлы named ? 1. bind-checkconf 2. named-checkconf 3. bind-conf 4. named-conf I) Что из перечисленного не является защищенным VPN-протоколом ? 1. PPOE 2. IPSEC 3. PPTP 4. CIPE J) В Kerberos, клиенты получают билеты в : 1. KSC 2. KTC 3. KDC 4. KGC K) В чем состоит отличие между Snort и Tripwire : 1. Tripwire - это HIDS (система обнаружения вторжений хоста), а Snort – NIDS (сетевая система обнаружения вторжений) 2. Tripwire следит за активностью на хосте, тогда как Snort следит за активностью на хосте и в сети 3. Tripwire может работать в режиме демона, а Snort нет 4. Оба этих продукта используют базу данных подозрительных действий 1 Ответы к тесту A) 2 B) 1 C) 3 D) 3 E) 4 F) 2 G) 3 H) 2 I) 1 J) 3 K) 1 2 Авторы Данный материал разработан компанией LynuxTraining. Перевод на русский язык: Агапова Ксения, Шабунио Юлия, Шер Павел Координатор перевода: Синицын Валентин Словарь терминов 10BaseT Сеть Ethernet по UTP-кабелям, с использованием концентраторов для получения топологии звезды; теоретически имеет максимальную скорость передачи 10 Mbit/s. 100BaseT Сеть Ethernet по UTP-кабелям, с использованием концентраторов для получения топологии звезды; теоретически имеет максимальную скорость передачи 100 Mbit/s. ALT ANSI Клавиша Alt (Alternative) на клавиатуре. Национальный Институт Стандартизации США (American National Standards Institute). Набор стандартов, которым отвечают большинство протоколов. API Программный интерфейс приложения (Application Programming Interface). Спецификация, позволяющая при написании программ иметь простой доступ к функциям библиотеки или другим системным ресурсам; функциональность операционной системы доступна через API. ARP ASCII ATA Протокол разрешения адреса (Address Resolution Protocol), см. RFC826. Низкоуровневый протокол который по IP адресу в локальной сети определяет Ethernet MAC адрес соответствующего интерфейса. Американский национальный стандартный код для обмена информацией (American National Standard Code for Information Interchange). Спецификация символов, широко используемая в мире UNIX и не только в нем. Популярный 16-битный стандарт интерфейса, который позволяет ISA шине в IBM PC-AT присоединять внешние устройства; включает 5 поколений; первоначальный ATA больше известен как IDE. ATAPI Пакетный интерфейс периферийных устройств для АТ-совместимых компьютеров (AT Attachment Packet Interface). Усовершенствование протокола ATA, позволяющее подключать приводы компакт-дисков и прочее. BIOS BSD Базовая система ввода-вывода (Basic Input/Output Operating System). Простая низкоуровневая операционная система, которая обеспечивает единообразный API к высокоуровневым операционным системам. Система Беркли (Berkeley Systems Distribution). Вариант UNIX, первоначально разработанный в Калифорнийском университете (University of California). BUGTRAQ Список почтовой рассылки для дискуссий, посвященных сетевой безопасности (демоны, программы, операционные системы, маршрутизаторы). C C++ Компилируемый язык программирования, тесно связанный с UNIX. Объектно-ориентированный язык программирования, базирующийся на языке C. CD-ROM Компакт-дисковое запоминающее устройство (Compact Disc Read Only Memory). Довольно популярный съемный носитель, известный в нескольких вариациях, наиболее широко используется ISO9660. CERT CGI CHAP char CIDR CIFS CPU Группа компьютерной "скорой помощи" (Computer Emergency Response Team). Коллектив людей, изучающих безопасность Интернета и обеспечивающих службу устранения неполадок; см. http://www.. Общий шлюзовой интерфейс (Common Gateway Interface). Стандарт, позволяющий приложениям сервера запускаться в ходе выполнения HTTP-запроса. Протокол аутентификации с предварительным согласованием вызова (Challenge Handshake Authentication Protocol). Тип данных C (обычно один байт), используемый для представления символов. Бесклассовая маршрутизация между доменами (Classless Inter-Domain Routing). См RFC1519; ср. Маска подсети переменной длины. Общий протокол доступа к файлам Интернет (Common Internet File System). Преемник SMB от Microsoft, набор протоколов для доступа в файлам и службам печати. Центральный процессор (Central Processing Unit). Главный компонент, позволяющий компьютеру работать; в настоящее время часто называется "микропроцессор" и располагается в отдельной кремниевой микросхеме (ср. Процессор). CSLIP Сокращенный протокол интерфейса линии последовательной передачи (Compressed Serial Line IP). SLIP с добавленным VJ сжатием заголовков IP. См RFC1144. CTRL Клавиша Control на клавиатуре. Debian DEBorah & IAN (Murdock). Дистрибутив GNU/Linux, распространяемый организацией добровольцев. DEL DES DHCP DMA DNS EIDE Клавиша Delete на клавиатуре. Стандарт шифрования данных (Data Encryption Standard). Стандарт для шифрования данных, одобренный правительством США, в настоящее время считается незащищенным от мощных атак. Протокол динамической конфигурации узла (Dynamic Host Configuration Protocol). Обеспечивает автоматическое назначение IP-адресов и других данных конфигурации от сервера к клиенту. Позволяет использовать IP-адреса повторно, так что число узлов может превышать число доступных IP адресов. См. RFC2131, ср. BOOTP. Прямой доступ к памяти (Direct Memory Access). Протокол оборудования, позволяющий специальному устройству (контроллеру DMA) передавать блоки данных от буферной памяти периферийного устройства непосредственно основной памяти без привлечения CPU; ср. PIO. Служба имен доменов (Domain Name System). Иерархически построенная распределенная служба каталогов, которая переводит имена, распознаваемые человеком, такие как www.lpi.org в соответствующие IP-адреса. См. RFC's 1034 и 1035, а также 1032 и 1033. Улучшенный IDE (Enhanced IDE). Запатентованное Western Digitals расширение стандарта интерфейса IDE с свойствами ATA-2 и ATAPI, используемое при подключении жестких дисков и приводов компакт-дисков к ПК. e-mail Электронная почта. ESC Клавиша Escape на клавиатуре. Ethernet Разновидность интерфейса для компьютерной сети LAN, использующая коаксиальный кабель (10Base2 или 10Base5) или кабели UTP (10BaseT или 100BaseT). Спецификации описаны в IEEE стандарте 802.2. ср. MAC. FAT FHS Таблица размещения файлов (File Allocation Table). Простая файловая система, использующая таблицу для индексирования файлов на блочном устройстве (гибком или жестком диске). Имеет разновидности FAT-12 (MS-DOS), FAT-16 (MS-DOS, MS-Windows 3.x) и "FAT-32" (MS-Windows 9x). Стандарт иерархии файловых систем (Filesystem Hierarchy Standard). Предлагаемый стандарт для расположения файлов в системе Unix. См. http://www.pathname.com/. forwarding Действие, заключающееся в получении электронной почты и пересылке ее на другой адрес. FSF Фонд Свободного Программного Обеспечения (Free Software Foundation) : освобождающая от уплаты налогов благотворительная организация, привлекающая средства для оплаты работ над проектом GNU; см. http://www.fsf.org. FSSTND Стандарт для расположения файлов в системе Linux; заменен на FHS. FTP GB GID GNU GPL Протокол передачи файлов (File Transfer Protocol). Протокол для передачи файлов по Интернету, а также приложение, совершающее эту передачу. См. RFC959. Гигабайт, Gb : 1000 (реже 1024) MB (1,000,000,000 или 1,048,576,000 или 1,073,741,824 байт) ID группы. ГНУ (GNU's Not Unix). Проект FSF для Unix(R)(TM)-совместимых утилит и программ, основанный исключительно на свободном исходном коде. Универсальная Общественная Лицензия (General Public License). Лицензия для распространения свободного программного обеспечения, которая разрешает копирование, изменение и перераспространение. Создана FSF для проектов, подобных GNU, также применима и к Linux. См. http://www.gnu.org/copyleft/gpl.html. HDLC Высокоуровневый протокол управления каналом (High-level Data Link Control). Стандарт ISO/IEC 3309; соответствует PPP. HOWTO Набор документов определенной тематики, формирующий ощутимую часть документации по Linux. Происходит от LDP, и, большей частью, публикуется им же. HTML HTTP Язык гипертекстовой разметки (HyperText Markup Language). Стандарт для определения структуры документа, определяемой тегами в тексте документа; используется в WWW совместно с HTTP. Протокол гипертекстовой передачи (HyperText Transfer Protocol). Серия протоколов на уровне приложения, используемых для связи между WWW-браузером и WWW-сервером. См. RFC2616. I/O ICMP ID IDE IEEE IMAP IP IRQ ISA ISDN ISO KB kbit/s Ввод/Вывод (Input/Output). Протокол управляющих сообщений в сети Internet (Internet Control Message Protocol). Необходимый протокол (RFC792) для уведомления об ошибках между шлюзами и узлами в сетях на основе IP. Действует на уровне протокола IP внутри сетевого уровня. Идентификатор. Встроенный интерфейс дисковых устройств (Integrated Drive Electronics). Популярный интерфейс для подключения жестких дисков к ПК, при этом электронные устройства контроллера расположены не на отдельной карте ПК, а встроены в дисковое устройство; См. также ATA. Институт инженеров по электротехнике и электронике (Institute of Electrical and Electronics Engineers). Базирующаяся в США международная организация профессиональных инженеров; также орган стандартизации. Протокол доступа к сообщениям в сети Интернет (Internet Message Access Protocol). См. RFC2060 на IMAP4. Протокол Интернета (Internet Protocol). Протокол сетевого уровня, используемый в IP-сетях. См. RFC791. Запрос на прерывание (Interrupt ReQuest). Архитектура, соответствующая промышленному стандарту (Industry Standard Architecture). Устаревший стандарт PC-шины. Цифровая сеть связи с комплексными услугами (Integrated Services Digital Network). Протокол для узкоканальной передачи, используемый телефонными компаниями для получения одного, двух, или более B-каналов (каналов-носителей) со скоростью передачи 64 Kbit/s каждый, по медным проводам длиной до 5.5 км. Каждый B-канал может быть использован для обеспечения высококачественной голосовой связи, службы факсов или передачи данных. Международная организация по стандартизации (International Standards Organization). Один из нескольких органов, учреждающих стандарты, в том числе и компьютерные. Килобайт, kb, kB, 1024 байт. Килобит в секунду, kbps, Kbps, Kbit/s. Скорость передачи данных, равная 1000 бит в секунду. Kbyte/s Килобайт в секунду, kbps, Kbps, KBps, KB/s, kbyte/s. Скорость передачи данных, равная 1024 байт в секунду. LAN LDP LILO Локальная сеть (Local Area Network). Небольшая сеть, как правило, из одного или нескольких сегментов, поддерживающая широковещательные передачи и прямые соединения между узлами; например, Ethernet, Token Ring, Appletalk и ARCNet; ср. WAN. Проект документирования Linux (Linux Documentation Project). Загрузчик Linux (Linux Loader). Загрузчик: программа, загружающая ядро Linux, с тем чтобы Linux мог запуститься; также может загружать другие операционные системы.. LLC LPI MAC Управление логическим соединением (Logical Link Control). Сетевой стандарт IEEE (#802.2), который действует внутри уровня 2 ISO/OSI : канального уровня, над подуровнем MAC. Имеет дело с определением ошибок, контролем переполнения и форматом кадров. Институт профессиональных пользователей Linux (Linux Professional Institute). Некоммерческая организация, основанная для создания широко поддерживаемых программ сертификации для Linux; см. http://www.lpi.org/. Управление доступом к носителю (Media Access Control). Уровень сетевого стандарта IEEE (#802.x) действующий в уровне 2 ISO/OSI: уровень связи данных, под подуровнем LLC. Имеет дело с методами доступа, определением ошибок, и форматами передач. Известными спецификациями IEEE MAC является Ethernet в своих разновидностях (#802.2) и Token Ring (#802.5?). MandrakeSoft Коммерческий дистрибутив Linux. MB Мегабайт, мег, Mb 1000 (или иногда 1024) KB (1,000,000 или 1,024,000 или 1,048,576 байт). Mbit/s Мегабит в секунду, Mbps. Скорость передачи данных, равная 1,000,000 бит в секунду. MBR Главная загрузочная запись (Master Boot Record). Область на внешнем цилиндре жесткого диска ПК, содержащая таблицу разделов. Таблица разделов состоит из четырех записей, определяющих тип, стартовый цилиндр и размеры разделов жесткого диска, коих может быть четыре штуки. Одна из этих записей помечена как 'активная'; это означает, что загрузка компьютера осуществляется с этого раздела. Гибкие диски не имеют MBR, поскольку у них нет таблицы разделов. Вместо этого, у них есть просто загрузочный сектор ( как у логического диска), содержащий таблицу описания носителя (Media Descriptor Table или MDT) и загрузчик операционной системы. MDT описывает формат гибкого или логического диска. MS-Windows NT 32-битовая операционная система от Microsoft(C)(R)(TM). MTU Максимальная единица передачи (Maximum Transfer Unit). Максимальный размер IP пакета, который принимается для передачи и не разбивается на датаграммы меньших размеров. NetBEUI Текущая реализация протокола NetBIOS, используемая в MS-DOS, MS-Windows и OS/2. NetBIOS по TCP/IP Уровень кода, реализующий API NetBIOSа, но применяющий датаграммы TCP и UDP, которые, в свою очередь, инкапсулированы в IP датаграммы. Поскольку IP является маршрутизируемым, это позволяет преодолеть самое существенное ограничение NetBIOS. См RFC's 1001, 1002, 1088. NetBIOS Облегченный транспортный протокол, разработанный Sytek, IBM и Microsoft для использования на персональных компьютерах. NFS NIS Сетевая файловая система (Network File System). Протокол, разработанный Sun Microsystems, позволяющий Unix машине присоединять область удаленного диска как часть локальной файловой системы; широко распространена, но сомнительной безопасности. Сетевая информационная система (Network Information System). Протоколы, обеспечивающие сетевые сервисы (такие как аутентификация) для NFS. offline Не подключенный к компьютерной системе или сети; ср. online. online Подключенный к компьютерной системе или сети; ср. Offline. OSI PAP PCI PID PIO PLIP PnP POP Взаимодействие открытых систем (Open Systems Interconnection). Концепция "связки" протоколов (поскольку "TCP/IP stack", как и "This damn Microsoft TCP/IP stack is so broken...") происходит из семиуровневой модели OSI, хотя и в TCP/IP имеется примерно четыре различных уровней (некоторые уровни объединены). См. физический, канальный, сетевой, транспортный, сеансовый, представительский и прикладной уровни (модель OSI); уровень сетевого доступа, сетевой уровень, транспортный и прикладной уровни, (набор TCP/IP). Протокол аутентификации по паролю (Password Authentication Protocol). Интерфейс периферийных компонент (Peripheral Components Interface). Шина ПК, для связи карт с процессором, заменившая первоначальную шину ISA. ID процесса (Process ID). Числовая переменная, используемая ядром для отслеживания процессов. Программируемый ввод/вывод (Programmed I/O). Технология, при помощи которой CPU выполняет нагруженный кодом цикл, в котором он копирует данные из буферной памяти периферийного устройства и записывает их в основную память; использовался в ранних версиях ATA, но был заменен DMA. IP по параллельной линии (Parallel Line IP). Протокол IP для параллельного кабеля (между двумя машинами, соединенными физически и не сильно отдаленными друг от друга). “Включай и работай” (Plug and Play). Почтовый протокол (Post Office Protocol). Протокол для извлечения почты с почтового сервера. См. RFC1939 (POP3). Различные серверные приложения имеют обычно имена, производные от 'pop': ipop3d, ipop2d, и popper. Postscript Язык описания страницы, разработанный и распространяемый Adobe Inc. Широко используется в лазерных принтерах, особенно в случаях, когда требуется высокое разрешение (например, при фотопечати). В Linux, различные приложения зачастую эмулируют его и для не-Postcript принтеров. PPID PPP RARP ID родительского процесса (Parent Process ID). Протокол двухточечного соединения (Point-to-Point Protocol). Протокол физического уровня (RFC1661), который может быть использован для инкапсуляции IP и других сетевых протоколов, обеспечивая отличное расширение протоколов LAN для пользователей коммутируемого доступа. Протокол определения сетевого адреса по местоположению узла (Reverse Address Resolution Protocol), rarp. Низкоуровневый протокол, который, по адресу оборудования (Ethernet MAC) в локальной сети возвращает соответствующий IP адрес, ср. ARP. README Важный документ, обычно поставляемый с пакетом программ, где уделяется внимание важным вопросам; Имя файла, как правило, пишется заглавными буквами, так что он оказывается вверху содержимого каталога. Red Hat Коммерческий дистрибутив Linux. RFC root RPC RPM SCSI Запросы на комментарии (Request For Comments). Официальная спецификация протоколов и стандартов Интернета. Учетная запись администратора (UID 0) на системах *nix, который имеет все привилегии; ср. Суперпользователь, а также самый верхний, первый, основной уровень (например: корневой каталог, "/"). Удаленный вызов процедуры (Remote Procedure Call). Управление пакетами Red Hat (Red Hat Package Management). Система, облегчающая установку, проверку, обновление и удаление пакетов Linux. За более подробной информацией обратитесь к HOWTO. Интерфейс малых компьютерных систем, произносится “скази” (Small Computer Systems Interface). Многоточечная архитектура шины, особенно удобная при одновременном внешнем и внутреннем подключении запоминающих устройств, таких как жесткие диски, ленточные накопители и приводы компакт-дисков. SGID Set Group ID, sgid. SLIP SMB SMTP SNR SUID SuSE TCP Межсетевой протокол для последовательного канала (Serial Line Internet Protocol). Способ инкапсуляции IP датаграммы для передачи по асинхронным модемным соединением. Смотри RFC1055, "A Non-Standard for Transmission of IP Datagrams over Serial Lines"; ср. PPP. Блок серверных сообщений (Server Message Block). Протокол, разработанный Microsoft, предназначенный для передачи вызовов API (первоначально MS-DOS, затем OS/2 и MS-Windows) и их аргументов по локальной сети NetBIOS; под Linux первоначально использовался как протокол для совместного использования файлов и принтеров с Windows машинами. Простой протокол электронной почты (Simple Mail Transfer Protocol). Общепринятый протокол, используемый почтовыми серверами для доставки электронной почты по Интернету. См. RFC821. Отношение сигнал/помеха (signal-to-noise ratio). Относительное количество полезной информации в сигнале, по сравнению с шумом, содержащимся в нем. Set User ID, suid. Для файлов Unix-совместимой файловой системы – разрешающий бит, делающий возможным порожденному процессу (то есть, полагая файл исполняемым) иметь те же права доступа к другим ресурсам, что у пользователя, создавшего файл, а не пользователя, создавшего процесс. Коммерческий дистрибутив Линукс. Протокол управления передачей (Transmission Control Protocol). Потоковый транспортный протокол, ориентированный на сеанс, обеспечивающий упорядочение, обнаружение и устранение ошибок, управление потоками, контроль перегрузки и мультиплексирование; ср. UDP. См. RFC793. TCP/IP Transmission Control Protocol / Internet Protocol. Комплект протоколов для передачи данных по сети Интернет. TIPS Test Item Processing System. Набор Python-скриптов, обеспечивающих web-интерфейс для управления тестами LPI. Смотри http://www.lpi.org/cgi-bin/tips.py. TFTP UDP UID UN*X URL USB Тривиальный FTP. Протокол, подобный FTP, но более простой и менее безопасный; используется главным образом для взламывания компьютеров и загрузки бездисковых сетевых клиентов. Смотри RFC1350. Протокол пользовательских датаграмм (User Datagram Protocol). Не ориентированный на соединение, не гарантирующий доставку транспортный протокол, обеспечивающий многократность и обнаружение ошибок в приложениях, требующих малотребовательный протокол для одноразовых транзакций; ср. датаграмма, пакет, TCP. См. RFC768. ID пользователя (User ID). Термин для обозначения любого варианта операционной системы UNIX(R)(TM), включая Linux и большое число других свободных и коммерческих систем; также *NIX. Универсальный локатор ресурса (Universal Resource Locator). Идентификатор для адреса в Интернете, которому предшествует имя протокола, используемого для достижения этого адреса (например: ftp://ftp.kernel.org/ ). Универсальная последовательная шина (Universal Serial Bus). Недавно разработанный стандарт шины для последовательного подключения периферийных устройств. user mask umask UTC UTP WAN Официальное мировое время. Неэкранированная витая пара (Unshielded Twisted Pair). Разновидность сетевого кабеля, содержащего несколько параллельных проводов, используемого для Ethernet. Сеть, как правило, имеет топологию звезды, содержит концентраторы и не требует терминаторов. Глобальная сеть (Wide Area Network). Сеть, связывающая географически разделенные объекты (и зачастую локальные сети в них), используя сетевые соединения типа “точка-точка” (выделенная линия, SLIP, PPP) или пакетную коммутацию (X.25, frame relay) и не поддерживающая такие свойств локальных сетей, как широковещательная передача и прямое соединение. Win-модем Модем, имеющий только цифровой обработчик сигналов ( Digital Signal Processor) и использующий приложения для MS-Windows на CPU компьютера для кодирования и декодирования данных. WINS WWW X XML Служба имен Интернет для Windows (Windows Internet Name Service). Автоматическая база данных имен NetBIOS для разрешения имен NetBIOS в адреса IP. Всемирная паутина (World Wide Web, web). Повсеместно распространяемый архив HTML документов, связанных посредством HTTP. X-Window. Система X Window : графический пользовательский интерфейс, разработанный в MIT и имеющий несколько разновидностей. Язык расширяемой разметки (eXtensible Markup Language). агент передачи сообщений Программа, маршрутизирующая электронную почту, основанную на заголовке RFC822 и вызывающая необходимого агента доставки, главным образом SMTP (RFC821) для маршрутизации почты к произвольному назначению. Например : exim, qmail, sendmail, smail. Смотри также RFC1711 и пользовательский почтовый посредник. адрес Область памяти или уникальный идентификатор, присвоенный интерфейсу какого-нибудь сетевого устройства, например, интерфейсу сетевого адаптера. активный Контекст, в котором процесс получает доступ к терминалу для вывода данных, то есть выполняется не в фоновом режиме. алгоритм Формальное описание процедуры, которая, будучи снабженной подходящими входными данными, выдаст результат, удовлетворяющий некоторым требованиям. аналоговый Соответствующий физическому количеству, принимающему любое значение из непрерывного диапазона. Например, таковым будет напряжение, используемое для кодирования громкости при передаче сигнала, передаваемого по стандартной медной телефонной линии. ср. Цифровой. аргумент Часть информации, передаваемой функции или команде. архив Резервные данные, хранимые в виде файла, содержащего один или более компонентов и их перечень (например, в формате tar, cpio, rpm или deb). ассемблер Программа, которая компилирует программу, написанную на языке ассемблера, в объектный код. база данных Как правило, большой набор упорядоченных и доступных данных. байт Тип данных, состоящий из 8 битов. библиотека Набор процедур (как правило, взаимосвязанных) для подключения к программе. бит Наименьшая единица информации : может принимать только одно из двух значений (0-1, вклвыкл, открыто-закрыто, и тп.). бит фиксации Sticky bit. Разрешающий бит для исполняемого файла, позволяющий ядру хранить в памяти образ процесса после его завершения, во избежание издержек новой загрузки при повторном запуске файла. блочное устройство Устройство, обменивающееся с операционной системой данными в виде блоков большого размера (например, 512 байт) за один прием. буфер Временное хранение; ср. Кэш. ввод Любые данные, вводимые в работающую программу или в файл. ветвление Когда исполняющийся процесс создает точно такой же (за исключением PID) выполняющийся дубликат самого себя; см. дочерний процесс, порождать. взламывать Получать доступ к компьютерной системе без соответствующей авторизации (например, путем угадывания пароля легального пользователя), и, быть может, мешать ее нормальной работе или целостности. взломщик Тот, что пытается совершить взлом; ср. Хакер. виртуальная консоль Виртуальный терминал, VT, VC. виртуальная память Дополнительная память, доступная системе, располагающаяся на жестком диске, и, следовательно, практически неограниченная, хотя и намного более медленная, нежели истинная ОЗУ. Часто называется подкачкой. виснуть ср. крах. владелец Учетная запись, чей номер UID связан с файлом. вызывать Приводить в исполнение. вывод Любые данные, созданные процессом. выгружать Освободить сервер от служб или приложений для высвобождения большего количества ресурсов (времени CPU, дискового пространства, и т.д.). выполнить Привести (программу) в состояние работы; ср. Запустить. гибкий диск Флоппи-диск. Магнитный носитель с гибким диском внутри; ср. жесткий диск. глобальный Переменная, раздел настройки, процедура, и тп, с неограниченной областью видимости (то есть, применимая везде, до тех пор пока не будет изменена локально). графика Картинки, рисунки; в отличие от текста. графический пользовательский интерфейс, GUI Интерактивный интерфейс, использующий графический дисплей. N.B. Используйте этот термин, только если он действительно графический (например, как X). Не используйте его для интерактивных программ на текстовых терминалах (на основе ncurses или slang). Для обозначения и тех, и других используйте "интерактивный интерфейс". Ср. Интерфейс командной строки. группа Относится к списку из одного или большего количества пользователей, обладающими одинаковыми правами доступа; см. /etc/groups. грязный Не чистый. дамп памяти Содержимое памяти, записанное в файл на диске (часто называемый "core") при крахе программы. данные "То, что дано", например, для ввода в компьютер; ср. Информация. датаграмма Пакет, используемый, главным образом, в UDP (Примечание: не только в IP – другие протоколы тоже используют термин “датаграмма” в собственной документации). двоичный файл Файл, который предназначен для чтения не человеком, а приложениями или операционной системой. деинсталлировать Удалить оборудование или приложения из компьютерной системы. демон Программа, которая выполняется в фоновом режиме и обеспечивает системные службы. диалап Соединение, совершаемое по коммутируемой телефонной сети общего пользования (Public Switched Telephone Network PSTN), в отличие от постоянного соединения по выделенной линии. диск Вращающийся магнитный носитель, который поддерживает прямой доступ и произвольную выборку; ср. гибкий диск, жесткий диск. дистрибутив Полная (как правило) совокупность программного обеспечения, необходимого для пользования компьютером, содержащая ядро Linux, разнообразные утилиты и приложения. домен Одна или более компьютерных сетей, служащих организационной группой. Имя присваивается сетевому домену. дочерний процесс Любой процесс, созданный другим, так называемым родительским процессом; как правило, используется с указанием родительского процесса. жесткая ссылка В файловых системах Unix-элемент каталога, указывающий на файл в другом каталоге того же диска или раздела и имеющий ту же узловую точку; ср. символическая ссылка. жесткий диск Устройство, использующее твердые диски в качестве магнитного носителя для хранения данных, ср. гибкий диск. журнал Запись действий. завершить Разорвать, закончить, выйти, остановить, и тп. зависимость Состояние, когда для работы программы требуются другие библиотеки|программы|пакеты. загрузить Передать с диска в память. загрузить (ОС) Привести операционную систему в состояние исполнения. загрузчик Программа, обычно устанавливаемая в MBR на машинах Intel, которая загружает ядро операционной системы и запускает его. задание Задача, посылаемая в фоновый режим или отложенная для более позднего выполнения. запустить Позволить (программе) работать; ср. Выполнить. излишний Ненужный; говорится об информации в контексте сжатия, или представления целостности данных. интегрированная среда разработки IDE (Integrated Development Environment). Интегрированная среда разработки. интерактивный Имеющий свойство взаимодействовать, то есть отвечать на действия извне. Используется в контексте программ или интерфейсов. интерактивный интерфейс Взаимодействие между компьютером и пользователем, позволяющее им влиять друг на друга и обмениваться вводом и выводом (команд и данных). Интернет Компьютерная сеть на основе протокола IP, распространенная по всему миру. интерпретатор Программа, проверяющая скрипт или исходный код программы и исполняющая его, строка за строкой. интерфейс Соединение (посредством устройства или программы) между различными компонентами компьютерной системы (как правило, производящее преобразования между внутренними протоколами компонентов); используется главным образом в контексте соединения по сети, или связи между компьютерными системами и пользователями. интерфейс командной строки Интерактивный пользовательский интерфейс, позволяющий компьютерной программе или оболочке получать команды через текстовый терминал (или эмулятор терминала в окне внутри графического пользовательского интерфейса). интранет Сеть (обычно локальная сеть) основанная на IP, но, в отличие от Интернета, разрешающая только ограниченный доступ. информация Что-нибудь, стоящее познания, в отличие от просто данных. испорченный Поврежденный (о файле или содержимом диска). исполняемый Двоичный файл или скрипт, который может быть запущен как программа (может потребовать разрешения на исполнение). исходники Файлы, содержащие исходный код программы или системы программ, из которых можно скомпоновать исполняемую программу или библиотеку, а также перенести ее на другую компьютерную платформу. исходный код Текст (набранный, как правило, человеком), детально определяющий действия программы, написанный на языке программирования. Для получения исполняемой компьютерной программы его следует обработать компилятором. кадр канал Пакет, собранный и переданный физическом уровне сети (например, Ethernet, Token Ring, и тп). Структура данных, соединяющая файл, присоединенный к одному процессу с файлом, с присоединенным к другому; по соглашению, стандартный поток вывода одного процесса к стандартному потоку ввода следующего. В командной строке принято обозначать символом '|' . карта Любое устройство, которое можно подключить в компьютерное гнездо расширения. каталог Специальный тип файлов, содержащий информацию о других файлах, например имя файла, месторасположение, разрешения, размер, и тд. концентратор Вообще говоря, устройство, соединенное с несколькими другими устройствами; применительно к компьютерным сетям, повторитель в основе сети с топологией звезды, как правило, с 10BaseT или 100BaseT Ethernet. клавиатура Устройство ввода с большим количеством кнопок, помеченных буквами и другими символами. клиент Компьютер или процесс, который соединяется и получает сервис от серверного компьютера или процесса. ключ Маркер, используемый для шифрования текста или дешифрования кодированного текста в системах шифрование. коаксиал Коаксиальный (со-осный) кабель. Кабель с внутренней и внешней обмотками, используемый в ТВ кабелях и локальных сетях Ethernet, где компьютеры обычно имеют T-узлы для соединения в единую цепь кабелей, которую необходимо ограничивать резисторами-терминаторами. компилятор Программа, проверяющая исходный программный код и транслирующая его в эквивалентный объектный файл; ср. Интерпретатор. компоновать Связать программу с процедурами, на которые она ссылается (вызывает). Эти процедуры обычно располагаются в объектных модулях или библиотеках. компьютер Цифровой электронный многоцелевой программируемый автомат, обрабатывающий информацию. консоль Первичный непосредственный пользовательский интерфейс компьютера. Некоторые функции системного администрирования могут быть произведены только в консоли. крах кэш Неожиданное завершение нормального выполнения. Предполагается, что жесткие диски испытывают иногда поломки, когда головки чтения/записи разрушают носитель, возможно, приводя носитель в негодность; таким образом, крах – непреднамеренное прекращение работы программы или устройства из-за какой-нибудь неисправности или ошибки, в особенности при завершении пагубным или неприятным образом. Любая легко доступная область хранения, используемая для содержания данных для быстрого доступа, при необходимости иметь частый доступ к ним; цель этого – ускорить доступ к данным и улучшить производительность системы. кэширующий DNS Сервер доменных имен, который не содержит собственных доменных файлов. Линукс (Linux) Unix-подобная операционная система, названная по имени Линуса Торвальдса (Linus Torvalds), впервые разработавшего и до сих пор поддерживающего ее. Свободно доступна по GPL. Если Вам это еще не известно, то вы вообще здесь делаете? логический На жаргоне инженеров-электронщиков : электронная компоненты и схемы устройства. Этого термина лучше избегать, дабы не путать его с общепринятым значением, встречающимся в программировании : абстрактное формальное умозаключение. локальный Легко достижимый, находящийся в локальной сети, не удаленный. маска сети Сетевая часть IP адреса; ср. маска подсети переменной длины. маска подсети переменной длины маскарадинг Притворяться другим узлом с целью совместного использования одного IP-адреса несколькими локальными узлами, спрятанными от внешнего мира в силу нехватки ресурсов или по соображениям безопасности, ср. NAT. маршрут Путь от одного узла к другому через одну или более сетей. При проверке IP-адреса назначения, датаграмма направляется к следующему маршрутизатору по пути назначения или же непосредственно к цели. маршрутизатор Шлюз, передающий IP-датаграммы между сетями. Функционирует на третьем (сетевом) уровне модели ISO/OSI, и полагает, что наличие адреса влечет наличие определенного пути (маршрута) для достижения назначения. В настоящее время принимается, что в качестве шлюза выступает компьютер общего назначения с операционной системой общего назначения [например, Linux], которая может выполнять и другие операции; в то время как маршрутизатор – специализированный компьютер со специальной операционной системой [например IOS], как правило, от поставщика [например Cisco]). ср. Мост. межсетевой экран Шлюз, ограничивающий передачу данных между "внутренней" сетью и Интернетом ("внешним" по отношению к экрану). мини-HOWTO Более скудный и более сосредоточенный документ, нежели HOWTO. модем Устройство, совершающее преобразование цифровых сигналов компьютера в аналоговые сигналы для связи по телефонной линии. мост Устройство, распространяющее пакеты между двумя компьютерными сетями; функционирует на втором уровне (канальный уровень) в модели ISO/OSI, и осуществляет широковещательную рассылку пакетов на основе адреса. Маршрутизация при этом не проводится. Ср. повторитель, маршрутизатор. мышь Устройство ввода, позволяющее указывать, выделять и активировать объекты, отображаемые, как правило, в графическом пользовательском интерфейсе. налаживать Делать небольшие изменения в конфигурации для того, чтобы получить большую производительность. ненадежный В контексте TCP/IP: протокол, не совершающий исправления ошибок (полагающий, что ошибки, возникающие, как правило, вследствие повторных передач, обнаружены и исправлены верхними уровнями модели OSI). низкоуровневый О языке программирования, в котором операторы похожи на инструкции процессора (или же: в котором операторы более сходны с объектным кодом, нежели в языке высокого уровня). носитель Физическое устройство, через которое передаются данные или (главным образом) где они хранятся. оболочка Программа, служащая посредником между пользователем и операционной системой, как правило, принимающая команды и вызывающая соответствующие программы. В мире UNIX, термин “оболочка” обычно относится к интерфейсам командной строки с возможностью запускать сценарии, таким как bash, csh и zsh. Однако, существуют и графические оболочки, например Windowmaker, KDE и GNOME. обновить Поменять оборудование или приложения в лучшую сторону. объектный код Инструкции, которые может выполнять процессор компьютера. однопользовательский режим Режим с уровнем запуска 1. ОЗУ окно Оперативное запоминающее устройство, Random Access Memory, RAM. Легко, быстро изменяемая память, используемая компьютером как основная. Имеет такие разновидности как EDO, ECC, SDRAM, и т.п., которые не эквивалентны, но, с точки зрения системного администратора, очень похожи при обычном использовании. Ср. ПЗУ. Область графического рабочего стола, интерфейс пользователя для взаимодействия с дочерним процессом рабочего стола. окружение Совокупность переменных, связанных с процессом, предназначенных для определения привилегий пользователя и конфигурации системы; дочерний процесс наследует эти переменные. операционная система ОС. Основной набор программ, управляющих различными компонентами и устройствами компьютера, а также их взаимодействием с приложениями и пользователями; например. MS-DOS, MS-Windows NT, MacOS, Unix, Linux. очередь Структура данных, реализующая список по принципу “первый вошел-первый вышел” (first-in, first-out); например очередь печати, которая содержит список заданий, которые следует выполнить по порядку. пакет Квант данных, передаваемых по сети; а именно : единица трафика TCP, несущая необходимую информацию по доставке самой себя, особенно для протокола UDP (датаграмма). пакет программ Совокупность связанных файлов и программ; часто также файл архива (tar, rpm), их содержащий. память Место, где компьютер хранит данные и|или программы для прямого доступа CPU : ОЗУ или ПЗУ (а также кэш-память), не диски. панель управления Набор кнопок, переключателей, индикаторов или изображений, используемый для настройки и управления маршрутизатором, принтером, компьютером или другим устройством. параллельный Несколько битов за один акт передачи (по нескольким проводам). параметр Переменная, чье значение имеет смысл для функции, принадлежащей команде или функции программы; ср. аргумент. пароль Фраза, которая идентифицирует пользователя во время входа в систему. ПЗУ Постоянное запоминающее устройство, Read Only Memory, ROM. Память компьютера, относящаяся, как правило, к некоторому долгосрочному носителю, например, кремниевой микросхеме или оптическому диску, которая может быть считана, но не изменена; это доставляет неудобства, когда данные следует изменить. Может сбить с толку то, что на некоторые ПЗУ все же можно записывать при определенных условиях, ср. ОЗУ. переменные окружения Переменные, определяющие окружение. периферийное Устройство, являющееся необязательной принадлежностью основных компонентов компьютера (CPU и память). пиксель Элемент изображения (picture element) : точка, точка сетки экрана дисплея, наименьшая единица, которую можно отобразить на экране дисплея. ПК Персональный компьютер. плавающая точка Используется для представления чисел, которые могут быть дробными; ср. Целое. по умолчанию То значение параметра, которое использует программа, если оно не задано явно. порт Имя, данное индивидуальному, пронумерованному "слоту", который доступен сетевым приложениям. Например, HTTP-серверы, как правило, используют портом 80. См. /etc/services ; также см. порт ввода/вывода. порт ввода/вывода Адрес, используемый периферийными устройствами для связи с CPU; см /proc/ioports. поток Последовательность байтов данных с контролем упорядоченности и переполнения. Потоковым протоколом в сетях TCP/IP является TCP. пользователь Человек, использующий ресурсы компьютера, а также его учетная запись или процесс; данные о идентификации, перечисленные в /etc/passwd. подкачка Виртуальная память; названа “подкачкой” из-за процессов обмена страницами между быстрой ОЗУ и и медленной виртуальной памятью при смене их приоритетов. повторитель Устройство, распространяющее сигналы между кабелями; в компьютерных сетях оно функционирует на первом, физическом уровне модели ISO/OSI, и не выполняет ни фильтрации пакетов, ни маршрутизации, ср. концентратор, мост, маршрутизатор. пользовательский почтовый посредник Пользовательская программа, используемая для доступа, обработки, чтения, архивирования, написания и отправки сообщений электронной почты. См. RFC1711. Такие почтовые программы часто включают некоторые возможности "агента передачи сообщений", в частности, использование SMTP для отправки электронной почты на почтовый сервер-назначение, а также протоколы POP3 или IMAP4 для загрузки почты с почтового сервера входящей почты, ср. Агент передачи сообщений. порождать Создавать дочерний процесс с помощью fork() и exec(). представительский уровень Шестой уровень в семиуровневой модели ISO/ OSI , определяющий представление символов (например ASCII) и графические форматы, такие как NAPLPS (North American Presentation Layer Protocols). В TCP/IP, уровень представления включен в уровень приложения, возможно, ближайшими эквивалентными форматами являются ASN.1, ANSI и HTML/XML. привод Любое устройство, где могут храниться и считываться данные, записанные на съемном или встроенном в устройство носителе. приглашение Сигнал, производимый оболочкой или приложением и указывающий, что они готовы к дальнейшему вводу команд или данных. прикладной уровень Название самого верхнего уровня как в семиуровневой ISO/OSI модели, так и в четырехуровневой связке протоколов TCP/IP. Включает в себя такие протоколы, как telnet, FTP, HTTP, SMTP, и т.п. приложение Программа, которая выполняется на самом верхнем уровне операционной системы. поставщик услуг Интернета (ISP) Компания, обеспечивающая подключение к Интернету. программа Последовательность инструкций для компьютера, реализующая алгоритм, зачастую хранимая в файле в форме либо непосредственно исполняемого объектного кода, либо исходного кода для интерпретатора или компилятора. При загрузке в память и выполнении программа-объектный код обычно становится процессом. программное обеспечение Компьютерные программы. прокси сервер Процесс, как правило, часть шлюзового окна, который связывает протоколы между компьютерными системами клиента и сервера. Прокси-сервер (англ. “proxy”-посредник) выступает в роли сервера для клиента и в роли клиента для сервера (переложение RFC2828). протокол Определение структур данных и форматов для передачи между двумя программами по сети. процесс Выполняющаяся программа; экземпляр выполняющейся программы. процессор Главное устройство, позволяющее компьютеру работать; в настоящее время часто называется "микропроцессор" и располагается на отдельной кремниевой микросхеме (ср. CPU). простаивающий Неактивный; ждущий задания или пробуждения. псевдоним Внутри оболочки: слово-подстановка для командной строки или дополнительный IP-адрес на интерфейсе. рабочая станция Компьютер, как правило, с графическим дисплеем, для индивидуального интерактивного использования; ср. Сервер. рабочее пространство Компьютерные ресурсы, приписанные к пользователю компьютера. рабочий стол В X – экран, из которого запускаются и выполняются все программы. раздел Произвольная область запоминающего устройства ( практически всегда жесткого диска), созданная программой разбиения до записи данных. Специально для IBM PC совместимых : одна из нескольких различных областей жесткого диска (количеством не более четырех), которые можно отвести под различные операционные системы. разрешение на выполнение Разрешение, устанавливаемое на файле файловой системы Unix и указывающее, что его можно запускать как программу в операционной системе. реализовать Создать реальный объект (программу, устройство), который соответствует абстрактным требованиям. регулярное выражение Формальное выражение шаблона строки, которую можно искать и обрабатывать программами, поддерживающими обработку шаблонов, такими как vi, grep, awk или perl. резервная копия Копия важных данных, хранимая на системном или внесистемном запоминающем устройстве для страховки от сбоев системного оборудования, программного обеспечения или пользователя. родительский процесс Процесс, который запустил один или более других процессов, называемых дочерними. руководство Документ, часто в книжном объеме, в котором описывается дизайн или работа пакета приложения или устройства. сборка Запуск последовательности шагов компиляции и компоновки для получения новой версии исполняемой программы. свободный Ничего не стоящий, бесплатный. сеансовый уровень Пятый ISO/OSI уровень – уровень сеанса. Устанавливает и контролирует системнозависимые аспекты сеансов связи между определенными узлами сети. Ликвидирует разрыв между службами, поставляемыми транспортным уровнем и логическими функциями, выполняющимися в операционной системе на узле, участвующем в сеансе связи. В наборе сетевых протоколов TCP/IP уровень сеанса отсутствует, и его функции частично реализованы в транспортном уровне, и частично – в уровне приложений. сервер доменных имен DNS, сервер имен. сегмент Кусок кабеля конечной длины – сегменты могут быть соединены повторителями (реже), мостами (чаще), маршрутизаторами или переключателями ( аппаратными логическими мостами и маршрутизаторами). серийный Последовательный, один бит за другим (по одному проводу). сервер Процесс или компьютер, обеспечивающий клиентские процессы определенными службами; например, web-сервер, сервер печати. сетевой уровень Сетевой уровень в наборе протоколов TCP/IP: для того, чтобы отличать его от самого низкого сетевого (физического) уровня, также используется термин “уровень internet”. Ср. Протокол Интернета. сетевой уровень Уровень в наборе сетевых протоколов, обрабатывающий адресацию и доставку датаграмм в сети или в Интернете. Уровень номер три в семиуровневой модели ISO/OSI. сеть Взаимосвязанная совокупность узлов и других сетевых устройств, имеющих общий физический уровень, например, Ethernet, X.25, и тп.; ср. LAN, WAN. сжатие Удаление излишней информации из файла или потока для уменьшения его размера, при этом сокращается место, требуемое для хранения и время, необходимое для пересылки. Сжатие с потерями не сохраняет информацию, которая считается излишней, и хорошо работает для графических или звуковых данных. сигнал Логическое прерывание процесса, которое процесс должен сразу же обработать. Одна из форм организации межпроцессного взаимодействия. символ Буква или знак, представимый, как правило, одним байтом в коде ASCII. символическая ссылка В файловых системах Unix: элемент каталога, указывающий на другой файл в файловой системе; ср. жесткая ссылка. символьное устройство Устройство, обменивающееся данными с операционной системой по одному символу (или байту, или даже слову) за один акт. синхронизировать Делать содержимое и состояние данных, хранящихся в двух различных источниках, идентичным (например, кэш, FTP сайты). синтаксис Формальные правила, определяющие, в каком порядке ключевые слова или команды, а также их составляющие, должны следовать при написании исходных кодов программ или при формировании команд оболочки. системный администратор Системный администратор: человек, который администрирует компьютерную систему и следит за ее работой. скрипт (сценарий) Компьютерная программа, написанная на интерпретируемом языке программирования, и, следовательно, пригодная для чтения человеком, ср. исполняемый, двоичный. служба Процесс, принимающий запросы и возвращающий ответы в бесконечном цикле; демон. сокет Соединение на TCP-уровне приложения. стандартный поток ошибок Стандартное устройство вывода ошибок в Unix (по умолчанию – экран терминала). стандартный поток ввода Стандартное устройство ввода в Unix (по умолчанию – клавиатура терминала). стандартный поток вывода Стандартное устройство вывода в Unix (по умолчанию – экран терминала). страница руководства Стандартная страница руководства по Unix ( в компьютерной системе обычно доступна в формате nroff, вызывается командой `man`). суперпользователь Супер пользователь, su, туз. Пользователь, имеющий учетную запись root и имеющий полный контроль над системой текст Набор символов, которые можно отобразить на дисплее терминала или напечатать на принтере для чтения человеком. текущий рабочий каталог cwd терминал Выход компьютера, обычно включающий дисплей для вывода текста (и, возможно, графики),клавиатуру (а, возможно, и мышь) для ввода, используемый как устройство организации для взаимодействия компьютера и пользователя. Ср. Рабочая станция. терминатор Нагрузка сопротивления, указывающая на конец в цепи устройств, как правило, SCSI-цепи или цепи коаксиальной сети. топология В компьютерных сетях: схематическое расположение соединений между узлами. транспортный уровень Транспортный уровень – центральный (четвертый) в семиуровневой модели ISO/OSI. Он обеспечивает сквозной контроль сеанса связи по мере того, как установлен путь, позволяя процессам обмениваться данными гарантированно и последовательно, независимо от того, какие системы участвуют в обмене и где они расположены. удалить Уничтожить или стереть файл|символ|каталог. узловая точка В файловых системах Unix, блок данных для файла на дисковом разделе, использующихся в администрировании. умереть Прекратить выполнение, главным образом окончательно. уровень запуска (уровень выполнения) Режим работы системы Unix, предлагающий запуск определенного набора служб; см. /etc/inittab. уровень канала Уровень номер два в семиуровневой модели ISO/OSI. Отвечает за установление безошибочных путей связи между узлами сети на физическом уровне, также формирует сообщения для передачи, проверяет целостность полученных сообщений, управляет доступом и использованием носителей и гарантирует правильную последовательность передаваемых данных. Эти функции, как правило, обеспечиваются драйвером сетевой карты. Серия 802.x стандартов IEEE разделяет этот уровень на два : уровень LLC и подчиненный уровень MAC. уровень сетевого доступа Самый низкий уровень в наборе протоколов TCP/IP, также известный как "физический" или "аппаратный" уровень. установить Перенести новую программу в компьютер на постоянное хранение (например, на жесткий диск) и произвести необходимую настройку и администрирование. устранение неполадок Процесс обнаружения причин(ы) проблем(ы) в сети|программе|устройстве. устройство "Периферийная" часть оборудования, которая является необязательной или может быть присоединена к компьютеру (даже если изначально она расположена внутри корпуса) : интерфейсные карты, приводы, принтеры, и т.п. утилита Программа, облегчающая выполнение работы. файл Последовательность (поток) байтов в известном расположении в области хранения. файл include Файл, содержащий постоянные и параметры, быть может, используемый двумя и более программами, включаемый в исходный код при компиляции данных программ. файловая система Структура данных, размещенная на логическом диске или разделе (с помощью mkfs), позволяющая операционной системе записывать информацию о хранимых файлах. физический уровень Самый низкий уровень семиуровневого набора сетевых протоколов ISO/OSI. фильтровать Отбрасывать ненужные данные. флоппи-дисковод Устройство, которое может считывать и записывать информацию на гибкие диски. фоновый Состояние исполнения процесса, когда не происходит вывода на терминал. формат Спецификация, касающаяся способа хранения данных. хакать Достигать результата нетривиальным способом. хакер Тот, кто хакает : так называют людей с неординарными компьютерными способностями; ср. взломщик. хост(узел) Любой компьютер, подсоединенный к сети на основе IP, в особенности компьютер, который может служить в качестве сервера для клиентских программ или других компьютеров. чистый Чистый привод – тот, что был правильно отмонтирован и, таким образом (теоретически) не нуждается в проверке; иначе привод называется “грязным”. цилиндр Набор дорожек, расположенных на одном радиусе на различных поверхностях жесткого диска. Жесткий диск с четырьмя пластинами внутри имеет восемь поверхностей, так что при каждом положении головок чтения/записи, восемь дорожек могут быть считаны без их перемещения. Эти восемь дорожек и формируют цилиндр. цифровой Относится к объекту, который может принимать только ограниченное количество дискретных, а не произвольных значений; например, двоичный. ср. Аналоговый. целое Тип данных, используемый для представления целых (недробных) чисел внутри ограниченного диапазона. целостность Правильность. цветовая таблица Цветовая карта (color map или color-map). Таблица, используемая для кодирования палитры цветов в изображениях. шаблон Символ-заполнитель, используемый для указания некоторого символа или группы символов. шина Провод (кабель) для передачи сигналов между различными компонентами одного компьютера. широковещание Кадр или датаграмма, предназначенная всем интерфейсам сети. шлюз Устройство или механизм передачи, связывающий две или более компьютерных сети, и передающий пакеты между сетями в Интернете. В настоящее время принято считать, что в качестве шлюза выступает компьютер общего типа с операционной системой общего типа [например, Linux], которая может выполнять и другие операции, и в этом качестве он функционирует на третьем (сетевом) уровне, в модели ISO/OSI; в то время как маршрутизатор – специализированный компьютер со специальной операционной системой [например IOS], как правило, от поставщика [например Cisco]). ср. Мост. шрифт Форма каждой из букв в наборе символов. экранный дисплей Устройство, показывающее текст, графику или другую информацию для восприятия человеком. эмулировать Имитировать действия устройства или программы так, чтобы эта имитация выполняла те же самые функции, что и оригинал. эмулятор Программа, эмулирующая функции некоторых устройств или других программ. эргономичный Удобный для использования людьми. ядро Основа операционной системы, обеспечивающее многозадачность (создание процессов, защищенность процессов, связь между процессами), управление памятью, и базовое управление вводом-выводом. язык ассемблера Низкоуровневый язык программирования, который может быть непосредственно транслирован в объектный код процессора. Глоссарий bash: 227 BIOS: 214 CERT: 214p. comments: 2 DHCP: 215 DNS: 215, 226, 231 FHS: 216 FTP: 216, 221, 229, 231 GID: 216, 220 grep: 230 HOWTO: 216, 220, 227 IDE: 214p., 217, 224 LDP: 217 lilo: 217 lp: 208p. LPI: 208p., 215, 218, 221 man: 2, 232 mkfs: 233 NFS: 218 PAP Password Authentication Protocol: 219 RPM: 220, 222, 228 sendmail: 222 SUID: 220 tar: 228 TCP: 218pp., 227pp., 231pp. TCP/IP: 218pp., 227, 229, 231, 233 UDP: 218, 220p., 223, 228 UID: 220p., 223 umask: 221 WINS: 221 /etc/group: 223 /etc/passwd: 229 /etc/services: 229 /proc: 229 библиотеки: 224 комментарии: 220 раздел подкачки (swap): 223 символическая ссылка: 224 скрипт: 220 стандартный поток ввода: 225 стандартный поток вывода: 225 устройства: 233