КОНТРОЛЬНА РОБОТА № 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
1) Необхідно написати конфігураційні файли для UUCP. 2) 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 portdrwxr-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 passwordprovider uumyhost Your_Secret_Password======= call ====== 1.2 config
В цьому файлі описуються різні параметри uucp, в основному шляхи і імена файлів. Цей файл потрібен, якщо потрібно перевизначити деякі умовчання, які або задані при компіляції.
======= config ======nodename myhost # тут необхідно указати ваше власне uucp-ім’яspool /var/spool/uucppubdir /var/spool/uucppubliclogfile /var/spool/uucp/Logstatfile /var/spool/uucp/Statsdebugfile /var/spool/uucp/Debugsysfile sysin sysout # імена файлів з описами систем - ваших лінківportfile portdialfile dialdialcodefile dialcodecallfile callpasswdfile passwd# кількість одночасно виконуваних процесів розкладки поштиmax-uuxqts 1======= config ====== 1.3 dial
Це файл з описами модемів.
======= dial ======dialer idc # довільне ім’я модему, під яким він буде відомий uucpdialtone wpause ,#chat "" ATZrdc OK ATM0DPWT CONNECT pcchat "" ATZrdc OK ATM0DTT CONNECT pcchat-fail BUSYchat-fail ERRORchat-fail NOsDIALTONEchat-fail NOsCARRIER#complete dd+++ddATHrc#abort dd+++ddATHrc======= dial ====== 1.4 dialcode
Служить для набору номера, має нульову довжину
1.5 passwd
В цьому файлі містяться логін і відповідний пароль для тих систем, які будуть дзвонити вам. При роботі з протоколом UUCP daemon uucico -l авторизує подзвонивших користувачів, пропонуючи їм при цьому ввести логін і пароль, і перевіряє правильність пароля по цьому файлу. Які логіни і паролі можна присвоїти віддаленим машинам, які дзвонять вам – справа смаку. Правильніше дати їм логіни, які починаються однаково, наприклад, з двох букв uu.
======= passwd ======uuhost1 Top_Sec
В цьому файлі міститься опис портів. Портів може бути багато. Кожен порт має своє ім’я, яке і використовується надалі в файлах з описами віддалених систем. Hабір параметрів не обмежується нижченаведеним прикладом. Докладніше можна знайти в описі до Taylor UUCP.
======= port ======port port1 # ім’я портуtype modemdevice /dev/cuaa1dialer idcspeed 38400port port2 # теж ім’я портуtype tcpservice 540======= port ====== 1.7 sysin
Це файл з описами систем, які будуть дзвонити вам.
======= sysin ======call-login *call-password *local-send /local-receive /port port1 # це, як ви пам'ятаєте, у нас модемний портchat-timeout 90protocol g # можливо, ви захочете використати який-небудь інший протоколtime never # дзвонять тільки вони, ви їм ніколи не дзвонитеdebug 1system host1myname myhost # як ви представитесь системі host1, коли вона подзвонитьcalled-login uuhost1system host2myname myhostcalled-login uuhost2system host3myname myhostcalled-login uuhost3======= sysin ====== 1.8 sysout
В цьому файлі зручно прописати ті системи, на які ви самі збираєтесь дзвонити. В даному випадку у нас тільки одна така система - ваш провайдер.
======= sysout ======call-login *call-password *local-send /local-receive /port port1chat-timeout 90protocol gtime any # дзвонити в будь-який час. А взагалі час можна задавати дуже гнучко.debug 1system providerchat ogin: L word: P # берется з файлу callphone 111111alternate # так робиться перебір номерівphone 222222alternatephone 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)dnlMAILER(local)dnlMAILER(smtp)dnlMAILER(uucp)dnlFEATURE(nodns)dnlFEATURE(nocanonify)dnlFEATURE(mailertable)dnlFEATURE(uucpdomain)dnl define(`SMART_HOST', `uucp-dom:provider')dnldefine(`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:host1host1.your.domain.org uucp-dom:host1host2.your.domain.org uucp-dom:host2host2.your.domain.org uucp-dom:host2.host3.your.domain.org uucp-dom:host3host3.your.domain.org uucp-dom:host3uucp-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.orghost2 host2.your.domain.orghost3 host3.your.domain.orgprovider 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 <список користувачів через пробіл >
надіслати поштове повідомлення всім вказаним в списку
користувачам
Вийти з системи роботи з поштовими повідомленнями
Завдання на роботу
1. Зайти до мережі і переглянути поштове повідомлення.
2. Вивести декілька поштових повідомлень, а також заголовки усіх повідомлень.
3. Написати і відправити лист іншому користувачеві.
4. Вивести на екран та відредагувати текст повідомлення.
5. Знищити написане повідомлення.