Gentoo Linux сборник статей



Pdf просмотр
страница56/79
Дата14.11.2016
Размер5.55 Mb.
Просмотров11395
Скачиваний1
1   ...   52   53   54   55   56   57   58   59   ...   79
Листинг 6.1: Emerge IMP
# emerge horde-imp
Важно: Эта часть построена вокруг horde-2.2.x and horde-imp-3.2.x. CVS версии (и следующие релизы) скорее всего, будут очень различаться в настройках. Так же имейте ввиду php-5.x, скорее всего, нарушит работу horde-2.x.
Horde не просто настроить если вы точно не знаете что делать. К счастью для вас, я точно знаю что делать, значит и вы будете. :)
Листинг 6.2: Конфигурирование Horde
# cd /var/www/localhost/htdocs/horde/config/
# for f in *.dist ; do mv ${f} ${f/.dist} ; done
# nano horde.php
663

Виртуальная почтовая система на основе qmail/vpopmail.
(Ниже 'Horde Authentication':)
$conf['auth']['driver'] = 'imap';
$conf['auth']['params']['dsn'] = '{localhost:993/imap/ssl/novalidate-cert}';
(Ниже 'Horde Logging':)
$conf['log']['name'] = '/var/log/apache2/horde.log';
(Ниже 'Problem Reporting':)
$conf['problems']['enabled'] = true;
$conf['problems']['email'] = 'webmaster@wh0rd.org';
# nano registry.php
(Ниже 'Handlers':)
$this->registry['auth']['login'] = 'imp';
$this->registry['auth']['logout'] = 'imp';
(Ниже 'Application registry':) Установите элемент 'status', раздел applications['imp'], из 'inactive' в 'active'
# touch /var/log/apache2/horde.log
# chown apache:apache /var/log/apache2/horde.log
Примечание: Вы можете поменять аккаунт 'webmaster' на что-нибудь другое.
Если вы хотите использовать этот e-mail адрес, тогда вы должны добавить такого пользователя в vpopmail. (или смотрите ниже о qmailadmin).
Теперь действительно быстро установим IMP.
Листинг 6.3: Конфигурирование IMP
# cd /var/www/localhost/htdocs/horde/imp/config/
# for f in *.dist ; do mv ${f} ${f/.dist} ; done
# nano servers.php
(Отредактируйте массив $servers['imap']
$servers['imap'] = array(
'name' => 'wh0rd.org',
'server' => 'localhost',
'protocol' => 'imap/ssl/novalidate-cert',
'port' => 993,
'folders' => '',
'namespace' => 'INBOX.',
'maildomain' => 'wh0rd.org',
'smtphost' => 'localhost',
'realm' => '',
'preferred' => ''
);
Наконец, поднимем apache, чтобы начать использовать webmail.
Листинг 6.4: Запуск apache
# nano /etc/conf.d/apache2
(Раскоменнтируйте APACHE2_OPTS="-D SSL -D PHP4")
# rc-update add apache2 default
# /etc/init.d/apache2 start
Предупреждение: Вы должны подумать о том, чтобы заставить работать Horde
664

Виртуальная почтовая система на основе qmail/vpopmail.
через https. Это не простая задача, но приглядитесь к ней ради безопасности.
Чтобы проверить установку IMP, запустите браузер и зайдите http://localhost/horde/
(измените localhost на ваш сервер) Вы должны увидеть страницу приглашения
Horde где вы можете войти. Опять же, в моей установке я вхожу с помощью 'vapier@wh0rd.org' и 'vappw' соответственно как логин и пароль.
На данный момент, Horde и IMP установлены. Однако, вы можете пройти заново через все дерево конфигурационных директорий и настроить все что вашей душе угодно.
7. Дополнительные пакеты
qmailadmin
Первый пакет на который я обращу ваше внимание это qmailadmin. Это веб интерфейс для управления виртуальными доменами. Просто emerge net- mail/qmailadmin а затем укажите вашему браузеру на http://localhost/cgi- bin/qmailadmin чтобы начать использовать его. qmailadmin делает жизнь намного проще.
qmHandle
Если вы вляпались в проблемы с очередями qmail и провели много времени над отладкой, то, возможно захотите взглянуть на qmHandle. Это простая перл программа которая позволяет вам видеть и редактировать очередь сообщений qmail. Опять таки все что нужно сделать это emerge net-mail/qmhandle.
Дополнения к horde
Я очень рекомендую посмотреть на множество приложений Horde. Turba,
Kronolith, и Nag эти приложения очень хорошо дополняют IMP для разных случаев. Их настройка схожа с настройкой IMP, так что у вас не будет проблем с ними. Просто не забудьте отредактировать registry.php в директории конфигурации horde, и новые приложения появятся внизу странички Horde.
ucspi-tcp
qmail использует ucspi-tcp для фильтрации входящих соединений. Если вы хотите настроить правила фильтрации, тогда смотрите файлы в /etc/tcprules.d/ (в старых версиях qmail эти файлы находятся в /etc). Здесь вы найдете по два файла на каждый сервис, конфигурационный файл (tcp.qmail-smtp) и его откомпилированную версию, ту которую и использует ucspi-tcp (tcp.qmail- smtp.cdb). Каждый раз после обновления конфигурационного файла, надо пересобрать бинарную его версию. Запустите tcprules tcp.qmail-smtp.cdb tcp.qmail- smtp.tmp < tcp.qmail-smtp. Каждый раз при соединении с qmail, откомпилированные правила перечитываются с диска, то есть, нет нужды
665

Виртуальная почтовая система на основе qmail/vpopmail.
перезапускать сервис.
qmail-scanner
Если вы хотите обеспечить фильтрацию контента на своем mail сервере (спам, вирусы), тогда вам необходимо использовать другую программу для организации очередей. Одна из хороших программ это qmail-scanner. Наберите emerge qmail- scanner и отредактируйте /etc/tcprules.d/tcp.qmail-smtp.
Важно: Процесс сборки qmail-scanner очень уродлив. Чтобы поддерживать пакеты, они уже должны быть установлены в системе. Это означает что вы должны установить SpamAssassin и/или Clam AntiVirus до qmail-scanner'а. Смотрите подходящие секции ниже.
Листинг 7.1: Смена программы организации очередей.
# cd /etc/tcprules.d/
# nano tcp.qmail-smtp
(добавьте QMAILQUEUE="/var/qmail/bin/qmail-scanner-queue" в правило catchall)
# tcprules tcp.qmail-smtp.cdb tcp.qmail-smtp.tmp < tcp.qmail-smtp
Смотрите секции об установке спам и вирус фильтров. Вы можете отредактировать несколько опций в /var/qmail/bin/qmail-scanner-queue.pl.
SpamAssassin
Один из лучших спам фильтров это SpamAssassin. Чтобы установить emerge mail- filter/spamassassin. Пакет поставляется двояко, как версия для командной строки и как клиент/серверная. Для серверов через которые проходит небольшое количество почты, использование версии для командной строки себя оправдывает. Но любой у кого большая загрузка серверов должен использовать клиент/серверную версию.
Листинг 7.2: Конфигурирование SpamAssassin
# nano /etc/mail/spamassassin/local.cf
(чтобы обеспечить самый минимум, добавьте следующие опции:)
required_hits 6
skip_rbl_checks 1
# rc-update add spamd default
# /etc/init.d/spamd start
# nano /var/qmail/bin/qmail-scanner-queue.pl
(Убедитесь что $spamc_binary variable выставлена в '/usr/bin/spamc'.)
(Если она выставлена в '', тогда смотрите далее.)
Важно: Если у вас не был установлен SpamAssassin до установки qmail-scanner'а,
Вы должны будете переустановить qmail-scanner. Процесс его сборки очень ужасен, включены будут только те функции, пакеты для которых уже были установлены.
На этом этапе входящая почта будет проходить через qmail-scanner который в
666

Виртуальная почтовая система на основе qmail/vpopmail.
свою очередь пропустит ее через SpamAssassin.
Clam AntiVirus
Как и SpamAssassin, Clam AntiVirus поставляется в двойном исполнении. Я расскажу как быстро поставить клиент/серверную версию. Во-первых, emerge app- antivirus/clamav.
Листинг 7.3: Конфигурирование Clam AntiVirus
# nano /etc/conf.d/clamd
(Установите START_CLAMD=yes)
# nano /etc/clamav.conf
(Настройте все как хотите)
# rc-update add clamd default
# /etc/init.d/clamd start
# nano /var/qmail/bin/qmail-scanner-queue.pl
(Убедитесь что $clamscan_binary переменная установлена в '/usr/bin/clamscan'. Если нет, смотрите ниже.)
# nano /var/qmail/control/conf-common
(Если ClamAV сообщает о проблемах с памятью попробуйте увеличить программный лимит (softlimit))
Важно: Если у вас не был установлен Clam AntiVirus до установки qmail-scanner'а,
Вы должны будете переустановить qmail-scanner. Процесс его сборки очень ужасен, включены будут только те функции, пакеты для которых уже были установлены.
На этом этапе входящая почта будет проходить через qmail-scanner который в свою очередь пропустит ее через Clam AntiVirus.
8. Заключительные примечания
У меня нет особых примечаний, но если у вас проблемы с этим руководством, пожалуйста, свяжитесь со мной или разместите сообщение в системе распределения запросов Gentoo. Если у вас есть интересная информация которая вы считаете, может расширить это руководство, то шлите ее мне для включения.
Я люблю qmail и с удовольствием добавлю веши, которые могут расширить опыт работы пользователя с mta
667

Руководство по электронной почте с использованием Mutt
Руководство по электронной почте с использованием
Mutt
Ссылка на оригинал:
http://www.gentoo.org/doc/ru/guide-to-mutt.xml
C версии: 1.0
1. Введение в E-Mail
Если вы не любитель e-mail клиентов с замысловатым графическим интерфейсом, или если вы просто хотите поэкспериментировать с другими клиентами, чтобы выбрать подходящий для себя, самым простым способом в вашем случае будет использование связки консольных приложений:
fetchmail->procmail->mutt->smtp
Программы эти не просто мощны и гибко настраиваемы, они также легковесны и эффективны. Потому, однажды настроив и запустив всю эту e-mail систему, вы будете просто ошеломлены тем, что сможете делать с её помощью.
Поскольку это краткое руководство, мы не будем рассматривать службы отправки почты (Mail Transfer Agent), такие как sendmail, postfix или exim. Мы также не будем использовать 25 порт для почтовых служб.
Мы можем себе это позволить, так как fetchmail способен передавать принятую почту непосредственно службе доставки почты (MDA) вместо того чтобы перенаправлять её на 25 порт. И мы можем не использовать службу отправки почты (MTA) для простой передачи почты.
Для запуска своей e-mail системы вам понадобится установить следующее программное обеспечение.
Листинг 1.1: Установка нужных программ
# emerge fetchmail procmail mutt nbsmtp
Теперь от полностью рабочей e-mail системы нас отделяют четыре маленьких шажка в направлении конфигурации файлов.
Важно: После каждого шага необходимо тестировать настройку на корректность.
Это конечно же подразумевают, что всё необходимое программное обеспечение у вас уже установлено.
2. Fetchmail
Fetchmail забирает почту с удаленного сервера на вашу локальную машину. Для
668

Руководство по электронной почте с использованием Mutt этого вам необходимо настроить файл .fetchmailrc в вашей домашней директории, подобно примеру:
Листинг 2.1: Пример .fetchmailrc poll mail.myisp.net protocol pop3 user "myname" password "mypassword"
Сразу после создания файла, необходимо выставить права доступа к нему (он должен быть читаем только его владельцем). Сделать это можно следующей командой:
Листинг 2.2: Изменение прав доступа
# chmod 710 .fetchmailrc
Чтобы увидеть процесс в действии, используйте ключ -v. Чтоб получить все сообщения, используйте -a. И ещё вы должны использовать ключ -m для того, чтобы передать принятую почту procmail.
Предупреждение: Будет также хорошей идеей использовать ключ -k, в этом случае если что-то пойдет не так, ваша почта не будет удалена с сервера и вы сможете её повторно забрать.
Пришло время проверить fetchmail в действии!
Листинг 2.3: Тест Fetchmail #1
# fetchmail -akv -m "/usr/bin/procmail -d %T"
Как только вы добьётесь работающей системы, вы можете добавить процесс в cron или какой-нибудь монитор навроде gkrellm. Fetchmail также может быть запущен как демон с указанием секундного интервала.
3. Procmail
Procmail - это программа фильтрующая почту получаемую от fetchmail. А далее, также как и MDA, она поставляет отфильтрованную почту в ваши почтовые ящики, откуда её уже можно прочитать программой mutt (это почтовый клиент, который мы будем использовать).
Для использования procmail, также необходимо создать файл .procmailrc в своём домашнем каталоге. Для наших целей "быстрой настройки" мы будем использовать простой .procmailrc, который фильтрует почту от трех списков рассылки gentoo в три почтовых ящика: gentoo-dev, gentoo-user и gentoo-announce.
Примечание: Правила фильтра называются условиями. Я также добавил условия для того, чтобы отфильтровать некоторый спам.
669

Руководство по электронной почте с использованием Mutt
Листинг 3.1: Пример .procmailrc
MAILDIR=$HOME/MuttMail ##проверьте правильность пути
5LOGFILE=$HOME/.procmaillog
LOGABSTRACT=no
#VERBOSE=on... используется только для отладки
VERBOSE=off
FORMAIL=/usr/bin/formail
NL="
"
##условные строки начинаются с :0
##не записывайте комментарии в строки условия
##отредактируйте ненужные условия!
##строки условий начинаются с *, а регулярные выражения ваши лучшие друзья
##условия добавленные после * попадают прямо в egrep
##строка следущая за условиями, в следующем регистре является именем почтового ящика
#отлавливание копий, используя formail
:0 Whc: .msgid.lock
| $FORMAIL -D 16384 .msgid.cache
:0 a
$MAILDIR/duplicates
#люди которые всегда пишут с одного почтового адреса
:0
* ^From:.*(craig\@hotmail|renee\@local.com)
$MAILDIR/friends
#выборка некоторого спама
:0
* ^Subject:.*(credit|cash|money|debt|sex|sale|loan)
$MAILDIR/spam
#никаких html писем
:0
* ^Content-Type:.*html
$MAILDIR/junk
#складировать письма из списков рассылки в мои почтовые ящики
:0
* ^List-Id:.*gentoo-user gentoo-user
:0
* ^List-Id:.*gentoo-dev gentoo-dev
:0
* ^List-Id:.*gentoo-announce gentoo-announce
#получать любую другую почту с gentoo
:0
* ^From:.*gentoo.org gentoo
:0 670

Руководство по электронной почте с использованием Mutt
* ^From:.*@freshmeat\.net freshmeat
###########################################
# последние условие: складирует остальную #
# почту в почтовый ящик по умолчанию #
###########################################
:0
* .*
default
# конец файла
Примечание: В данном случае вам только потребуется создать почтовую директорию в $HOME/MuttMail, после чего Procmail создаст все необходимые файлы почтового ящика в этом каталоге, используя названия из строк условий.
Для дополнительной информации посетите http://www.procmail.org/
Для проверки нашего .procmailrc, повторно запустите fetchmail (который мы уже настроили). Помните также, что опция -k оставляет почту на удаленном сервере, потому её можно использовать для нашего теста.
Листинг 3.2: Тест Procmail #1
# fetchmail -akv -m "/usr/bin/procmail -d %T"
Ну всё, теперь когда fetchmail и procmail работают, мы можем зайдя в
$HOME/MuttMail прочитать нашу почту программой less или вашим любимым файловым менеджером.
4. Почтовый клиент Mutt
Mutt используется для чтения и написания писем. Это очень мощное, сложно- настраиваемое, легковесное и эффективное приложение.
Mutt поддерживает чтение и запись в различных форматах почтового ящика: mbox, MMDF, MH и Maildir. Тип почтового ящика распознается автоматически. В нашем случае мы используем формат mbox, где все сообщения почтового ящика сохраняются в отдельных файлах.
Mutt также имеет способность работать с папками, расположенными на удаленном IMAP сервере. См. Поддержку IMAP в разделе 4.11 руководства по
Mutt и сайт Mutt http://www.mutt.org/.
При установке mutt создаётся основной файл конфигурации /etc/mutt/Muttrc. Вам также необходимо создать файл .muttrc в своём домашнем каталоге.
Листинг 4.1: Пример .muttrc
(Конечно, неплохо бы прочитать документацию Mutt из /usr/share/doc/mutt*)
671

Руководство по электронной почте с использованием Mutt
(Любые настройки здесь отменяют параметры общей конфигурации из /etc/mutt/Muttrc)
# cp /etc/mutt/Muttrc
/.muttrc

# nano -w .muttrc
set pager_context=1
set pager_index_lines=6 #показывать оглавления в окне программы set menu_scroll set pgp_verify_sig=no #не показывать pgp на странице set status_on_top #разместить статусную строку вверху set sort=threads #сортировать сообщения по заголовкам set status_format=" %r %b %f %n Del %d Msgs %m %l %> (%P)"
set pager_format="%-10.10i %[!%a %b %d %R]"
set date_format="!%H:%M %a %d %b "
set index_format="%4C %Z %[%b%d] %-15.15F %s"
set folder_format="%2C %t %8s %d %N %f"
#set sendmail="/usr/bin/nbsmtp -d isp.net -h smtp.isp.net -f yourname@isp.net"
#set from="default-mailaddress" #задаёт ваш адрес в строке "from"
#set realname="myname"
set record="$HOME/MuttMail/sent" #сохранять отправленную почту здесь set delete=yes #удалить без подтверждения set include=yes
#выделять сообщение в ответе set fast_reply=yes
#не подтверждать ответ set beep=no
#не пищать set markers=no
#не помечать + сложенные строки set confirmappend=no
#не подтверждать сохранение в =keep set to_chars=" +TCF" #нет L для mail_list set folder = $HOME/MuttMail mailboxes =gentoo-user mailboxes =gentoo-dev mailboxes =gentoo-announce mailboxes =gentoo mailboxes =freshmeat mailboxes =duplicates mailboxes =default mailboxes =sent mailboxes =friends mailboxes =junk mailboxes =spam mailboxes =keep save-hook .* =keep #mbox по умолчанию сохраняет (s) почту в =keep subscribe gentoo-user gentoo-dev #подписанные списки bind pager h display-toggle-weed
#переключать заголовки кнопкой h
# симулировать старое url меню macro index \cb |urlview\n 'call urlview to extract URLs out of a message'
macro pager \cb |urlview\n 'call urlview to extract URLs out of a message'
#запуск fetchmail нажатием кнопки G
macro index G "!fetchmail -a -m 'procmail -d %T'\r"
macro pager G "!fetchmail -a -m 'procmail -d %T'\r"
#редактирование .muttrc... не требует перезапуска
672

Руководство по электронной почте с использованием Mutt macro generic ,sm ":source $HOME/.muttrc\r"
macro generic \cj "!rxvt -bg wheat -e joe $HOME/.muttrc\r"
#по умолчанию список заголовков в полях удаляется перед показом почты
#игнорирует всё, кроме того, что вам нужно ignore *
unignore Date To From: Subject X-Mailer Organization User-Agent hdr_order Date From To Subject X-Mailer User-Agent Organization
##ваш Mutt должен поддерживать несколько цветов
##для обозначения четырех уровней выделенного текста
##данные настройки отменяют параметры общей конфигурации в /etc/mutt/Muttrc
#color quoted green default color quoted1 magenta blue
#color quoted2 yellow default
#color quoted3 red default
#color signature cyan cyan
#эта цветовая схема взята из /etc/mutt/Muttrc.color
#закомментируйте её, если вам нужна цветовая схема по умолчанию из /etc/mutt/Muttrc
# Je vois la vie en rose :-)
color hdrdefault brightcyan blue color header brightwhite blue "^from:"
color header brightwhite blue "^subject:"
color quoted brightgreen blue color signature brightwhite blue color indicator blue green color error red black mono error bold color status black cyan mono status bold color tree yellow blue color tilde brightmagenta blue color body brightwhite blue
"[-a-z_0-9.]+@[-a-z_0-9.]+"
mono body bold "[-a-z_0-9.]+@[-a-z_0-9.]+"
color body brightyellow black "^Good signature"
mono body bold "^Good signature"
color body brightwhite red "^Bad signature from.*"
mono body bold "^Bad signature from.*"
color normal white blue color message green black color attachment brightgreen blue
# конец файла... но вы можете его дописывать и дописывать... :)
Это только маленький пример файла .muttrc. На самом же деле гораздо больше опций поддаются конфигурации, например, те же настройки gpg. Для примеров и помощи посмотрите http://mutt.netliberte.org/.
Теперь вы можете протестировать наш .muttrc
673

Руководство по электронной почте с использованием Mutt
Листинг 4.2: Тест .muttrc
# mutt -y
После чего должно появиться окно Mutt с почтовыми ящиками, которые мы создали, когда настраивали fetchmail.
Нажмите ? для получения помощи в навигации по почтовым ящикам в Mutt.
5. SMTP
Последний шаг, это настройка nbsmtp ('No-Brainer SMTP'), используемого для отправки почты на ваш сервер SMTP. Данная настройка самая простая и требует лишь добавления нескольких строк в конфигурационный файл .muttrc domain: домен, сообщаемый nbsmtp. Будет почти всегда похож на окончаниее вашего адреса электронной почты. from@addr: Это тот адрес, который будет сообщаться nbsmtp в строке "from".
Обратите внимание, что данный адрес может отличаться от того, что записан в поле "From:" вашего почтового клиента (MUA). host: Сервер smtp, куда, собственно, и будет отправляться почта.
Листинг 5.1: Добавление поддержки smtp
# nano -w .muttrc
set sendmail="/usr/bin/nbsmtp -d isp.net -h smtp.isp.net -f urname@isp.net"
Теперь всё готово для создания письма. В окне Mutt нажмите m, для того чтобы написать текстовое сообщение на ваш же почтовый ящик. Mutt использует значение EDITOR или VISUAL, указываемое с помощью опций editor= в .muttrc.
После того, как сообщение будет написано, нажмите y для его отправки. Если всё прошло удачно, мы увидим сообщение 'sending mail', следующее за 'New mail in
=sent'.
Помните, в .muttrc у нас задано сохранять всю отправленную почту при помощи строки :set record="$HOME/MuttMail/sent"
Теперь, чтобы завершить испытание, снова запустите fetchmail для получения всей почты и вашего тестового письма, которое вы себе отправили. Как только это тестовое письмо будет найдено, нажмите h для того, чтобы посмотреть все его заголовки и полный путь прохождения почты (mail transfer path).
Примечание: Есть ещё одна программа, которая, возможно, вам пригодится, под названием urlview. Она извлекает ссылки из текстовых сообщений и перенаправляет их в ваш браузер.
674

Руководство по электронной почте с использованием Mutt
Листинг 5.2: Установка urlview
# emerge urlview
После чего создайте
/.urlview копируя конфигурационный файл из
/usr/share/doc/urlview*/, и подправьте необходимые настройки под свой браузер.
Чтож, теперь у нас есть мощная почтовая система. Читайте различную документацию и руководства, а также ищите примеры конфигурационных файлов в 'google' по ключевым словам muttrc и procmailrc.
675

Руководство по файловой системе для устройств
Руководство по файловой системе для устройств
Ссылка на оригинал:
http://www.gentoo.org/doc/ru/devfs-guide.xml
C версии: 1.0
1. Что такое devfs?
Старые (добрые?) времена
Традиционная реализация Linux предоставляет пользователю абстрактный каталог устройств, называемый /dev. Внутри этого каталога находятся device nodes, специальные файлы, символизирующие устройства внутри системы.
Например, /dev/hda символизирует первое IDE устройство в вашей системе.
Файлы устройств позволяют создавать программы, которые взаимодействуют с устройствами так, как если бы устройства были обычными файлами, вместо использования специальных API.
Файлы устройств подразделяются на две группы, называемые character devices
(символьные устройства) и block devices (блочные устройства). Первая группа содержит устройства, для котрых отсутствует буферизация чтения/записи. Вторая группа, естественно, содержит устройства, для которых чтение/запись буферизируется. Из обоих типов устройств может быть прочитан за раз один символ или блок. Поэтому такой способ присваивания имён может сбивать с толку и на самом деле неправилен.
Если посмотреть на конкретное устройство, можно обнаружить что-то, похожее на это:



Поделитесь с Вашими друзьями:
1   ...   52   53   54   55   56   57   58   59   ...   79


База данных защищена авторским правом ©nethash.ru 2019
обратиться к администрации

войти | регистрация
    Главная страница


загрузить материал