Linux apache編譯安裝

來源:互聯網
上載者:User

原文連結:http://liujiesmart.iteye.com/blog/636151

1.下載httpd-2.2.15.tar.gz 

[root@test-AS4 ~]# mkdir -P /usr/local/src/apache/    #建立源包存放的目錄 

[root@test-AS4 ~]# cd /usr/local/src/apache/           #把httpd-2.2.15.tar.gz放入此目錄下 

[root@test-AS4 apache]# tar zxvf httpd-2.2.15.tar.gz       #解壓檔案會產生httpd-2.2.15目錄 

[root@test-AS4 apache]# ll 
total 6464 
drwxr-xr-x  11 angel angel    4096 Mar 10 07:42 httpd-2.2.15 
-rw-r--r--   1 root  root  6593633 Mar 10  2010 httpd-2.2.15.tar.gz 

[root@test-AS4 httpd-2.2.15]# cd httpd-2.2.15 

[root@test-AS4 httpd-2.2.15]# ./configure --prefix=/usr/local/apache-2.2.15  --enable-so --enable-mods-shared=most --with-mpm=worker 

[root@test-AS4 httpd-2.2.15]# make 

[root@test-AS4 httpd-2.2.15]# make install 

#  --prefix=<Install_Path> 指明編譯後的二進位檔案安裝到<Install_Path>目錄,用實際安裝路徑替換<Install_Path>,如--prefix=/usr/local/apache-2.2.15 ,如果省略此配置參數,預設安裝到/usr/local/apache2目錄。 

#  --enable-so 指明編譯動態載入模組(DSO)支援到httpd二進位檔案,此模組使得Apache的各功能模組可以與核心分開編譯、運行時動態載入。有了DSO支援,升級和增加模組時只需編譯相關的模組即可,不必重新編譯整個系統。最新版本的Apache預設編譯此模組到httpd二進位檔案,如果你在使用早期版本的apache並且需要DSO支援,可能要明確指出此選項。 

#  --enable-mods-shared=<MODULE-LIST> 明確指明要以DSO方式編譯的模組,<MODULE-LIST>為空白格分隔的模組名列表、all或者most,all表示包含所有模組,most表示包含大部分模組,如--enable-mods-share="rewrite deflate",--enable-mods-share=most,效果等同於多個--enable-<FEATURE>=share 
# --with-mpm=<MPM> 先擇Apache多路處理模組,<MPM>={beos|event|worker|prefork|mpmt_os2},prefork為Unix系統下預設處理模組,它將運行一個非線程型的、預派生的Web伺服器,適合於沒有安全執行緒庫,需要避免線程相容性問題的系統,它是要求將每個請求相互獨立的情況下最好的MPM,這樣若一個請求出現問題就不會影響到其他請求。worker為支援混合的多線程多進程的多路處理模組,由於使用線程來處理請求,所以可以處理海量請求,而系統資源的開銷小於基於進程的MPM,同時,它也使用了多進程,每個進程又有多個線程,以獲得基於進程的MPM的穩定性。如果你的系統是基於安全執行緒的,那麼筆者建議使用worker替代prefork,它將使得你的系統得到實際的效能改善。 

2. 設定開機自啟動服務控制指令碼 
  Apache安裝後可通過其安裝路徑的bin目錄下的apachectl指令碼控制服務的啟動和停止。本例中apache安裝在/usr/local/apache-2.2.15,服務控制指令碼為: 
    /usr/local/apache-2.2.15/bin/apachectl 
   執行下面的命令啟動Apache服務: 
    /usr/local/apache-2.2.15/bin/apachectl start 
   執行下面的命令停止Apache服務: 
    /usr/local/apache-2.2.15/bin/apachectl stop 
  可以簡單地把Apache啟動命令加到/etc/rc.local檔案,讓Apache隨系統啟動而自動啟動: 
    echo "/usr/local/apache-2.2.15/bin/apachectl start"  >> /etc/rc.local 

下面介紹如何把Apache加入到系統服務,用service命令來控制Apache的啟動和停止。 

## 這裡請注意一下!如果Linux伺服器上預設安裝了httpd的話(用rpm -qa|grep httpd查看), 

## 會有 /etc/init.d/httpd 這個指令檔的,所以你也可以用以下方法直接產生這個檔案來覆蓋它 

## 那麼下次就可以用 service httpd start 來啟動了 

## 如果需要區分開來的話就使用下面的方式 
  首先以apachectl指令碼為模板產生Apache服務控制指令碼: 
    grep -v "#" /usr/local/apache-2.2.15/bin/apachectl  > /etc/init.d/apache 
   用vi編輯Apache服務控制指令碼/etc/init.d/apache: 
    vi /etc/init.d/apache 
   在檔案最前面插入下面的行,使其支援chkconfig命令: 
    #!/bin/sh 
              # chkconfig: 2345 85 15 
              # description: Apache is a World Wide Web server. 
   儲存後退出vi編輯器,執行下面的命令增加Apache服務控制指令碼執行許可權: 
    chmod  +x  /etc/init.d/apache 
   執行下面的命令將Apache服務加入到系統服務: 
    chkconfig --add apache 
   執行下面的命令檢查Apache服務是否已經生效: 
    chkconfig --list apache 
              命令輸出類似下面的結果: 
              apache          0:off 1:off 2:on 3:on 4:on 5:on 6:off 
       表明apache服務已經生效,在2、3、4、5運行層級隨系統啟動而自動啟動,以後可以使用service命令控制Apache的啟動和停止。 
  啟動Apache服務: 
    service apache start 
   停止Apache服務: 
       service apache stop 
   執行下面的命令關閉開機自啟動: 
    chkconfig apache off 
   執行下面的命令改變開機自啟動的運行層級為3、5: 
    chkconfig --level 35 apache on 

3. Apache的配置 

源碼包方式安裝目錄結構 
  源碼包方式安裝時通常是在configure命令的--prefix選項指定的目錄中建立如下的目錄結構,特殊指定的目錄除外: 
         ./icons     #Apache表徵圖檔案目錄 
           ./modules   #動態載入模組目錄 
           ./lib       #庫檔案目錄 
           ./logs      #記錄檔目錄 
           ./build     # 
           ./conf      #主設定檔目錄 
           ./conf/extra     #擴充及模組設定檔目錄 
           ./error     #預設錯誤應答檔案目錄 
           ./manual    #Apache文檔目錄 
           ./include   #包含標頭檔目錄 
           ./htdocs    #預設WEB主目錄 
           ./cgi-bin   #預設cgi檔案目錄 
           ./bin     #Apache二進位程式及服務程式目錄 
           ./man     #man協助檔案目錄 

4. 設定檔 http.conf 

ServerRoot "/usr/local/apache-2.2.15"       ##設定伺服器的基礎目錄,預設為Apache安裝目錄 
Listen 80           ##設定伺服器監聽的IP和連接埠 
LoadModule authn_file_module modules/mod_authn_file.so 
LoadModule authn_dbm_module modules/mod_authn_dbm.so 
LoadModule authn_anon_module modules/mod_authn_anon.so 
LoadModule authn_dbd_module modules/mod_authn_dbd.so 
LoadModule authn_default_module modules/mod_authn_default.so 
LoadModule authz_host_module modules/mod_authz_host.so 
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so 
LoadModule authz_user_module modules/mod_authz_user.so 
LoadModule authz_dbm_module modules/mod_authz_dbm.so 
LoadModule authz_owner_module modules/mod_authz_owner.so 
LoadModule authz_default_module modules/mod_authz_default.so 
LoadModule auth_basic_module modules/mod_auth_basic.so 
LoadModule auth_digest_module modules/mod_auth_digest.so 
LoadModule dbd_module modules/mod_dbd.so 
LoadModule dumpio_module modules/mod_dumpio.so 
LoadModule reqtimeout_module modules/mod_reqtimeout.so 
LoadModule ext_filter_module modules/mod_ext_filter.so 
LoadModule include_module modules/mod_include.so 
LoadModule filter_module modules/mod_filter.so 
LoadModule substitute_module modules/mod_substitute.so 
LoadModule deflate_module modules/mod_deflate.so 
LoadModule log_config_module modules/mod_log_config.so 
LoadModule logio_module modules/mod_logio.so 
LoadModule env_module modules/mod_env.so 
LoadModule expires_module modules/mod_expires.so 
LoadModule headers_module modules/mod_headers.so 
LoadModule ident_module modules/mod_ident.so 
LoadModule setenvif_module modules/mod_setenvif.so 
LoadModule version_module modules/mod_version.so 
LoadModule mime_module modules/mod_mime.so 
LoadModule dav_module modules/mod_dav.so 
LoadModule status_module modules/mod_status.so 
LoadModule autoindex_module modules/mod_autoindex.so 
LoadModule asis_module modules/mod_asis.so 
LoadModule info_module modules/mod_info.so 
LoadModule cgid_module modules/mod_cgid.so 
LoadModule dav_fs_module modules/mod_dav_fs.so 
LoadModule vhost_alias_module modules/mod_vhost_alias.so 
LoadModule negotiation_module modules/mod_negotiation.so 
LoadModule dir_module modules/mod_dir.so 
LoadModule imagemap_module modules/mod_imagemap.so 
LoadModule actions_module modules/mod_actions.so 
LoadModule speling_module modules/mod_speling.so 
LoadModule userdir_module modules/mod_userdir.so 
LoadModule alias_module modules/mod_alias.so 
LoadModule rewrite_module modules/mod_rewrite.so 
<IfModule !mpm_netware_module> 
User daemon     ##設定實際提供服務的子進程的使用者。 
Group daemon    ##設定提供服務的Apache子進程運行時的使用者組。 
</IfModule> 
ServerAdmin you@example.com      ##設定在所有返回給用戶端的錯誤資訊中包含的管理員郵件地址。 
ServerName 192.168.221.128       ##設定伺服器用於辨識自己的主機名稱和連接埠號碼(用IP代替)。 
DocumentRoot "/usr/local/apache-2.2.15/htdocs"     ##設定Web主目錄。 
<Directory />       ###<Directory>和</Directory>用於封裝一組指令,使之僅對某個目錄及其子目錄生效。 
    Options FollowSymLinks 
    AllowOverride None 
    Order deny,allow 
    Deny from all 
</Directory> 
<Directory "/usr/local/apache-2.2.15/htdocs">   ##設定DocumentRoot指定目錄的屬性 
    Options Indexes FollowSymLinks    ##建議拿掉Indexes 
    AllowOverride None 
    Order allow,deny 
    Allow from all 
</Directory> 
<IfModule dir_module>    ##設定預設目錄資源清單檔案 
    DirectoryIndex index_top.html entrance.html index.html index.php index.htm index.asp index.php3 
</IfModule> 
<FilesMatch "^\.ht">     ##拒絕對.ht開標頭檔的訪問,以保護.htaccess檔案 
    Order allow,deny 
    Deny from all 
    Satisfy All 
</FilesMatch> 
ErrorLog "logs/error_log"      ##指定錯誤記錄檔檔案 
LogLevel warn        ##指定記錄到錯誤記錄檔的訊息層級 
<IfModule log_config_module>    ##定義訪問日誌的格式 
    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 
    LogFormat "%h %l %u %t \"%r\" %>s %b" common 
    <IfModule logio_module> 
      LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 
    </IfModule> 
    CustomLog "logs/access_log" common    ##指定訪問日誌及使用的格式 
</IfModule> 
<IfModule alias_module>    ##設定預設CGI指令碼目錄及別名 
    ScriptAlias /cgi-bin/ "/usr/local/apache-2.2.15/cgi-bin/" 
</IfModule> 
<IfModule cgid_module> 
</IfModule> 
<Directory "/usr/local/apache-2.2.15/cgi-bin">    ##設定預設CGI指令碼目錄的屬性 
    AllowOverride None 
    Options None 
    Order allow,deny 
    Allow from all 
</Directory> 
DefaultType text/plain    ##設定預設MIME內容類型 
<IfModule mime_module> 
    TypesConfig conf/mime.types 
    AddType application/x-compress .Z 
    AddType application/x-gzip .gz .tgz 
</IfModule> 
<IfModule ssl_module> 
SSLRandomSeed startup builtin 
SSLRandomSeed connect builtin 
</IfModule> 

<IfModule mpm_worker_module>              ##編譯參數 --with-mpm=worker時,使用worker.c模組 
                ServerLimit         25    ##/usr/local/apache-2.2.15/bin/apachectl -l查看使用模組 
                ThreadLimit        200 
                StartServers         3 
                MaxClients        2000 
                MinSpareThreads     50 
                MaxSpareThreads    200 
                ThreadsPerChild    100 
                MaxRequestsPerChild  1000 
</IfModule> 

Timeout 15 
KeepAlive On 
MaxKeepAliveRequests 100 
KeepAliveTimeout 3 
UseCanonicalName Off 
AccessFileName .htaccess 
ServerTokens Prod 
ServerSignature Off 
HostnameLookups Off 

NameVirtualHost *:80 
<VirtualHost *:80> 
    DocumentRoot /usr/local/apache-2.2.15/htdocs/irene 
    ServerName www.irene.com 
</VirtualHost> 
<VirtualHost *:80> 
    DocumentRoot /usr/local/apache-2.2.15/htdocs/angel 
    ServerName www.angel.com 
</VirtualHost> 

----------------------------------------------------------------------------------------- 

4. 認證和授權配置 

## 在httpd.conf設定檔中添加如下代碼 

<Directory "/usr/local/apache-2.2.15/htdocs/protect"> 
        AllowOverride None      ## 不使用.htaccess檔案 
        AuthType Basic          ## 指定使用基本認證方式 
        AuthName "apache.passwd"    ## 指定認證領網域名稱稱 
        AuthUserFile /usr/local/apache-2.2.15/htdocs/protect/apache.passwd  ## 認證口令存放位置 
        require valid-user     ## 授權給認證口令檔案中的所有使用者 
        #Order allow,deny 
        #Allow from all 
</Directory> 

** 由於文本中 DocumentRoot "/usr/local/apache-2.2.15/htdocs" 已經指定了你的主目錄 

** 所以在這個目錄下建立相關目錄作為指定的保護文檔位置 

** 也可以使用Alias別名 指定一個其他目錄 

[root@test-AS4 ~]# cd /usr/local/apache-2.2.15/htdocs 

[root@test-AS4 htdocs]# mkdir protect 

[root@test-AS4 protect]# htpasswd -c apache.passwd angel 

[root@test-AS4 protect]# ll 
total 8 
-rw-r--r--  1 root root 20 Mar 14 21:14 apache.passwd 
[root@test-AS4 protect]# cat apache.passwd 
angel:Grka1xfi6y5RM 
[root@test-AS4 protect]# 

## 開啟瀏覽器URL: http://192.168.221.128/protect/

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.