メール設定 · 9 min read · Dec 24, 2025
完璧なSpamSnake - Ubuntu Jeos 10.10 Maverick Meerkat - ページ 2
6. Postfixのインストール:
apt-get install postfix postfix-mysql postfix-doc procmail2つの質問がされます。次のように答えてください:
一般的なメール構成のタイプ: –> インターネットサイト
システムメール名: –> server1.example.com
Postfixを停止します:
postfix stop以下のようにPostfixを編集します:
vi master.cfpickupサービスタイプの下に2つの項目を追加する必要があります。pickupサービスはローカルメール(ローカルは「このマシン上」を意味します)を「ピックアップ」して配信します。これは、このマシンによって生成されたメールのコンテンツフィルタリングをバイパスする方法です。
完了すると、次のようになります:
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受信者コールアウト(オプション)
この機能は、受信者サーバーにクエリを実行して受信者が存在するかどうかを確認します。存在しない場合、送信サーバーに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これをsmtpd_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 32bit/64bit設定
.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サーバーから「requests ok」を受け取るはずです。
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
ベイジアン情報を保存するサーバーに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::DCCエラーを防ぐために次のように作成します:
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です。
接続文字列を底に追加します:
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::DomainKeyscronに追加します:
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を実行すると、これらのディレクトリに保存されているベイジアンデータベースがroot:rootに変更され、SpamAssassinがdbを参照する際にエラーが発生します。メールログを監視し、権限を元に戻すことを忘れないでください。また、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にログを記録するようになりました。
新しい投稿を受信箱で受け取る
スパムはありません。いつでも購読を解除できます。