$7.49 .com domain with free InstantPage Website Builder$1.99 Web Hosting   捷飞网络官方淘宝店   Godaddy 优惠码
返回列表 发帖
分享到:




[应用&技术] 分享Qmail常见问题解决办法 [GDLC原创]

1.不能给sina发信 " F; P7 O' F7 I6 V4 ]7 L1 \0 M) F; v
进入qmail/control创建helohost
' Q. f/ `' z/ G7 A/ r. g% Becho serverip > helohost

建议将
5 ]  G" y7 O# G. r) M
不能给sina发信 5 a+ d# J+ T6 [; Q8 G" O4 f
进入qmail/control创建helohost
) e0 ?% ~* P* u! _* n
echo serverip > helohost
; n( h% ]3 |5 ]- Z8 {
修改为给新浪打电话
' \& d. n: _/ H3 e# ~# p9 v
- I& y  c( y5 b& j1 E  y2. |/usr/local/bin/autorespond 10000 5 . d/ b9 @2 i* `
|
表示调用一个程序来处理该邮件这里是调用autorespond来处理;10000表示允许处理信 : u! i/ l$ D) n2 i. u- V
件的总时间;5表示在这段时间内的最大邮件 2 D. M; k% z( p: p9 z* T
3.
限制你的邮件列表被滥用
+ G6 u/ J' [9 o1 j/ E
你需要在邮件列表文件头加入一个过滤程序。一种选择是使用qmail的补丁程序 qlist ,你可以在官方站点qmail.org找到它。它会使用pgp 来标记你的邮件信息,一个包含pgp标识的过滤的邮件列表大致如下:
# |7 A9 r& f' Y9 x$ p|if grep "^-----BEGIN PGP MESSAGE-----$"; then exit 0; else exit 100; fi ( n+ f" a% a! B. j  M6 |' @
|if grep "^-----END PGP MESSAGE-----$"; then exit 0; else exit 100; fi 3 g- _# [/ C- K
|if pgp -f; then exit 0; else exit 100; fi 9 `0 A0 s. J: j" {3 I% c. R
+list 0 l1 |8 O: D! z4 M
&address
7 c8 t5 Q' p! K/ N! c&address
2 c& k* C( X/ ?" D) E/ Q6 ]3 y... 2 X2 A. U$ n; i, `
只有邮件列表允许的用户(假定是别名)才拥有pgp的密钥。或者为需要的用户指定一个密钥文件。另外一种过滤器通过检查邮件,判断是否来自本地用户或者来自最近的qmail-smtpd进程。如果是本地用户就允许通过,远程站点的就退回该信件。它的形式如下: |if grep Received: | tail +1l | grep network; then echo
8 g( Z: S: _9 R4 S5 M$ J) ~"This is a moderated list"; exit 100; fi
9 T* \! O9 U# q+list
: P: {* B) v1 w% J, V% q; M&address : ^7 O6 z0 p# o6 T6 i* p0 f/ V
&address
. F! ~. d6 \# N3 \; m2 d+ P... ' Q# p9 o0 q* {
* k+ C# A8 i$ E0 b. {" i$ f  z
如果不是本地系统的用户,你可以分配一个别名(记得chmod 700 ~alias),使它能投递到邮件列表。运行: + U3 n4 ~$ H; t" U
* c+ g0 U7 F: u$ L# y
|grep -v '^Delivered-To:' | forward LISTNAME 1 X" W4 J$ @- q$ S/ Z& m, s

  T! c8 [8 q( g: B7 q3 q4 o
必须删除 Delivered-To: 这行,否则将它放弃这个别名 * O5 U1 M. Z& Y$ f! Y
4.
如果你不想让一份无法投递的邮件在队列里呆太久
& S5 P% m' t- l
你可以在 queue/info 目录里运行
4 F& l9 e% n0 E1 F. f$ Gtouch -d '1 week ago'
7 [) w6 S; R6 o5 r0 R& d0 I
来结束它的队列生命周期。这样,如果再次投敌不成功,这份邮件就会被退回 . s% o: U& f5 @! I: f
5.
telnet my.domain 25时返回:
1 p, b+ d' ~/ B3 K4 _9 O; L$ ATrying xx.xx.xx.14.....
% m* g8 x$ V$ {( {: @7 X8 a, pConnected to www.xxx.com
. M2 D; g# `5 }! X( u( S" A. z9 @. [Escape character is '^]'.
+ e, w1 d5 a6 B  p8 X8 g220 www.xxx.com ESMTP
1 {8 C0 k6 v  ~4 R502 unimplemented (#5.5.1)
: R7 p6 m8 b' b1 y
此现象是密码验证的包checkpasswd没有装好。 6 n/ |, e0 Y# w' D- [5 @, X0 P
6.
装完qmail后,用本地的信箱或外面的信箱发信过来都显示错误:
8 E. b) a+ P7 ^delivery 12: failure: Sorry,_no_mailbox_here_by_that_name._(#5.1.1)/
没有创建用户的Maildir目录.请记住,创建maildir目录的组和用户权限必须正确
; {+ H; o3 o& W4 f; G1 [7. maillog
里面出现: # \  V% E+ p+ I- }  m
"Unable_to_open_./Maildir:_is_a_directory._(#4.2.1)/"
在修改rc里的./Mailbox 改成 ./Maildir/时出错 + E7 ]% w" {; D: m* b: [" Q' z
8. maillog
里面出现:   m2 X9 ^8 j" D4 p, r
oh:_.qmail_has_file_delivery_but_has_x_bit_set._(#4.7.0)/

" _7 _& i7 `% x% x  g4 w. n.qmail
文件多了个x标志位, 运行chmod a-x .qmail
9 l- _* ]# ^- n& P. `! _5 e
4 k$ u3 D# O8 `6 z9.maillog
里面出现:
! U+ \8 o( {  o4 e7 F8 v2 \"Unable_to_open_./Maildir:_is_a_directory._(#4.2.1)/"
用户的.qmail所在地方不对,此文件必须存在于用户的HOME里面 4 u2 Y4 \7 a6 E- ?' t" _
10
tcpserver執行qmail-smtpd 时默认的为40个进程, 要想修改更多的话,例:200tcpserver -c 200
0 t, P9 R, L; `6 y# S" @% Btcpserver -v -u uid -g gid 0 smtp /var/qmail/bin/qmail-smtpd \   v4 S9 I5 y) T; v' a& Q9 l2 J$ X8 V
2>&1 | /var/qmail/bin/splogger smtpd 3 &
( N3 y, S7 }2 Z$ B) S&
不要省略,
! v3 |' \' e7 F& h9 w( _11
.如何清除90天前的邮件find /home/vpopmail/domains/ -ctime +90 -type f -path '*Maildir/cur*' | xargs -i --verbose rm '{}' 2>&1 1 c1 o& n( v7 f; g8 T3 A
12. Qmail
拒收某个IP或网段的邮件
' T9 j3 A% \, C" e
编辑你的tcp.smtp文件,加入:
  ~: S# W0 _  M
对方的IP:deny 3 {- w% ?1 c* G: G7 k, |$ s
或者: ( T  b& ?  ?3 G3 M* n) p- g; Y
某个网段.:deny & m+ ]: E- Q( b( `% U( V9 ~1 S" X
例:2.82.34.:deny
: C( W; L! R) C# v1 c) k; n, o- {
来禁止2.82.34的整个网段的访问。 8 L8 d: m( e8 m. i) ^/ ?
然后使用tcprules重新生成tcp.smtp.cdb文件。
& L  Z# n/ t5 }3 K8 x13.qmail
自动删除发给系统上不存在的邮件帐号的信,而且不产生系统退信echo'|/var/vpopmail/bin/vdelivermail' 'delete'> /var/vpopmail/domains/yourdomain.com/.qmail-default . ?  @9 j1 w% \- k  W* i* u
这会把发给不存在的用户的信直接删除掉. % X: \  e3 z% H' J
14.
清除qmail的邮件队列
! N0 v& J4 X) m8 c* i9 |5 Y
安装qmail-remove
3 M: u: B/ k- p3 \  Wqmail-remove -r & `; f$ l/ {# K. j$ l4 [3 S" x
这步会把所有队列内容移动到/var/qmail/queue/yanked目录下。
9 }  H/ p3 B, T  _( t: F% j) w
接下来可以决定如何处理该目录的内容了,垃圾邮件 $ T4 x+ V) i8 c' }! ?* _* t
15. Q:
有没有简单的方法可以阻止某些用户发邮件到外部地址 (或内部服务器)?
. T5 M  ]& G* j6 \A:
可以.注意NO_RELAY标志,它可以对任何用户起作用: . P, t; M% V3 N5 B4 ]4 c
vmoduser -r email@domain
  h5 D" a4 @2 ]8 A: dQ:
有没有方法可以拒绝整个域的POP连接,而不单是某个邮件地址?A: 当然.vmodeuser可以帮你解决问题: . n0 Y" u9 w2 m( x- d0 t
! ]9 E6 G" L) b" e0 B
vmoduser -p domain.com 4 ~) S+ l1 c/ A0 J
16.
把一邮件域的名字比如a.com更改为b.com,如何实现
3 t! ^/ e. c) a( F5 L
以下几个步骤:
# w; X4 w2 z- e, `1
cd /home/vpopmail/domains ! d. `% g# W; z, [7 O, P
mv a.com b.com + U* U! {: i6 K3 b, r
2
、把vpopmail数据库的vpopmail表导出把所有a.com改为b.com,然后删除vpopmail表,再导入. 4 V0 f' {& |9 ~# R7 M* \5 }
3
、把把vpopmail数据库的dir_control表的a.com改为b.com
( B/ K  \6 H2 H. Y" n; I, _  V4
、在/home/qmail/control 目录下把 virtualdomainsrcpthosts下的的a.com改为b.com.
2 f, Y4 o9 W+ m5
、在/home/qmail/users目录下把assign文件的a.com改为b.com , s) ]0 b$ k5 e$ x  r
6
、需要运行qmail-newu重新生成cdbassign只是配置文件,cdb才是实际的数据文件。 + s- r( J+ H3 T# f1 K
加快 qmail 投递邮件速度
9 E# o3 }% c: n# l  x17. spamd
调用maildrop方法
- V8 u7 X( v  U" J) l1 S
youreal.com下修改.qmail-default
: c. V& S" q5 Y: i
: " Z5 d6 H  T9 `% _. N
| /usr/local/bin/maildrop ./.mailfilter
! }: F! s$ ?9 f! h" a* [% @; ?. D) m
创建.mailfilter
; q7 P3 ?4 }/ H* m  b
内容如下: & V3 X. y9 q/ o: w5 c3 A
VHOME=`/var/qmail/vpopmail/bin/vuserinfo -d $EXT@youreal.com`
9 g7 ]/ H1 P, K1 ]/ _4 j, f) `/ b! `7 e# s% l" n2 z) V6 `4 Q
if ( $SIZE < 262144 ) 6 i; P; {0 o* ~+ I
{
: D! t/ R& k% @6 Gexception { % a9 g0 a" w4 w
xfilter "/usr/bin/spamc -f -u $EXT@youreal.com" 4 v3 a5 a2 ]$ g8 o* k: \
}
! F/ c- Z2 Z4 A/ c" ]2 v} 8 X, ?( v" C6 ]2 |' B
" e  Y5 Q# C2 ^6 Q' z! t) @" o  h
if (/^X-Spam-Flag: *YES/) ! ]  q+ e! S9 T& E' _" H/ D
{ . k# i3 ]0 J6 n, O3 W# B9 A0 ]; S

0 d* m+ B8 U- p. v: V/ l- e" J  R7 G6 p, `9 [# w& z
2 w4 X; L# s0 ]4 z2 w4 I/ D
to "$VHOME/Maildir/.Trash/" ##
使符合垃圾邮件特征的邮件放到垃圾箱里
' J7 Z* }  f. R+ Y  o- w
; ]) k! f7 F$ r/ y9 P* W} , i+ P- M4 k6 Y+ Q8 J
else
7 D6 w( Y6 F3 p- y8 w$ x; `  V: M{ ) [. {  X8 F/ ~. B8 C
exception {
! s" d' e) F- X+ J$ A& uto "$VHOME/Maildir/." ! [6 P. J* K- e: F: z
} ; z6 }- A- e+ m" m! E3 t% k
修改.mailfilter的属性
' B- m- h2 p2 ?. G' Vchown vpopmail:vchkpw .mailfilter
0 l# @8 Q  M& o* p8 Y4 c. f- Ichmod 600 .mailfilter 2 K$ H2 D7 q* Q3 X7 G4 R

9 P; q0 ^* @" F* q% oqmail
控制文件的作用 6 {" h$ V/ R' B. x
qmail-inject

  `( k1 [" w' Sqmail-inject
接受本地邮件消息后检测邮件头是否符合RFC822标准,并传送给qmail-queue排进队列
; W. h) x: m  H7 ~/ x( Y/ gdefaultdomain
用来向那些没有使用正确的username@hostname.domain格式的邮件中增加邮件地址的,默认情况下,如果主机地址中没有结束符"."qmail-inject将给主机名后添加defaultdomain的内容,如果该文件不存在,将使用me文件中的值代替.例如: defaultdomain值为yourdomain.com本地产生了一封发送给xxxx@xxxx的邮件,那么qmail-inject将用 yourdomain.com来补全这个后缀,变成xxxx@xxxx.yourdomain.com
* I( D4 `4 O7 J$ K* jdefaulthost
用来定义主机名,用来向地址中不含主机名的邮件补足邮件地址的。类似于defaultdomain。例如:defaulthost值为yourdomain.com那么发送给 xxxx的消息,将被qmail-injectdefaulthost的值来补足为xxxx@yourdomain.com,以便于qmail- send快速分辨是否属于本地地址。 ) T: g, X, a+ v; q7 \" `' ~2 r0 J6 x
idhost
用来指定邮件中Message-ID:头字段的主机名例如:idhost值为yourdomain.com那么邮件头中如下:
" z% A% I) O* i( @9 ~6 z! _4 _Message-ID:<1234567890.12345.qmail@yourdomain.com>
1 F4 C5 f/ A# k& Y, S! P5 T( I& ~8 F
如果idhost值为xxxx.yourdomain.com 那么邮件头中如下:
- L  {6 |7 k$ k$ W& W: AMessage-ID:<1234567890.12345.qmail@xxxx.yourdomain.com>
& [, d9 t5 P" G& Oplusdomain
8 I  k" ], x& V  Q( S8 W* m9 x
用来将其值添加在任何一个以一个+号结尾的地址 4 s( Z2 X. ]" e- E8 _& _3 W
qmail-qmqpc qmail-qmqpc
是快速邮件排队协议(QMQP)使用的程序,QMQP是一个QMAIL专用协议,用在工作站级QMAIL服务器向中心服务器发送队列。
8 }0 {0 j. h. w% b  Zqmqpservers
用来指定qmail-qmqpc使用的上级服务器
/ X8 ?5 m+ r0 q. c
通常该功能应用很少,我认为qmail-qmqpc用法就是代替qmail-queue来直接传给上级服务器。
( K& P+ {9 {5 T: ]! Qqmail-remote
' K* a. S, C) b" {( sqmail-remote
通过SMTP协议向远程主机传送邮件。
2 C7 s: C  @' `! J; A; W) I( u# l2 Shelohost
该文件用来指定qmail-remote程序与远程邮件主机SMTP会话中的主机名。
' }* h7 m* N$ s4 _$ t$ Usmtproutes
用来指定到固定目的的静态SMTP路线。 $ U; Y4 c+ y6 R* P' \
例子:smtproutes内容如下
5 z) D. _, I) u6 n" E, c9 Y; uxxxx.yourdomain.com:mail8.xxxx.jp 7 n) P0 x; |- Q. H
:fw.xxxx.yourdomain.com:8088 8 C5 l* B9 X* p
第一行的存在会将发给xxxx.yourdomain.com的邮件重定向到mail8.xxxx.jp主机   F" j% W& o- T; T& _- x8 ~* W6 t5 g
第二行的存在会将任何不符合之前行条件的邮件重定向到fw.xxxx.yourdomain.com8088端口,让邮件安全的穿越防火墙
# X7 [% t3 |- r! [; N* ^/ Mqmmail-remote
将按照smtproutes中的行序来进行处理 0 s! s3 Q- P# N" @) K" Z
timeoutconnect
用来指定qmail-remote尝试同一个远程邮件主机建立一个SMTP会话的时间。默认值状态下如果超出60秒没有得到远程邮件主机的回应,那么将断开连接。 " e4 ^6 l2 N7 n' W3 b
timeoutremote
用来指定qmail-remote在一个SMTP连接已经建立后,远程邮件主机的每一个回应的时间数。默认值为1200秒。 # z# i- @( f7 e5 ^& ~

0 I! A" e9 B% R) ^0 k3 r5 J$ ^qmail-send

. b) p, y( e& Uqmail-send
用来检测队列中每一个邮件的状态,并调用相应的程序进行处理。例如一个目的为本地的邮件将会被qmail-send调用qmail-lspawn处理。
+ {- G0 V! R/ k9 U0 lbouncefrom | bouncehost
默认情况下,退回给原始发送方的邮件的发件人地址为MAILER-DAEMON@HOSTNAME,如果你想修改MAILER-DAEMON这段,那么就修改bouncefrom文件吧。如果想修改MAILER-DAEMON@HOSTNAMEHOSTNAME这段,那么就修改bouncehost文件。例如:bouncefrom内容为SERVER-MANAGER | bouncehost文件内容为mail8.xxxx.jp那么一封因为邮件地址不存在而被退回的通知邮件的发件人将是 SERVER-MANAGER@mail8.xxxx.jp $ |2 V' R* U1 k3 c. p- J3 C( X
concurrencylocal
用来决定qmail可以同时运行的本地投递进程的数目,默认值是10,标准安装的qmail最大可设值是120。安装的时候可以通过修改conf-spawn来将其变为255以下任何数目。
) }" J% Q$ g: b2 {& X2 tconcurrencyremote
用来决定qmail可以同时运行的远程投递进程的数目,默认值是20,就是说,qmail可以在同一时间内同时发送20封邮件,标准安装的qmail最大可设值是120。安装的时候可以通过修改conf-spawn来将其变为255以下任何数目。 " J7 o% C4 H' k1 X  ~6 l; g2 E
doublebouncehost | doublebounceto
这两个控制文件类似于bouncefrombouncehost的关系,也是doublebouncehost指定主机名,doublebounceto指定用户名。 3 x# Q2 S+ e- d: [/ R. i
他们的功能是为一个被退回两次的邮件制定一条出路。例如:doublebouncehost内容为xxxx.yourdomain.com | doublebounceto内容为xxxx那么一个被退回2次的邮件将被发送给xxxx@xxxx.yourdomain.com
: @* h3 Z5 D( @
没有这两个文件的时候,那么发送给postmaster@me文件中的域名 . I& J0 O' H) X. \) B( V& j
envnoathost
! a& }$ ]* d& n, ^# Sqmail-send
用来给没有主机名的邮件收件人制定一个主机名的,通常这个文件并没有必要,qmail-send总是使用me文件中的域名。 . n4 l  N+ K4 S/ b, U, [
locals
( t$ b# V* u" v9 ]* }: I
用来为qmail指明位于本地的邮件地址。qmail-send利用此文件来判断收件人地址是否是一个本地地址。
4 u" H! O5 _  i, S4 P
例如:locals文件中写有xxxx.yourdomain.com 9 M# A9 z8 T% }2 C
那么qmail-send检测到队列中有发送给@xxxx.yourdomain.com的邮件的时候,就会调用qmail-lspawn来进行本地投送。
$ ^/ |" q: K- o* V9 Lme
如果没有me文件,那么你的qmail将拒绝执行。me文件用来指定本地邮件服务器的主机名。以上列出的许多控制文件在没有被创建的时候,qmail都会用me中的值来代替。   X* v5 g  R. Q, k4 @% _1 `  I: H
percenthack
UUCP协议中带有%并在该文件中列出的地址将会被转换为一个标准的DNS格式主机名。
# Z& j6 I" C! P. O+ V4 Rqueuelifetime
用来指定一个邮件在队列中的最大存活时间,默认是604800秒,当一个邮件达到这个时间线后,qmail将最后一次尝试发送这封邮件,如果依然失败,会将其从队列中删除。
0 u" h/ G; j6 f' T! H, z; ^( _- U% wvirtualdomains   c# M: c% h, b! ^$ q: h% x
qmail接受本地邮件以外,还接受该文件中指定的域或者邮件地址,就是常说的虚拟域支持。
0 F1 f5 q; A3 D8 y8 {qmail-smtpd / H$ p$ H$ `& V2 K4 O. G
qmail-smtpd
接受远程主机的邮件并转交给队列处理程序qmail-queue来处理。 ' t* x' K+ L# R) p
badmailfrom
用来指定不喜欢的发件人的邮件地址或者是域名 ! p1 X( R: ~1 n/ j: |9 E% [
例如:badmailfrom中写有 ; w* ~) f5 t- d+ p
advt@msn.com
) X: s: B* {6 m$ p9 p; Q@hotmail.com
0 ]1 e  ^6 b% N5 c( D
如果advt@msn.com给该邮件主机送信时,将得到code 553,告知其是一个不受欢迎的发件人。而所有来自hotmail.com的发件人也将得到同样的code 5533 K, c0 Q: m# M- I2 \
databytes
用来指定该邮件服务器可以接受邮件的最大字节数。
0 Z3 m2 a# n3 s: Q
例如:databytes指定为8000000
- E, A5 F& H# ?* _/ ~7 ^; i5 p% n
那么如果有人给该主机发送的邮件字节数超过了这个商业上默认的最大容忍限度,将得到code 552,告知其邮件大小超出了该邮件主机所能容忍的限度。恐怖的是,默认状态下,这个文件并没有,如果有人用你服务器上的两个不存在的地址作为 FROM/TO发一个100M的邮件 . r1 p, }2 P! j9 K8 L: ?: B: D
localiphost
/ m, S0 G# w: \7 u8 A% l6 c: B
用来为使用ip来标示目的主机的邮件消息指定本地主机名的例如:xxxx.yourdomain.comip地址为198.17.1.2 | localiphost内容为xxxx.yourdomain.com那么一封发送给xxxx@[198.17.1.2]的邮件的地址会被转换为 xxxx@xxxx.yourdomain.com & ~3 O6 q: O1 b4 q8 V  X
rcpthosts | morercpthosts
" ?7 b( b/ k8 q) F& s
这两个文件用来指定qmail可以接收的除本地主机名外的其他域名他们的作用是相同的,不过因为rcpthosts中的域名不能超过50行,所以才出现了morercpthosts文件 5 y/ Q' x1 y1 w/ T* Q2 k; d8 M
timeoutsmtpd
用来指定qmail-smtpd等待远程SMTP主机发送数据的时间线。默认的情况下,如果连接建立后1200秒内没有接受到远程SMTP主机的任何信息,那么将关闭这个连接。 / {5 g  [6 n9 a) p
smtpgreeting
用来指定SMTP连接的欢迎标志
! d. ~4 e' \8 ^: K" U$ x! x
例如:smtpgreeting值为 welcome connect to out open relay mail server - ad.xxxx.yourdomain.com那么建立一个smtp连接的时候将会看到如下信息:
" x1 d) n' v. h$ \  PTrying 198.17.x.x... . |, P# G4 Y8 e9 a
Connected to ad.xxxx.yourdomain.com.
( B7 L. H& {: ~3 q- _Escape characteris ^]. - t. Q* Z: v, c  H! ]
220 welcome connect to out open relay mail server - ad.xxxx.yourdomain.com ESMTP ; G$ }  A3 H4 z; \7 V: E3 k* ?
delivery 1: deferral: Uh-oh:_home_directory_is_writable._(#4.7.0)/
% V* t& o7 z! z8 n+ WIt's actually pretty clear: qmail refuses to deliver mail to that account 2 _. ~/ Y" F" U* g$ H! k
because its home directory is world-writable, because that's a security risk.
4 Q. ^; A( M$ S8 g/ n9 j' W& ~2 d% j; |: N8 ?
Remove the world-writable permissions on the user's home directory

qmail中的几个error的产生的原因和解决方法 0 J8 O( F' m8 `- H# L* g# Z
wd | 14
十二月, 2004 10:18
' L! m, X# V5 [4 h* s& W, m9 Z  q
1 deferral: Unable_to_chdir_to_maildir._(#4.2.1)
# ?' {# I7 k9 z/ s' U
* K" P6 h& s( Y% b7 |$ k! ]
这个是qmail找不到用户的收信目录所致。如果你是用vpopmail的虚拟域名来管理的,那看看你的control/locals文件,里面不能有虚拟域名,只能有实际域名(这个实际域名的意思应该是使用系统用户作为用户的域,而不是使用vpopmail的虚拟用户的域)。因此呢,如果不是用 vpopmail,那么可能是系统用户的目录权限设置不正确。
5 I" d' b& u7 N% Z
8 V! j. j% J- n
如果发生这个错误,首先保证你没有对user/assign做过手动修改,添加域名都是使用vpopmailvadddomin命令来添加的,没有修改过~vopmail/domins目录以及其下面目录的权限和属主,然后修改了locals文件之后重启应该就没有问题了。 8 [5 g- @3 |/ _$ x
7 ^+ [: [. B2 b3 v
2 deferral: Uh-oh:_.qmail_has_prog_delivery_but_has_x_bit_set._(#4.7.0) 8 g, I! V- _+ R) X2 _2 N

) d) O2 B+ P3 n6 X$ s4 r; u+ F
这个是因为你的.qmail文件设置了x属性,把.qmail文件的x去掉就ok了。这个.qmail文件就在你的domins/xxx.com下面,包括比如.qmail-default之类的文件,修改一下权限,去掉xok了。 * M1 F$ U" l- R: ?( B4 n5 P; Z* V
/ D) K/ w/ ~; S
3 454 oops, unable to write pipe and I can't auth (#4.3.0)
+ L0 V" n; c7 Z' a: \+ x1 t, l( v" s) q( I. C+ [
这个错误是在你打了smtp auth的补丁之后,却发现不能正常auth,输入了正确的用户名密码还是提示不正确。可以通过下面的命令来测试。
, |( x1 c% f% p, q4 d- \$ v+ r* _. o0 L& Z2 o+ D5 N$ V1 V) z
[root@caph qmail-smtpd]# telnet localhost 25
9 U% c. A) X. |, {2 f; f2 o0 E1 NTrying 127.0.0.1... . m$ W) H9 x  d9 m$ z
Connected to localhost.
5 M+ D" Z' ~* g4 S' AEscape character is '^]'. $ S( b  |& h8 _- [/ F8 f/ v% K9 y
220 xxx.com ESMTP
- f1 B; m0 s( v0 yehlo - R! \5 N+ o, j2 |. `
250-xxx.com 4 k3 @. S5 B/ k' r! ^  o7 m! O
250-PIPELINING
/ T% s8 ^2 J/ ]/ K9 |5 p250-8BITMIME $ y9 ]2 n2 y9 {) @( _" t
250-SIZE 104857600 ) s4 E6 x1 o4 |$ t
250 AUTH LOGIN PLAIN CRAM-MD5 //
显示这个通常表示你已经打好了补丁,不过这个是可以通过修改qmail-smtp.c文件来定制的。
4 ]2 b7 t+ b5 Aauth login 1 Z& s' e# v: |6 q5 r6 k
334 VXNlcm5hbWU6 6 P5 p# K/ v. J$ ?  S6 b) {* p
awefaq23rasdf & f" B0 r1 a" |- ~3 ^/ f- [
334 UGFzc3dvcmQ6 & S0 h% C" X- y+ d# x
awefwaef
& j5 Y1 R) m# k( x  l; S454 oops, unable to write pipe and I can't auth (#4.3.0) 7 A# ~$ P( T% w: p: S% F' r* d) M
quit
: c. m  w% u5 _221 xxx.com 7 `! l) G4 L4 ]- ~& H4 K
Connection closed by foreign host.
9 Q3 C2 V( M+ g
1 t' p( D, D8 T1 W  F  g# D* M
出现了这种问题是因为smtp运行脚本没有设置正确的用户所致。将你的smtptcpserver命令的运行用户和组指定一下。 , R, k9 @  X! u

( O8 X8 F5 S& V3 Y" |QMAILDUID=`id -u vpopmail` : J( z* d) s& f: s: f8 q: t) `! P2 F
QMAILDGID=`id -g vpopmail`
; J( b% `! J8 S) G' |4 t# g' C) @. s8 x
/usr/local/bin/tcpserver -v -H -R -l "$LOCAL" -x /etc/tcp.smtp.cdb -c "$MAXSMTPD"
& M# P1 ^( a! q5 u" r6 p; K-u "$QMAILDUID" -g "$QMAILDGID" 0 smtp /usr/local/bin/rblsmtpd -r relays.ordb.org 4 n. n7 e, {6 K2 u
/var/qmail/bin/qmail-smtpd 8 a8 e/ ~: @; V6 I) o7 a
/home/vpopmail/bin/vchkpw /bin/true /bin/cmd5checkpw /bin/true 2>&1 & {9 p+ b- @- R; S' ^6 K& B, n

  ]; m0 O, Q$ j+ _+ }+ U; B3 O! {
不需要修改~vpopmail/bin/vchkpw的属性。
, y' J0 t$ V3 C$ _7 f( _( J4 r0 d& D* n$ C( U( F  b
4 451 qq write error or disk full (#4.3.0) ' b* @- e2 S) R

3 e$ o& L8 H! T. I* a' P, X3 v
通常产生这个可能有2个原因:(1)你的qmail queue所在的磁盘空间不足。(2qmail-queue的权限设置不正确或者文件有问题。

参考: http://blog.chinaunix.net/uid-7351136-id-2058434.html





返回列表
Namecheap
Namecheap.com - Cheap domain name registration, renewal and transfers - Free SSL Certificates - Web Hosting
互联网安全