• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • 我的qmail安裝經歷,希望對大家有個幫助

    發表于:2007-05-25來源:作者:點擊數: 標簽:
    安裝qmail(首先確保DNS是配置好的) 軟件準備: qmail-1.03.tar.gz ucspi-tcp-0.88.tar daemontools-0.76.tar.gz qmail-103.patch checkpassword-0.90.tar 1安裝qmail: [root@email/usr/local/src]#gzip-dqmail-1.03.tar.gz [root@email/usr/local/src]#tarxf

    安裝qmail(首先確保DNS是配置好的)
       軟件準備:
           qmail-1.03.tar.gz
           ucspi-tcp-0.88.tar
           daemontools-0.76.tar.gz
           qmail-103.patch
           checkpassword-0.90.tar
    1>安裝qmail:
           [root@email /usr/local/src]# gzip -d qmail-1.03.tar.gz

           [root@email /usr/local/src]# tar xf qmail-1.03.tar

           [root@email /usr/local/src]# cd qmail-1.03


           對qmail打補丁(需將.patch文件拷到qmail目錄下)

            [root@email /usr/local/src/qmail-1.03]# patch –p1 < qmail-103.patch(是p壹)
           創建qmail主目錄及添加必須的系統用戶
           由于qmail不是以root身份運行,而且qmail是同時由多個程序處理不同的工作,如接收郵件,發送郵件,本地投遞等等,                                          所以需要多個用戶身份:

          # mkdir /var/qmail

          [root@email /]# /usr/sbin/groupadd nofiles

          [root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail/alias -s /bin/false alias 

          [root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmaild

          [root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmaill

          [root@email /]# /usr/sbin/useradd -g nofiles -d /var/qmail -s /bin/false qmailp

          [root@email /]# /usr/sbin/groupadd qmail

          [root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmailq

          [root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmailr

          [root@email /]# /usr/sbin/useradd -g qmail -d /var/qmail -s /bin/false qmails

          編譯 

          [root@email /usr/local/src/qmail-1.03]# make setup check

          這個命令將會完成所有的編譯工作,生成所有的二進制程序,并將其拷貝到相應的目錄,缺省qmail是安裝在/var/qmail目       錄下。

    2>安裝daemontools-0.76.tar.gz

          [root@mail src]# tar xvfz daemontools-0.76.tar.gz
          [root@mail src]# cd admin
          [root@mail src]# cd daemontools-0.76

          [root@maildaemontools-0.76]# package/install

          即可實現daemontools的安裝。

    3> qmail配置
          qmail編譯成功以后就應該開始對其進行配置,最簡單的實現配置的方法是使用命令config:

          [root@mail qmail-1.03]# ./config

          config程序將試圖對本地地址進行反向解析,以確定本機域名;若反向解析失敗,則配置也就失敗??梢詤⒖?nbsp;      INSTALL.ctl文件內容。也可以在運行config程序時指定本機域名信息:
    用以下命令來增加域名
          [root@mail qmail-1.03]# ./config-fast your.full.host.name

          若你的主機有若干個域名,并且多個域的MX記錄也指向該主機,則你就需要編輯/var/qmail/control/目錄下的文件locals和       rcpthosts,在其中加入多個域名,例如本機器具有域名email.secfocus.com和email.secfocus.net,并且這兩個域的MX記錄分別指向email.secfocus.com和email.secfocus.net。則locals中應該具有如下內容:

          localhost
          email.secfocus.com
          secfocus.com 
          email.secfocus.net
          secffocus.net

          而文件rcpthosts具有以下內容:

          localhost 
          email.secfocus.com
          secfocus.com
          email.secfocus.net 
          secfocus.net

          下一步 需要對某些不能接收郵件的系統帳戶添加別名:

          [root@mail /usr/local/src/qmail-1.03]# cd /var/qmail/alias
          [root@mail /var/qmail/alias]# echo adam > .qmail-root
          [root@mail /var/qmail/alias]# echo bob > .qmail-postmaster
          [root@mail /var/qmail/alias]# echo bob > .qmail-mailer-daemon

    這里的bob或adam是系統管理員的普通用戶帳號。qmail在接收到一個發給用戶user1的信件,qmail-local則首先尋找名為user1的用戶,若沒有找到,qmail-local將去查詢是否有名字為user1的別名用戶,若有則發信給user1對應的真正用戶。其中別名是通過在/var/qmail/alias中定義的,[root@mail ideal]$echo ./Maildir/ >/home/ideal/.qmail


    4>.設置daemontools 


    (這一步的所有要建的文件夾及文件都在web-file/qmail下的supervise)

    下面設置當系統啟動時自動啟動qmail。這里要使用daemontool里面的svcan工具,這些第三方的工具的使用和含義參見附錄A。按照前面的步驟,現在daemontools應該已經安裝在/usr/local/bin目錄下。 

    首先,需要創建daemontools服務工作目錄,該工具的作者推薦/service,這里我們就使用缺省目錄: 

    [root@email /]# mkdir /service 
    [root@email /]# mkdir /var/qmail/supervise 
    [root@email /]# mkdir /var/qmail/supervise/qmail-send 
    [root@email /]# chmod +t /var/qmail/supervise/qmail-send 
    [root@email /]# mkdir /var/qmail/supervise/qmail-send/log 
    [root@email /]# mkdir /var/qmail/supervise/qmail-smtpd 
    [root@email /]# chmod +t /var/qmail/supervise/qmail-smtpd 
    [root@email /]# mkdir /var/qmail/supervise/qmail-smtpd/log 
    [root@email /]# mkdir /var/log/qmail 
    [root@email /]# mkdir /var/log/qmail/qmail-send 
    [root@email /]# mkdir /var/log/qmail/qmail-smtpd 
    [root@email /]# chown qmaill /var/log/qmail 
    [root@email /]# chown qmaill /var/log/qmail/* 
    下來,需要創建/var/qmail/supervise目錄下的內容: 

    [root@mail rc5.d]# cd /var/qmail/supervise/qmail-send 

    在該目錄下創建名為run的script內容如下: 

    #!/bin/bash 
    exec /var/qmail/rc 

    在目錄/var/qmail/supervise/qmail-send/log下創建run文件,內容如下: 

    #!/bin/bash 
    exec /usr/local/bin/setuidgid qmaill /usr/local/bin/multilog t 
    s2500000 /var/log/qmail/qmail-send 

    在目錄/var/qmail/supervise/qmail-mtpd下創建run文件,內容如下: 

    #!/bin/sh 

    QMAILDUID=`id -u qmaild` 
    NOFILESGID=`id -g qmaild` 
    exec /usr/local/bin/softlimit -m 2000000 
    /usr/local/bin/tcpserver -v -p -x /etc/tcp.smtp.cdb 
    -u $QMAILDUID -g $NOFILESGID 0 smtp /var/qmail/bin/qmail-smtpd 
    2>&1 

    在目錄/var/qmail/supervise/qmail-smtpd/log/下創建run文件,內容如下: 

    #!/bin/bash 
    /usr/local/bin/setuidgid qmaill /usr/local/bin/multilog t 
    s2500000 /var/log/qmtpd 

    將這幾個script的屬性均修改為可執行: 

    [root@mail /]# chmod +x run
    由于svscan的工作方式,我們這里不在/service內創建真正的目錄,而是創建符號連接/var/qmail/supervise下的真正目錄。
    5>啟動qmail
       拷貝/var/qmail/boo/home 到/var/qmail/rc
     chmod +x rc 

    之后就需要在/service下創建到/var/qmail/supervise下各個目錄的的符號鏈接 

    [root@mail qmail]# ln -s /var/qmail/supervise/* /service/

    6>安裝ucspi-tcp和mysql
    ucspi-tcp-0.88.tar.gz
    MySQL-3.22.32-1.i386.rpm
    MySQL-client-3.22.32-1.i386.rpm
    MySQL-share-3.22.32-1.i386.rpm
    MySQL-devel-3.22.32-1.i386.rpm
    安裝ucspi-tcp
     make 
     make setup check
    安裝mysql
    rpm –ivh 各個軟件包
    后啟動mysql
    mysql –u root mysql
     >update user set password=password(‘你希望得密碼’) where user=’root’;
    后重啟機器。
    7>安裝vpopmail
    vpopmail-4.9.8-1.tar.gz 或 vpopmail-5.2.tar.gz
    (sqwebmail-3.x以上要安裝vpopmail-5.2.tar.gz,安裝過程是一樣得。)
    首先安裝好ucspi-tcp
    編輯/etc下得tcp.smtp文件如下:
      127.0.0.1:allow,RELCYCLIENT=””
    192.168.0.:allow,RELCYCLIENT=””
    :allow
    第一步:修改文件/usr/src/vpopmail-4.9.4/vmysql.h,修改 

    /* Edit to match your set up */ 
    #define MYSQL_SERVER "localhost" 
    #define MYSQL_USER "root" 
    #define MYSQL_PASSWD "passwoerd" 
    /* End of setup section*/ 

    中mysql服務器的地址,若你的mysql服務器存放在其他機器上,則將localhost修改為你的mysql服務器的ip地址;若你希望使用其他具有對數據庫讀寫及創建庫和表格的用戶來訪問數據庫,則將root為你希望的用戶名;將passwoerd修改為你的mysql數據庫對應的訪問密碼。 

    拷貝//usr/local/lib/mysql下的所有內容到/lib/中 

    第二步:創建需要的用戶和組: 

    /usr/sbin/groupadd vchkpw 
    /usr/sbin/useradd -g vchkpw vpopmail 

    第三步:配置編輯vpopmail: 

    ./configure --enable-roaming-users=y --enable-hardquota=10000000   (這里如是高版本的是delfaulquota
    --enable-default-domain=secfocus.com --enable-mysql=y 
    --enable-sqlincdir=/usr/local/include/mysql/ 
    --enable-sqllibdir=/usr/local/lib/mysql 
    --enable-ucspi-dir=../ucspi-tcp-0.88 --enable-passwd=n 
    (注:以上全為一行) 
    make 
    make install 

    第四步:添加虛擬域 
    /home/vpopmail/bin/vadddomain domain1.com 
    /home/vpopmail/bin/vaddaliasdomain domain2.com

    8>設置pop3及smtp

          首先安裝checkpassword 和ucspi-tcp
    在/etc/xinetd.d 目錄下建立pop-3和smtp如下。
    cat > smtp
    service smtp
    {
            socket_type      =stream
    protocol        =tcp
    wait            =no
    user           =qmaild
    server       =/var/qmail/bin/qmail-smtpd
    server_args = 2>&1 | /var/qmail/bin/splogger smtpd 3& / 
            disable  =no
      }
    #cat > pop-3
     service pop-3
     {
            socket_type  =stream
            protocol    =tcp
            wait        =no
            user       =root
            server     =/var/qmail/bin/qmail-popup
     server_args  = abc.com  home/vpopmail/bin/vchkpw /var/qmail/bin/qmail-pop3d Maildir &      
    這時候從客戶端使用outlook express等MUA軟件,應該可以收到剛才測試所發送的郵 件。(有時你的pop-3會出現在本機上起來了,而在遠程起不來,就請停掉iptables/ipchains. 

    9>刪除sendmail
    #> killall –9 sendmail
     #> mv /usr/lib/sendmail /usr/lib/sendmail.old
     #> mv /usr/sbin/sendmail /usr/sbin/sendmail.old
     #> ln –s /var/qmail/bin/sendmail /usr/lib/sendmail
     #> ln –s /var/qmail/bin/sendmail /usr/sbin/sendmail

    10>安裝sqwebmail
    sqwebmail-3.3.7.tar.gz

    如你安裝的是sqwebmail-5.2的版本在/home/vpopmail/etc/目錄下不會有inc_deps  lib_deps這兩個文件。則需建立這兩個文件。內容如下:
    inc_deps的內容如下:
    -I/home/vpopmail/include
    ~
    lib_deps的內容如下:
    -L/home/vpopmail/lib -lvpopmail
    (如不建的話./configure 時會出錯喲)
    設置環境變量(加在root得.bash_profile下)
    INCS=-I/usr/include/mysql 
    export INCS 
    LIBS="-L/usr/lib/mysql -lmysqlclient -lz" 
    export LIBS 
    CPPFLAGS=-I/usr/include/mysql 
    LDFLAGS=-L/usr/lib/mysql 
    export CPPFLAGS 
    export LDFLAGS 
    安裝:
    ./configure --with-cachedir --without-gzip --enable-webpass=yes 
    --enable-softtimeout=300 --enable-autopurge=180 --enable-maxpurge=180 
    --with-htmllibdir=/var/www/sqwebmail --enable-cgibindir=/var/www/cgi-bin  
    --enable-imagedir=/var/www/images/sqwebmail 
    --enableimageurl=/images/sqwebmail/ 
    --enable-mimecharset=gb2312 --with-maxargsize=5000000 
    --with-maxformargsize=5000000 --with-maxmsgsize=5000000 --without-ispell 
    --with-authshadow --with-authmysql --with-authldap --with-authuserdb 
    --with-authpwd --without-authpam --with-authvchkpw --without-authdaemon 
    (以上全為一行,建議不要設置所有得images路徑)
    make
    configure-check
    make
    make check
    make install-strip
    make install-configure 

    打開瀏覽器,http://xxx.xxx.xxx.xxx/cgi-bin/sqwebmail 
    輸入用戶名、口令,OK!(系統用戶直接輸入用戶名、虛擬域用戶輸入Email地址:user@domain.com) 

    11>安裝vqsignup(自動注冊軟件)
    (注意:以下所有得權限設置都在移動完成后在目標文件夾中做)
    1.首先下載vqsignup-0.4.tar.gz軟件包,解開。
    2.進入源代碼目錄,編輯Makefile文件。
    指定vpopmail所帶的頭文件include目錄。如:
           FLAGS=-I/home/vpopmail/include
           同時指定vpopmail的庫文件目錄,以及libypopmail.a 和 libcrypt.a這兩個庫文件。
           如:
         $(CC) $(FLAGS) -o $(BIN) $(OBJS) -L/home/vpopmail/lib -lvpopmail -lcrypt
           正保存所作改動后,編譯源代碼。
           make
    3.將生成的vqsignup.cgi拷貝到cgi-bin目錄下,并且改變其的權限:
    cp   vqsignup.cgi   /home/httpd/cgi-bin
           chown vpopmail vqsignup.cgi
           chgrp vchkpw vqsignup.cgi
           設置vqsignup 的 setuid 位,
           chmod ug+s vqsignup.cgi
         4.將vqsignup.conf拷貝到cgi-bin目錄下,并且  
            chmod ugo+r vqsignup.conf
         5.將vqsignup_html目錄拷貝到cgi-bin目錄下,并且
            chmod  ugo+r vqsignup_html
         6. 將vqsignup.html拷貝到/home/httpd/html目錄下,并且
            chmod  ugo+r vqsignup.html
    7.在cgi-bin目錄下編輯vqsignup.conf文件,在”add_domain”一行中更新為所指定
           的虛擬域,如:
           add_domain ssw.com     
           add_domain unix.xom    
       在"result_*"寫上所有html文件的絕對路徑,如:
           result_error /home/httpd/cgi-bin/vqsignup_html/error.html            
           result_failed_user /home/httpd/cgi-bin/vqsignup_html/failed-user.html
           result_failed_pass /home/httpd/cgi-bin/vqsignup_html/failed-pass.html
           result_failed_domain /home/httpd/cgi-bin/vqsignup_html/failed-domain.
           result_fields /home/httpd/cgi-bin/vqsignup_html/fields.html          
           result_domain /home/httpd/cgi-bin/vqsignup_html/domain.html          
           result_suclearcase/" target="_blank" >ccess /home/httpd/cgi-bin/vqsignup_html/success.html        
         8.在vqsignup_html目錄中編輯每一個html文件,更新為郵件服務所支持的一些虛
           擬域名 
         9.在/home/httpd/html目錄在編輯vqsignup.html文件,更新為郵件服務器所支持的一
           些虛擬域名。g
         10.進行測試
            在IE瀏覽器中鍵入http://你的服務器/vqsignup.html就可以用戶自己提交并完成郵
            箱的建立。


    漢化我是對html頁面進行漢化,中文亂碼我是用我說的vbscrip來處理的。其它的我沒有考慮,所以我做的不是很好,請大蝦們給我點建議。

    還有,
    www.hleil.com是一個不錯的qmail技術論壇,上面有幾個牛人!

     zlzj2010 回復于:2003-08-12 11:44:21
    忘了一點,測試你的郵件服務器的例子,假設我的地址時10.0.0.222,域名時:abc.net  用戶時,hello,密碼時hello,hello的base64編碼是:aGVsbG8=
    smtp測試:
    $ telnet 10.0.0.222 25  
    Trying 10.0.0.222...
    Connected to 10.0.0.222 (10.0.0.222).
    Escape character is '^]'.
    220 abc.net  ESMTP
    ehlo                    
    250-abc.net
    250-AUTH LOGIN CRAM-MD5 PLAIN
    250-AUTH=LOGIN CRAM-MD5 PLAIN
    250-PIPELINING
    250 8BITMIME
    auth login
    334 VXNlcm5hbWU6
    aGVsbG8=
    334 UGFzc3dvcmQ6
    aGVsbG8=
    235 ok, go ahead (#2.0.0)
    mail from hello@abc.net
    250 ok
    rcpt to:hello@abc.net
    250 ok
    data
    354 go ahead
    asdf
    asdf
    asdf
    .
    250 ok 1060659046 qp 22272
    quit
    221 abc.net
    Connection closed by foreign host.

    pop3測試:

    $ telnet 10.0.0.222 110
    Trying 10.0.0.222...
    Connected to 10.0.0.222 (10.0.0.222).
    Escape character is '^]'.
    +OK <22309.1060659271@abc.net>
    user hello
    +OK
    pass hello
    +OK
    list
    +OK
    1 231
    .
    retr 1
    +OK
    Return-Path: <>
    Delivered-To: hello@abc.net
    Received: (qmail 22272 invoked from network); 12 Aug 2003 03:30:42 -0000
    Received: from unknown (HELO  (hello@10.0.0.222)
      by 0 with SMTP; 12 Aug 2003 03:30:42 -0000
    asdf
    asdf
    asdf

    .
    dele 1
    +OK
    quit
    +OK
    Connection closed by foreign host.

    看,剛才發送的郵件收到了,試試把,祝你好運.

     zlzj2010 回復于:2003-08-12 11:46:03
    smtp認證采用的是base64的編碼,測試時用戶名和密碼都應該為base64編碼后的

    關于base64編碼的程序網上比較多,大家可以取搜索一下!

     zlg88 回復于:2003-08-17 20:35:09
    在測試25端口時,進入驗證的命令:
    auth login 
    334 VXNlcm5hbWU6 
    aGVsbG8= 
    334 UGFzc3dvcmQ6 
    aGVsbG8= 

    其中的"aGVsbG8= "是什么意思,我這里總是報
    535 authorization failed (#5.7.0)

    能否幫忙解決一下?

     gadfly 回復于:2003-08-17 20:43:02
    分別是base64過的用戶名和密碼,最好用客戶端軟件測試

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>