서버 설정 · 12 min read · Dec 24, 2025
완벽한 SpamSnake - Ubuntu Jeos 10.10 매버릭 미어캣 - 2페이지
6. Postfix 설치:
apt-get install postfix postfix-mysql postfix-doc procmail두 가지 질문이 있습니다. 다음과 같이 답하십시오:
메일 구성의 일반 유형: –> 인터넷 사이트
시스템 메일 이름: –> server1.example.com
Postfix 중지:
postfix stop아래와 같이 Postfix를 편집하려고 합니다:
vi master.cf픽업 서비스 유형 아래에 두 개의 항목을 추가해야 합니다. 픽업 서비스는 로컬 메일(로컬은 “이 머신에서”)을 “픽업”하고 배달합니다. 이는 이 머신에서 생성된 메일에 대한 콘텐츠 필터링을 우회하는 방법입니다.
완료되면 다음과 같아야 합니다:
pickup fifo n - - 60 1 pickup
-o content_filter=
-o receive_override_options=no_header_body_checksmain.cf 편집:
vi /usr/src/postfix.sh#!/bin/sh
postconf -e "alias_maps = hash:/etc/aliases"
newaliases
postconf -e "myorigin = domain.tld"
postconf -e "myhostname = server1.domain.tld"
postconf -e "mynetworks = 127.0.0.0/8, 192.168.0.0/24"
postconf -e "message_size_limit = 10485760"
postconf -e "local_transport = error:No local mail delivery"
postconf -e "mydestination = "
postconf -e "local_recipient_maps = "
postconf -e "relay_domains = mysql:/etc/postfix/mysql-relay_domains.cf"
postconf -e "relay_recipient_maps = mysql:/etc/postfix/mysql-relay_recipients.cf"
postconf -e "transport_maps = mysql:/etc/postfix/mysql-transports.cf"
postconf -e "virtual_alias_maps = hash:/etc/postfix/virtual"
postconf -e "disable_vrfy_command = yes"
postconf -e "strict_rfc821_envelopes = no"
postconf -e "smtpd_banner = $myhostname ESMTP SpamSnake"
postconf -e "smtpd_delay_reject = yes"
postconf -e "smtpd_recipient_limit = 100"
postconf -e "smtpd_helo_required = yes"
postconf -e "smtpd_client_restrictions = permit_sasl_authenticated, permit_mynetworks, permit"
postconf -e "smtpd_helo_restrictions = permit_sasl_authenticated, permit_mynetworks, permit"
postconf -e "smtpd_sender_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_non_fqdn_sender, reject_unknown_sender_domain, permit"
postconf -e "smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unknown_recipient_domain, reject_unauth_destination, whitelist_policy, grey_policy, rbl_policy, spf_policy, permit"
postconf -e "smtpd_data_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_pipelining"
postconf -e "smtpd_restriction_classes = spf_policy, rbl_policy, grey_policy, whitelist_policy"
postconf -e "spf_policy = check_policy_service unix:private/policy"
postconf -e "rbl_policy = reject_rbl_client zen.spamhaus.org, reject_rbl_client bl.spamcop.net"
postconf -e "grey_policy = check_policy_service unix:private/greyfix"
postconf -e "whitelist_policy = check_client_access mysql:/etc/postfix/mysql-global_whitelist.cf, check_sender_access mysql:/etc/postfix/mysql-global_whitelist.cf"
postconf -e "header_checks = regexp:/etc/postfix/header_checks"
touch /etc/postfix/virtual
echo "root [email protected]" >> /etc/postfix/virtual && echo "abuse [email protected]" >> /etc/postfix/virtual && echo "postmaster [email protected]" >> /etc/postfix/virtual
postmap /etc/postfix/virtual
touch /etc/postfix/header_checks
echo "/^Received:/ HOLD" >> /etc/postfix/header_checks
postmap /etc/postfix/header_checks
cat > /etc/postfix/mysql-global_whitelist.cf < /etc/postfix/mysql-relay_domains.cf < /etc/postfix/mysql-relay_recipients.cf < /etc/postfix/mysql-transports.cf < 참고: 이 단계에서는 [email protected], example.com 및 @example.com을 설정에 맞는 실제 값으로 바꾸어야 합니다.
chmod +x /usr/src/postfix.sh그리고 다음을 사용하여 실행합니다:
./usr/src/postfix.sh*참고: cf 파일의 사용자/비밀번호는 나중에 Baruwa DB 설정에 사용할 사용자/비밀번호와 동일해야 합니다. 스크립트를 실행하기 전에 빨간색으로 표시된 모든 항목을 변경해야 합니다.
Postfix 수신자 호출(Optional)
이 기능은 수신자 서버에 쿼리하여 수신자가 존재하는지 확인합니다. 존재하지 않으면 550 오류로 발신 서버에 응답하고 연결을 끊습니다. 사용자가 존재하면 SpamSnake는 이메일 처리를 계속합니다. 이는 백스캐터를 방지하는 또 다른 방법이지만 비용이 발생합니다. http://www.postfix.org/ADDRESS_VERIFICATION_README.html에서 자세히 읽어보세요. 이 방법이 서버를 느리게 할 것이라고 판단되면 이 방법을 건너뛰고 스크립트 방법(이 가이드의 후반부)을 사용할 수 있습니다.
vi /etc/postfix/main.cf다음과 같이 추가합니다:
verify_recipient = reject_unknown_recipient_domain, reject_unverified_recipient
look_ahead = check_recipient_access hash:/etc/postfix/access
unverified_recipient_reject_code = 550
address_verify_map = btree:/var/lib/postfix/verify이것을 smtpd_restriction_classes에 추가합니다:
verify_recipient, look_ahead이것을 smptd_recipient_restrictions에 추가합니다:
smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination, look_ahead, whitelist_policy, grey_policy, rbl_policy, spf_policy, permittouch /etc/postfix/access그리고 도메인을 추가합니다:
domainA.com verify_recipient
domainB.com verify_recipient*참고: 필터링할 유효한 도메인을 추가해야 합니다.
Postmap:
postmap /etc/postfix/accessPostfix 설치 최종 확인:
less /etc/postfix/main.cf파일의 내용을 확인하여 오류가 있는지 확인하고 필요시 수정합니다. Postfix를 시작합니다:
postfix startPostfix가 응답하는지 확인합니다:
telnet 127.0.0.1 25다음과 같은 메시지가 표시되어야 합니다:
220 [yourFQDNhere] ESMTP Postfix (Ubuntu)7. MailScanner 설치 (Apparmor, Clamav, DCC, Pyzor, Razor 및 Spamassassin)
cd /usr/src
wget http://http.us.debian.org/debian/pool/main/libt/libtool/libltdl3_1.5.26-4+lenny1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb
dpkg -i libltdl*
apt-get install razor pyzor clamav-daemon libclamav6 apparmorClamav을 위한 Apparmor 구성
clamav가 디렉토리에 접근할 수 있도록 www-data 그룹에 추가합니다:
usermod -a -G www-data clamav이제 clamd의 프로파일을 편집합니다:
vi /etc/apparmor.d/usr.sbin.clamd그리고 Incoming 폴더를 폴더 목록에 추가합니다:
/usr/sbin/clamd {
#clamav
/var/spool/MailScanner/ rw,
/var/spool/MailScanner/incoming/ rw,
}apparmor를 다시 로드합니다:
/etc/init.d/apparmor reloadDCC 32비트/64비트 구성
.deb 소스에서 DCC를 설치합니다:
cd /tmp
wget http://ppa.launchpad.net/jonasped/ppa/ubuntu/pool/main/d/dcc/dcc-common_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb && dpkg -i dcc-common_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb
wget http://ppa.launchpad.net/jonasped/ppa/ubuntu/pool/main/d/dcc/dcc-client_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb && dpkg -i dcc-client_1.3.130-0ubuntu1~ppa1~karmic1_$(uname -m | sed -e 's/x86_64/amd64/' -e 's/i686/i386/').deb설치를 테스트합니다:
cdcc info서버에서 ‘요청이 성공했습니다’라는 메시지를 받아야 합니다.
Pyzor 구성
pyzor가 python2.6과 잘 작동하지 않기 때문에, 다음을 /usr/bin/pyzor의 첫 번째 줄에 추가하여 다음과 같이 만듭니다:
#!/usr/bin/python -Wignore::DeprecationWarning여기서 Pyzor 서버의 IP 주소를 Pyzor에 공급합니다. 이렇게 하면 서버의 IP 주소가 해당 파일에 생성됩니다. 그런 다음 연결을 테스트합니다. 방화벽 뒤에 있는 경우 서버로 들어오고 나가는 포트 24441/udp를 열어야 합니다. 그 동안 DCC를 위해 6277/udp, Razor를 위해 2703/tcp 및 SpamAssassin을 위해 783/tcp도 열어야 합니다:
mkdir /var/lib/MailScanner
pyzor --homedir=/var/lib/MailScanner discover
pyzor pingRazor 구성
.razor 구성을 생성합니다:
cd && rm /etc/razor/razor-agent.conf
mkdir /var/lib/MailScanner/.razor
razor-admin -home=/var/lib/MailScanner/.razor -create
razor-admin -home=/var/lib/MailScanner/.razor -discover
razor-admin -home=/var/lib/MailScanner/.razor -registervi /var/lib/MailScanner/.razor/razor-agent.confdebuglevel = 0
razorhome = /var/lib/MailScanner/.razor/의존성 설치:
apt-get install libconvert-tnef-perl libdbd-sqlite3-perl libfilesys-df-perl libmailtools-perl libmime-tools-perl libmime-perl libnet-cidr-perl libsys-syslog-perl libio-stringy-perl libfile-temp-perl libole-storage-lite-perl libarchive-zip-perl libsys-hostname-long-perl libnet-cidr-lite-perl libhtml-parser-perl libdb-file-lock-perl libnet-dns-perl libncurses5-dev libdigest-hmac-perl libdigest-sha1-perl libnet-ip-perl liburi-perl libfile-spec-perl spamassassin libnet-ident-perl libmail-spf-query-perl libmail-dkim-perl dnsutils libio-socket-ssl-perl gdebi-core최신 MailScanner 다운로드 및 설치:
cd /usr/src && wget http://www.mailscanner.info/files/4/tar/MailScanner-install-4.81.4-1.tar.gz
tar xvfz MailScanner-install-4.81.4-1.tar.gz && cd MailScanner-install-4.81.4
./install.shcrontab -e를 실행하고 다음 항목을 추가합니다:
37 5 * * * /opt/MailScanner/bin/update_phishing_sites &> /dev/null
07 * * * * /opt/MailScanner/bin/update_bad_phishing_sites &> /dev/null
58 23 * * * /opt/MailScanner/bin/clean.quarantine &> /dev/null
42 * * * * /opt/MailScanner/bin/update_virus_scanners &> /dev/null
3,23,43 * * * * /opt/MailScanner/bin/check_mailscanner &> /dev/null SpamAssassin
먼저 기본 SpamAssassin 구성 파일을 비활성화해야 합니다:
mv /etc/spamassassin/local.cf /etc/spamassassin/local.cf.disabled이제 MailScanner에서 SpamAssassin 구성 파일을 백업한 후 편집합니다:
cp /opt/MailScanner/etc/spam.assassin.prefs.conf /opt/MailScanner/etc/spam.assassin.prefs.conf.backSpamAssassin SQL Bayes
사전 요구 사항: perl-DBI 및 perl-DBD-MySQL 모듈이 설치되어 있어야 합니다.
가정 및 변수:
SpamAssassin Bayes 데이터베이스 이름: sa_bayes
SpamAssassin Bayes 데이터베이스 사용자 이름: sa_user
SpamAssassin Bayes 데이터베이스 비밀번호: sa_password
Bayesian 정보를 저장할 서버에 MySQL 데이터베이스를 생성합니다.
mysql -u root -p
mysql> create database sa_bayes;
mysql> GRANT ALL ON sa_bayes.* TO sa_user@localhost IDENTIFIED BY 'sa_password';
mysql> flush privileges;데이터베이스 구조를 가져옵니다:
mysql -u sa_user -p sa_bayes < /usr/share/doc/spamassassin/sql/bayes_mysql.sqlvi /etc/spamassassin/v310.pre에서 DCC를 활성화합니다:
loadplugin Mail::SpamAssassin::Plugin::DCClint 테스트에서 오류를 방지하기 위해 다음을 생성합니다:
mkdir /var/www/.spamassassinvi /opt/MailScanner/etc/spam.assassin.prefs.conf그리고 다음을 맨 위에 추가합니다:
#pyzor
use_pyzor 1
pyzor_options --homedir /var/lib/MailScanner/
#razor
use_razor2 1
razor_config /var/lib/MailScanner/.razor/razor-agent.confDCC 경로 수정:
dcc_path /usr/bin/dccproc헤더 문자열 업데이트:
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-SpamCheck
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-SpamScore
bayes_ignore_header X-YOURDOMAIN-COM-MailScanner-Information
#use_auto_whitelist 0“YOURDOMAIN-COM”은 MailScanner.conf 파일에서 “%org-name%”에 사용한 것으로 대체되어야 합니다. “X-“는 그대로 두십시오. 이는 위의 MailScanner.conf에서 사용된 동일한 orgname입니다.
하단에 SQL 연결 문자열 추가:
bayes_store_module Mail::SpamAssassin::BayesStore::SQL
bayes_sql_dsn DBI:mysql:sa_bayes:localhost
bayes_sql_username sa_user
bayes_sql_password sa_password
bayes_sql_override_username rootvi v310.pre그리고 DKIM이 도메인 키를 대체했으므로 domainkeys를 주석 처리합니다:
#loadplugin Mail::SpamAssassin::Plugin::DomainKeys크론에 추가:
30 01 * * * /usr/bin/sa-learn --force-expire --sync -p /opt/MailScanner/etc/spam.assassin.prefs.conf 누락된 perl 패키지 설치:
perl -MCPAN -e shell
install IP::Country::Fast
install Encode::Detect
install Crypt::OpenSSL::RSA모두 함께 작동하도록 권한 설정:
chown -R postfix:www-data /var/spool/postfix/hold
chmod -R ug+rwx /var/spool/postfix/hold설정을 테스트합니다:
spamassassin -x -D -p /opt/MailScanner/etc/spam.assassin.prefs.conf --lint다음과 같은 줄을 확인하십시오:
debug: bayes: Database connection established
debug: bayes: found bayes db version 3
debug: bayes: Using userid: 2DCC, Pyzor 및 Razor에서 플러그인을 로드하고 오류가 없기를 바랍니다.
MailScanner 구성
SpamAssassin을 위한 디렉토리를 스풀에 만들고 postfix에 권한을 부여해야 합니다. root로 sa-learn –force를 실행하면 이러한 디렉토리에 저장된 bayes 데이터베이스가 root:root로 변경되고 spamassassin이 db를 볼 때 오류가 발생합니다. mail.log를 주의 깊게 살펴보면 권한을 다시 변경해야 한다는 것을 기억할 수 있습니다. 또한 MailScanner 기본 구성을 비활성화합니다:
mkdir /var/spool/MailScanner/spamassassinMailScanner.conf 파일을 백업합니다:
cp /opt/MailScanner/etc/MailScanner.conf /opt/MailScanner/etc/MailScanner.conf.dist
vi /opt/MailScanner/etc/MailScanner.conf다음 스크립트를 사용하여 MailScanner.conf의 다음 매개변수를 변경합니다:
vi /usr/src/mailscanner.shchmod +x mailscanner.sh그리고 다음을 사용하여 실행합니다:
./usr/src/mailscanner.shsed -i "/^%org-name% =/ c\%org-name% =orgname" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^%org-long-name% =/ c\%org-long-name% = longorgname" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^%web-site% =/ c\%web-site% = www.domain.tld" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Run As User =/ c\Run As User = postfix" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Run As Group =/ c\Run As Group = www-data" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Work Group =/ c\Incoming Work Group = clamav" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Work Permissions =/ c\Incoming Work Permissions = 0640" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Incoming Queue Dir =/ c\Incoming Queue Dir = /var/spool/postfix/hold" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Outgoing Queue Dir =/ c\Outgoing Queue Dir = /var/spool/postfix/incoming" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^MTA =/ c\MTA = postfix" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine User =/ c\Quarantine User = root" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Group =/ c\Quarantine Group = www-data" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Permissions =/ c\Quarantine Permissions = 0660" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Quarantine Whole Message =/ c\Quarantine Whole Message = yes" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Virus Scanners =/ c\Virus Scanners = clamd" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Monitors for ClamAV Updates =/ c\Monitors for ClamAV Updates = /var/lib/clamav/*.cld /var/lib/clamav/*.cvd" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Clamd Socket =/ c\Clamd Socket = /var/run/clamav/clamd.ctl" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Clamd Lock File =/ c\Clamd Lock File = /var/run/clamav/clamd.pid" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Spam Subject Text =/ c\Spam Subject Text = *SPAM*" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Spam Actions =/ c\Spam Actions = deliver store" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^High Scoring Spam Actions =/ c\High Scoring Spam Actions = store delete" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^Non Spam Actions =/ c\Non Spam Actions = deliver store" /opt/MailScanner/etc/MailScanner.conf
sed -i "/^SpamAssassin User State Dir =/ c\SpamAssassin User State Dir = /var/spool/MailScanner/spamassassin" /opt/MailScanner/etc/MailScanner.conf *참고: 스크립트를 실행하기 전에 빨간색으로 표시된 항목을 변경해야 합니다.
MailScanner 시작 스크립트:
vi /etc/init.d/mailscanner다음과 같이 작성하고
chmod +x /etc/init.d/mailscanner#! /bin/sh
### BEGIN INIT INFO
# Provides: MailScanner daemon
# Required-Start: $local_fs $remote_fs
# Required-Stop: $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Controls mailscanner instances
# Description: MailScanner is a queue-based spam/virus filter
### END INIT INFO
# Author: Simon Walter <[email protected]>
# PATH should only include /usr/* if it runs after the mountnfs.sh script
PATH=/usr/sbin:/usr/bin:/bin:/sbin:/opt/MailScanner/bin
DESC="mail spam/virus scanner"
NAME=MailScanner
PNAME=mailscanner
DAEMON=/opt/MailScanner/bin/$NAME
STARTAS=MailScanner
SCRIPTNAME=/etc/init.d/$PNAME
CONFFILE=/opt/MailScanner/etc/MailScanner.conf
# Exit if the package is not installed
[ -x "$DAEMON" ] || exit 0
run_nice=0
stopped_lockfile=/var/lock/subsys/MailScanner.off
# Read configuration variable file if it is present
[ -r /etc/default/$PNAME ] && . /etc/default/$PNAME
# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh
# Define LSB log_* functions.
# Depend on lsb-base (>= 3.0-6) to ensure that this file is present.
. /lib/lsb/init-functions
# sanity check for permissions
fail()
{
echo >&2 "$0: $1"
exit 1
}
check_dir()
{
if [ ! -d $1 ]; then
mkdir -p "$1" || \
fail "directory $1: does not exist and cannot be created"
fi
actual="$(stat -c %U $1)"
if [ "$actual" != "$2" ]; then
chown -R "$2" "$1" || \
fail "directory $1: wrong owner (expected $2 but is $actual)"
fi
actual="$(stat -c %G $1)"
if [ "$actual" != "$3" ]; then
chgrp -R "$3" "$1" || \
fail "directory $1: wrong group (expected $3 but is $actual)"
fi
}
user=$(echo $(awk -F= '/^Run As User/ {print $2; exit}' $CONFFILE))
group=$(echo $(awk -F= '/^Run As Group/ {print $2; exit}' $CONFFILE))
check_dir /var/spool/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/lib/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/run/MailScanner ${user:-postfix} ${group:-www-data}
check_dir /var/lock/subsys ${user:-root} ${group:-root} #Required to Create Folder
check_dir /var/lock/subsys/MailScanner ${user:-postfix} ${group:-www-data}
#
# Function that starts the daemon/service
#
do_start()
{
# Return
# 0 if daemon has been started
# 1 if daemon was already running
# 2 if daemon could not be started
start-stop-daemon --start --quiet --startas $STARTAS --name $NAME --test > /dev/null \
|| return 1
start-stop-daemon --start --quiet --nicelevel $run_nice --chuid postfix:www-data --exec $DAEMON --name $NAME -- $DAEMON_ARGS \
|| return 2
# Add code here, if necessary, that waits for the process to be ready
# to handle requests from services started subsequently which depend
# on this one. As a last resort, sleep for some time.
# Set lockfile to inform cronjobs about the running daemon
RETVAL="$?"
if [ $RETVAL -eq 0 ]; then
touch /var/lock/subsys/mailscanner
rm -f $stopped_lockfile
fi
if [ $RETVAL -eq 0 ]; then
echo "MailScanner Started"
fi
}
#
# Function that stops the daemon/service
#
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --retry=TERM/30 --name $NAME
RETVAL="$?"
[ "$RETVAL" = 2 ] && return 2
# Remove lockfile for cronjobs
if [ $RETVAL -eq 0 ]; then
rm -f /var/lock/subsys/mailscanner
touch $stopped_lockfile
fi
if [ $RETVAL -eq 0 ]; then
echo "MailScanner Stopped"
fi
}
#
# Function that sends a SIGHUP to the daemon/service
#
do_reload() {
start-stop-daemon --stop --signal 1 --quiet --name $NAME
return 0
}
case "$1" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
restart|force-reload)
#
# If the "reload" option is implemented then remove the
# 'force-reload' alias
#
log_daemon_msg "Restarting $DESC" "$NAME"
do_stop
case "$?" in
0|1)
do_start
case "$?" in
0) log_end_msg 0 ;;
1) log_end_msg 1 ;; # Old process is still running
*) log_end_msg 1 ;; # Failed to start
esac
;;
*)
# Failed to stop
log_end_msg 1
;;
esac
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
exit 3
;;
esac
exit 0mailscanner 스크립트가 작동하도록 심볼릭 링크를 생성합니다:
chmod 755 /etc/init.d/mailscanner
update-rc.d mailscanner defaults
ln -s /opt/MailScanner/bin/Quick.Peek /usr/sbin/Quick.Peek시스템 시작:
/etc/init.d/mailscanner start
/etc/init.d/postfix start로그에서 오류를 확인합니다:
tail -f /var/log/mail.logmail.log를 확인하십시오 (tail –f /var/log/mail.log) 다음과 같은 메시지가 표시되어야 합니다:
Jun 13 12:18:23 hoshi MailScanner[26388]: MailScanner E-Mail Virus Scanner version 4.81.4 starting...축하합니다 - 이제 MailScanner가 MySQL에 로깅되고 있습니다.
새 게시물을 받은 편지함에서 받기
스팸은 없습니다. 언제든지 구독 해지 가능합니다.