КОНТРОЛЬНА РОБОТА № 3
Розсилання пошти в мережЕВій операційній системі FreeBSD
Мета роботи
Одержати практичні навички у розсиланні пошти з використанням протоколу UUCP та команди MAIL у мережевій операційній системі FreeBSD4.2
Теоретичні положення
Протокол UUCP (Unix to Unix copy) призначений для копіювання файлів між декількома машинами в мережі, для виконання команд на віддаленій машині. Цей протокол також можна використати для розсилання пошти. Нехай одна з машин є вузлом, яка обмінюється поштою з користувачами поза організацією, де вона знаходиться через головну обчислювальну машину з адресою MAIL.PROVIDER.KIEV.UA, а також виконує розсилання пошти ще трьом машинам всередині організації, де вона знаходиться. Нехай імена цих машин будуть host1.your.domain.org, host2.your.domain.org і host3.your.domain.org.
Нехай для простоти ім'я нашої машини буде MYHOST.YOUR.DOMAIN.ORG
Кожній машині для проведення операції розсилання пошти необхідно присвоїти її власне UUCP - ім’я. Воно не повинно співпадати з її справжнім іменем, але не зважаючи на це, будемо вважати, що UUCP - імена наших машин - це MYHOST, HOST1, HOST2, HOST3 і PROVIDER
Обмін поштою відбувається повністю через протокол UUCP, причому схема проходження така:
Нехай стрілка означає напрям дзвінка. Тоді
PROVIDER |
MYHOST | HOST1 | ||
HOST2 | ||||
HOST3 |
Настройка розсилання пошти передбачає настройку самого протоколу UUCP і настройку служби SENDMAIL.
Розглянемо детально, як організований протокол UUCP, і які основні команди і daemon’и необхідні для повної його реалізації
UUCP - Unix to Unix copy
Синтаксис команди - uucp [опції] вихідний_файл кінцевий_файл
Файл може бути записаний як СИСТЕМА!ШЛЯХ, де СИСТЕМА - це UUCP – ім’я даної машини. Після того, як була дана команда, вона не виконується відразу, а записується в загальну чергу, а її виконання проводити daemon UUCICO при його звертанні до системи. Причому це звертання відбувається відразу, якщо в опціях не був вказаний ключ -r або --nouucico.
Для цієї команди можуть бути дані наступні опції
-c, --nocopy - не копіювати вихідні файли в SPOOL - директорію. Якщо файли були видалені до того, як над ними попрацював daemon UUCICO, то копіювання аварійно перерветься;
-С, --copy - ця операція відбувається за умовчання;
-d, --directories - створювати всі необхідні директорії для копіювання, якщо це необхідно;
-f, --nodirectories - не створювати ніяких директорій, вважаючи, що вони уже існують. В іншому випадку аварійно перервати копіювання;
-R - копіювати рекурсивним методом, тобто копіювати вкладені папки;
-m, --mail - повідомляти про вдале (невдале) закінчення пересилки пошти через mail;
-n user, --notify user- повідомляти про вдале (невдале) закінчення пересилки пошти через mail для конкретного користувача на віддаленій системі;
-r, --nouucico - не запускати daemon UUCICO відразу, а ставити файли в чергу для пізнішого виконання;
-j, --jobid - виводити на екран ідентифікаційний номер процесу;
-t, --uuto - використовується за умовчання для скрипта UUTO для коректної інтерпретації СИСТЕМА!ШЛЯХ;
Команда UUSTAT
Синтаксис команди - uustat [опції]
Показує поточний статус різних об'єктів, які підпадають під дії протоколу UUCP. Ця команда також може бути використана для того щоб відповісти на запит або послати негативну відповідь на запит, посланий командами UUCP або UUX.
Для повного перегляду допомоги англійською мовою в командному рядку UNIX необхідно набрати команду man uustat.
Нам буде достатньо використати команду
uustat -all - показати всю чергу запитів на передачу файлів
uustat --status - показати всі послідовності зв'язних інформаційних обмінів між усіма віддаленими машинами.
Uustat --ps - показати стан всіх процесів UUCP, які контролюють порти або доступ до системи.
UUX
Синтаксис команди - uux [опції] команди
Ця команда служить для виконання команд на віддалених машинах через UUCP використовуючи файли віддаленої машини. При виконанні автоматично запускається daemon UUCICO, якщо в командному рядку не стояло --nouucico
Виконання команди відбувається через активізацію daemon’а UUXQT. Аргументи файлів можуть бути зібрані з віддаленої системи і передані керуючій системі, як потік стандартного вводу.
При написанні шляхів в якості аргументів UUX, можна використати знання, отримані з параграфа про UUCP.
Для більш детального перегляду допомоги англійською мовою в командному рядку UNIX необхідно набрати команду man UUX.
Для повного опису конфігурації необхідно розглянути також наступний daemon і дві додаткові утиліти
Daemon UUXQT
Синтаксис daemon’а : UUXQT [опції]
Він виконує команди, що вимагаються командою UUX з локальної або віддаленої машини. Daemon UUXQT запускається daemon’ом UUCICO відразу ж по факту виконання команди UUX, якщо в рядку не був вказаний ключ --nouucico
Розглянемо основні опції
-c command - виконуються запити тільки для указаних в командному рядку команд;
-s system - виконуються запити, отримані з указаних в командному рядку названий систем.
Утиліта UUCHK
Синтаксис uuchk [-s система] [стандартні опції для UUCP]
UUCHK зчитує дані про конфігурацію протоколу UUCP, і відображає значно ширший спектр інформації, чим можна прочитати в конфігураціойному файлі. Цю утиліту корисно використовувати, коли відбувається процес конфігурації протоколу UUCP. Опція система використовується для того, щоб указати, для яких систем необхідно вивести дані про конфігурацію. Утиліта MAKEMAP служить для перетворення файлів в бази даних для настройки SENDMAIL.
Настройка протоколу UUCP
Необхідно написати конфігураційні файли для UUCP.
drwxrwx--- 3 uucp uucp 512 15 ноя 16:23 ./
drwxr-xr-x 10 root wheel 2048 30 дек 21:44 ../
-r--r----- 1 uucp uucp 61 23 янв 1997 call
-r--r----- 1 uucp uucp 260 8 апр 1997 config
-rw-r----- 1 uucp uucp 250 3 сен 20:51 dial
-r--r----- 1 uucp uucp 1 25 авг 1996 dialcode
-r--r----- 1 uucp uucp 14 21 апр 1997 passwd
-r--r----- 1 uucp uucp 96 29 май 1997 port
drwxr-xr-x 2 root uucp 512 15 ноя 12:08 samples/
-r--r----- 1 uucp uucp 160 28 май 1997 sysin
-r--r----- 1 uucp uucp 366 16 ноя 16:06 sysout
1.1 call
В цьому файлі описується ваш логін і пароль для продзвонки на інші uucp-машини. Природно, логін і пароль необхідно получити від адміністратора тої машини, на яку ви зібрались дзвонити. В нашому випадку він буде виглядати приблизно так:
======= call ======
# system login password
provider uumyhost Your_Secret_Password
======= call ======
1.2 config
В цьому файлі описуються різні параметри uucp, в основному шляхи і імена файлів. Цей файл потрібен, якщо потрібно перевизначити деякі умовчання, які або задані при компіляції.
======= config ======
nodename myhost # тут необхідно указати ваше власне uucp-ім’я
spool /var/spool/uucp
pubdir /var/spool/uucppublic
logfile /var/spool/uucp/Log
statfile /var/spool/uucp/Stats
debugfile /var/spool/uucp/Debug
sysfile sysin sysout # імена файлів з описами систем - ваших лінків
portfile port
dialfile dial
dialcodefile dialcode
callfile call
passwdfile passwd
# кількість одночасно виконуваних процесів розкладки пошти
max-uuxqts 1
======= config ======
1.3 dial
Це файл з описами модемів.
======= dial ======
dialer idc # довільне ім’я модему, під яким він буде відомий uucp
dialtone w
pause ,
#chat "" ATZ\r\d\c OK ATM0DPW\T CONNECT \p\c
chat "" ATZ\r\d\c OK ATM0DT\T CONNECT \p\c
chat-fail BUSY
chat-fail ERROR
chat-fail NO\sDIALTONE
chat-fail NO\sCARRIER
#complete \d\d+++\d\dATH\r\c
#abort \d\d+++\d\dATH\r\c
======= dial ======
1.4 dialcode
Служить для набору номера, має нульову довжину
1.5 passwd
В цьому файлі містяться логін і відповідний пароль для тих систем, які будуть дзвонити вам. При роботі з протоколом UUCP daemon uucico -l авторизує подзвонивших користувачів, пропонуючи їм при цьому ввести логін і пароль, і перевіряє правильність пароля по цьому файлу. Які логіни і паролі можна присвоїти віддаленим машинам, які дзвонять вам – справа смаку. Правильніше дати їм логіни, які починаються однаково, наприклад, з двох букв uu.
======= passwd ======
uuhost1 Top_Secret_Password
uuhost2 Smart_Password
uuhost3 Stupid_Password
======= passwd ======
1.6 port
В цьому файлі міститься опис портів. Портів може бути багато. Кожен порт має своє ім’я, яке і використовується надалі в файлах з описами віддалених систем. Hабір параметрів не обмежується нижченаведеним прикладом. Докладніше можна знайти в описі до Taylor UUCP.
======= port ======
port port1 # ім’я порту
type modem
device /dev/cuaa1
dialer idc
speed 38400
port port2 # теж ім’я порту
type tcp
service 540
======= port ======
1.7 sysin
Це файл з описами систем, які будуть дзвонити вам.
======= sysin ======
call-login *
call-password *
local-send /
local-receive /
port port1 # це, як ви пам'ятаєте, у нас модемний порт
chat-timeout 90
protocol g # можливо, ви захочете використати який-небудь інший протокол
time never # дзвонять тільки вони, ви їм ніколи не дзвоните
debug 1
system host1
myname myhost # як ви представитесь системі host1, коли вона подзвонить
called-login uuhost1
system host2
myname myhost
called-login uuhost2
system host3
myname myhost
called-login uuhost3
======= sysin ======
1.8 sysout
В цьому файлі зручно прописати ті системи, на які ви самі збираєтесь дзвонити. В даному випадку у нас тільки одна така система - ваш провайдер.
======= sysout ======
call-login *
call-password *
local-send /
local-receive /
port port1
chat-timeout 90
protocol g
time any # дзвонити в будь-який час. А взагалі час можна задавати дуже гнучко.
debug 1
system provider
chat ogin: \L word: \P # берется з файлу call
phone 111111
alternate # так робиться перебір номерів
phone 222222
alternate
phone 333333
======= sysout ======
Коректність настройки можна перевірить, запустив uuchk.
Щоб періодично дзвонити своєму провайдеру за поштою, вставте рядок в /etc/crontab
0 * * * * uucp /usr/libexec/uucp/uucico -S provider
Hастройка sendmail
2.1 Hастройка sendmail.cf
Hеобхідно створити новий sendmail.cf, котрий буде знати про uucp. Для його
створення возьмемо такий файл-прототип:
====== uucp.mc =========
divert(-1)
include(`../m4/cf.m4')
VERSIONID(`@(#)uucp.mc 1.01')
OSTYPE(bsd4.4)dnl
MAILER(local)dnl
MAILER(smtp)dnl
MAILER(uucp)dnl
FEATURE(nodns)dnl
FEATURE(nocanonify)dnl
FEATURE(mailertable)dnl
FEATURE(uucpdomain)dnl
define(`SMART_HOST', `uucp-dom:provider')dnl
define(`confCOPY_ERRORS_TO', `postmaster')dnl
====== uucp.mc =========
Після чого необхідно виконати команду
m4 uucp.mc > /etc/sendmail.cf
Увага! MAILER(smtp) прибирати не можна, навіть, якщо ніякого smtp немає. Він все рівно потрібен для того, щоб працював мейлер uucp-dom. Це мейлер, котрий знає про доменну форму імен - для того, щоби адреса в листах не були в форматі uucp (через знаки оклику).
2.2 Hастройка mailertable
Маршрутзація uucp пошти відбувається згідно правилам, описаним в mailertable. Візьмемо в якості шаблону такий файл
======= /etc/mailertable ======
uucp-dom:provider
======= /etc/mailertable ======
Де provider - це uucp-ім’я системи провайдера (система повинна бути описана в /etc/uucp/sysout) Точка тут виступає в ролі символа підстановки і означає будь-яку кількість довільних символів. Якщо ви не є завершеною системою, то якщо роздаєте пошту комусь ще по uucp, то ваш mailertable може виглядати так:
======= /etc/mailertable ======
host1.your.domain.org uucp-dom:host1
host1.your.domain.org uucp-dom:host1
host2.your.domain.org uucp-dom:host2
host2.your.domain.org uucp-dom:host2
.host3.your.domain.org uucp-dom:host3
host3.your.domain.org uucp-dom:host3
uucp-dom:provider
======= /etc/mailertable ======
Окрема точка в кінці означає - все інше пересилати провайдеру, він сам розбереться. Зрозуміло, що мову в mailertable йде тільки про імена машин. Про користувачів він нічого не знає. Тобто, записи
host1.your.domain.org uucp-dom:host1
host1.your.domain.org uucp-dom:host1
означають тільки те, що пошта для машин
host1.your.domain.org
foo.host1.your.domain.org
bar.host1.your.domain.org
foo.bar.host1.your.domain.org
і т.п. буде направляться через uucp-систему host1. Залишилось тільки додати, що sendmail використовує mailertable у вигляді database map, тому залишилось зробити наступне:
makemap hash /etc/mailertable.db
2.3 Hастройка uudomain
Як уже вказувалось раніше, доменне ім’я системи (hostname) і uucp-ім’я цієї ж самої системи абсолютно не зобов'язані співпадати. Тому в файлі uudomain налаштовується відповідність доменного імені хост і його uucp-імені. В цьому файлі повинні бути описані всі системи, з якими у вас є прямий зв'язок по uucp. Користуючись нашим прикладом, ваш uudomain буде виглядати приблизно так:
======= /etc/uudomain ======
host1 host1.your.domain.org
host2 host2.your.domain.org
host3 host3.your.domain.org
provider mail.provider.ru
======= /etc/uudomain ======
uudomain, так же як і mailertable, має бути у вигляді database map, тому
makemap hash /etc/uudomain.db
Тепер залишилось тільки
kill -1 `cat /var/run/sendmail.pid`
2.4 Hастройка uucp-сервера
Вважається, що ваша машина є поштовим сервером, на який ваші клієнти (host1.your.domain.org, host2.your.domain.org, host3.your.domain.org) будуть ходити за поштою. Ходити за поштою вони можуть по телефону або по IP. Бити сервером uucp дуже просто - коли клієнт подзвонить модемом або зайде на 540 порт, йому необхідно підсунути uucico в якості shell. Краще підсовувати uucico з ключом -l, тоді воно буде само питати пароль, а брати паролі буде з власного файлу з паролями (/etc/uucp/passwd)
2.5 Розсилання пошти користувачами
Команда
mail - відправка і отримання пошти
Синтаксис
mail [-iInv] [-s Коментар ] [-c адреса пересилки]
[-b копія адрес пересилки] адресат
[-опції команди SENDMAIL ...]
mail [-iInNv] -f [ім’я користувача]
mail [-iInNv] [-u раніше заданий киристувач]
Mail - це побудована на платформі UNIX система з вбудованим інтерфейсом для обробки поштових повідомлень.
Опції команди MAIL
-v - режим, коли всі деталі пересилки або прийому повідомлень виводяться на екран
-i - режим ігнорування сигналів збросу, що поступають зі сторони телефонної лінії або сети
-N вивід на екран заголовків повідомлень при роботі з конкретною папкою, в якій вони зберігаються
-s вказувати мета листа
-c, -b посилати копії листа списку користувачів, вказаних через кому
В самому початку mail виконає команди, які прописані в файлах usr/share/misc/mail.rc, /usr/local/etc/mail.rc і /etc/mail.rc. Потім буде запущений файл ~/.mailrc. Mail перевірить наявність нових повідомлень в поштовій скринці користувача, а також перевірить наявність уже отриманих повідомлень в поштову скриньку.
Якщо в командному рядку була вказана команда mail без параметрів, система увійде в режим роботи з поштовими повідомленнями. При цьому командний рядок буде мати вигляд &
Нижче наведені команди для роботи в цьому режимі
t <список номерів поштових повідомлень через пробіл>
вивести на екран текст повідомлення
n
перейти до виводу на екран наступного повідомлення
e <список номерів поштових повідомлень через пробіл>
відредагувати повідомлення
f < список номерів поштових повідомлень через пробіл >
вивести на екран заголовки повідомлень
d < список номерів поштових повідомлень через пробіл >
відмітити повідомлення для подальшого знищення при виході з режиму роботи з поштою
s < список номерів поштових повідомлень через пробіл >
приєднати до повідомлення файл
u < список номерів поштових повідомлень через пробіл>
зняти помітку з повідомлень, які або помічені для видалення при виході з системи
R < список номерів поштових повідомлень через пробіл >
відповісти на повідомлення тому, хто його прислав
r < список номерів поштових повідомлень через пробіл >
відповісти всім на повідомлення
m <список користувачів через пробіл >
надіслати поштове повідомлення всім вказаним в списку
користувачам
Вийти з системи роботи з поштовими повідомленнями
Завдання на роботу
Зайти до мережі і переглянути поштове повідомлення.
Вивести декілька поштових повідомлень, а також заголовки усіх повідомлень.
Написати і відправити лист іншому користувачеві.
Вивести на екран та відредагувати текст повідомлення.
Знищити написане повідомлення.