1.Apache作為現(xiàn)今web服務(wù)器用的最廣泛也是最穩(wěn)定的開源服務(wù)器軟件
2.其工作模式有許多種,源碼包安裝httpd時(shí)可查看httpd-mpm.conf文件,該文件位于extra/conf目錄中
3.目前主要有兩種模式:
event模式:一個(gè)進(jìn)程中包含多個(gè)線程
prefork模式:一個(gè)進(jìn)程中包含一個(gè)線程
worker模式:一個(gè)進(jìn)程中包含多個(gè)線程
1.event是Apache最新的工作模式,它和worker模式很像,不同的是在于它解決了keep-alive長連接的時(shí)候占用線程資源被浪費(fèi)的問題
2.event工作模式在遇到某些不兼容的模塊時(shí),會(huì)失效,將會(huì)回退到worker模式
3.event工作模式需要Linux系統(tǒng)(Linux 2.6+)對epoll的支持,才能啟用。需要補(bǔ)充的是HTTPS的連接(SSL)
4.在event工作模式中,會(huì)有一些專門的線程用來管理這些keep-alive類型的線程
5.當(dāng)有真實(shí)請求過來的時(shí)候,將請求傳遞給服務(wù)器的線程執(zhí)行完畢后,又允許它釋放
6.這樣, 一個(gè)線程就能處理幾個(gè)請求了 ,實(shí)現(xiàn)了 異步非阻塞。這增強(qiáng)了在高并發(fā)場景下的請求處理
StartServers 3
MinSpareThreads 75
MaxSpareThreads 250
ThreadsPerChild 25
MaxRequestWorkers 400
MaxConnectionsPerChild 0
參數(shù) | 說明 |
---|---|
StartServers | 服務(wù)啟動(dòng)時(shí)初始的進(jìn)程數(shù),默認(rèn)3 |
MinSpare Threads | 最小的空閑子進(jìn)程數(shù),默認(rèn)75 |
MaxSpare Threads | 大的空閑子進(jìn)程數(shù),默認(rèn)250 |
ThreadsPerChild | 每個(gè)子進(jìn)程產(chǎn)生的線程數(shù)量,默認(rèn)是25 |
MaxRequestWorkers | 限定同一時(shí)間內(nèi)客戶端大接入的請求數(shù)量,默認(rèn)是400 |
MaxConnectionsPerChild | 每個(gè)子進(jìn)程在其生命周期內(nèi)允許大的請求數(shù)量,如果請求總數(shù)已經(jīng)達(dá)到這個(gè)數(shù)值,子進(jìn)程將會(huì)結(jié)束,如果設(shè)置為0,子進(jìn)程將永遠(yuǎn)不會(huì)結(jié)束。將該值設(shè)置為非0值,可以防止運(yùn)行PHP導(dǎo)致的內(nèi)存泄露 |
ServerLimit 1000
StartServers 20
MinSpareThreads 25
MaxSpareThreads 1200
ThreadsPerChild 50
MaxRequestWorkers 2000
MaxC onnectionsPerChild 1000
1.prefork是一個(gè)多路處理模塊(MPM),實(shí)現(xiàn)了一個(gè)進(jìn)程型的、預(yù)派生的web服務(wù)器,適合于沒有線程安全庫、需要避免線程兼容性問題的系統(tǒng)
2.在要求每個(gè)請求相互獨(dú)立的情況下具有很好的特性,若- -個(gè)請求出現(xiàn)問題不會(huì)影響到其他請求
3.具有很強(qiáng)的自我調(diào)節(jié)能力,只需要很少的配置指令進(jìn)行調(diào)整就可以適合于企業(yè)應(yīng)用要求
4.最重要的是將MaxClients設(shè)置為一一個(gè)足夠大的數(shù)值以處理潛在的請求高峰,同時(shí)又不能太大,以避免所需的內(nèi)存超出物理內(nèi)存的大小
5.一個(gè)單獨(dú)的控制進(jìn)程(父進(jìn)程)負(fù)責(zé)產(chǎn)生子進(jìn)程,子進(jìn)程用于監(jiān)聽請求并作出應(yīng)答,因此在內(nèi)存中會(huì)- -直存在一-些備用的(spare)或是空閑的子進(jìn)程用于響應(yīng)新的請求,可加快響應(yīng)速度
6.父進(jìn)程通常以root身份運(yùn)行,以便綁定80端口,子進(jìn)程通常以一個(gè)低特權(quán)的用戶運(yùn)行,可通過配置項(xiàng)的User和Group配置
7.運(yùn)行子進(jìn)程的用戶必須要對網(wǎng)站內(nèi)容有讀取權(quán)限,但是對其他資源必須擁有盡可能少的權(quán)限,以保證系統(tǒng)安全
8.編譯安裝時(shí)沒有指定工作模式,默認(rèn)會(huì)使用prefork模式,可用httpd-l查看
StartServers 20
MinSpareServers 10
MaxSpareServers 50
MaxClients 150
MaxRequestsPerChild 0
參數(shù) | 說明 |
---|---|
ServerLimit | 大進(jìn)程數(shù) |
StartServers | 啟動(dòng)的時(shí)候創(chuàng)建的進(jìn)程數(shù)量 |
MinSpareServers | 最少空閑進(jìn)程 |
MaxSpareServers | 最多空閑進(jìn)程 |
MaxClients | 最多創(chuàng)建多少個(gè)子進(jìn)程用來處理請求 |
MaxRequestsPerChild | 每個(gè)進(jìn)程處理的大請求數(shù),達(dá)到請求數(shù),進(jìn)程即被銷毀,如果設(shè)置為0,子進(jìn)程永遠(yuǎn)不會(huì)結(jié)束 |
ServerLimit 1000
StartServers 10
MinSpareServers 10
MaxSpareServers 30
MaxClients 1000
MaxRequestsPerChild 5000
1.每個(gè)進(jìn)程能夠擁有的線程數(shù)量 是固定的,服務(wù)器會(huì)根據(jù)負(fù)載情況增加或減少進(jìn)程數(shù)量
2.一個(gè)單獨(dú)的控制進(jìn)程(父進(jìn)程)負(fù)責(zé)子進(jìn)程的建立。每個(gè)子進(jìn)程能夠建立ThreadsPerChild數(shù)量的服務(wù)線程和一個(gè)監(jiān)聽線程,監(jiān)聽線程監(jiān)聽接入請求并將其傳遞給服務(wù)線程處理和應(yīng)答
3.Apache總是會(huì)維持一個(gè)備用(spare)或是空閑的服務(wù)線程池, 客戶端無須等待新線程或新進(jìn)程的建立即可得到服務(wù)
4.父進(jìn)程一般都是以root身份啟動(dòng),以綁定80端口;隨后,Apache以較低權(quán)限的用戶建立子進(jìn)程和線程
5.User和Group指令用于配置Apache子進(jìn)程的運(yùn)行用戶。 子進(jìn)程要對網(wǎng)頁內(nèi)容擁有讀權(quán)限,但應(yīng)該盡可能限制權(quán)限
參數(shù) | 說明 |
---|---|
ServerLimit | 大進(jìn)程數(shù),默認(rèn)值是"16" |
ThreadL imit | 每個(gè)子進(jìn)程的大線程數(shù),默認(rèn)值是"64” |
StartServers | 服務(wù)器啟動(dòng)時(shí)建立的子進(jìn)程數(shù),默認(rèn)值是"3" |
MaxClients | 允許同時(shí)接受的大接入請求數(shù)量(大線程數(shù)量) |
MinSpare Threads | 最小空閑線程數(shù),,默認(rèn)值是"75" |
MaxSpare Threads | 設(shè)置大空閑線程數(shù)。默認(rèn)值是"250" |
ThreadsPerChild | 每個(gè)子進(jìn)程建立的常駐的執(zhí)行線程數(shù)。默認(rèn)值是25 |
MaxRequestsPerChild | 設(shè)置每個(gè)子進(jìn)程在其生存期內(nèi)允許伺服的大請求數(shù)量。設(shè)置為"0",子進(jìn)程將永遠(yuǎn)不會(huì)結(jié)束 |
1.目錄的權(quán)限設(shè)置使用
2.它們是一-對容器語句,必須成對出現(xiàn),它們之間封裝的是具體的設(shè)置目錄權(quán)限語句,這些語句僅對被設(shè)置目錄及其子目錄起作用
參數(shù) | 作用 |
---|---|
Options | 設(shè)置在特定目錄使用哪些特性 |
AllowOverride | 允許存在于.htaccess文件中的指令類型 |
Require | 設(shè)置目錄的訪問控制 |
Indexes | 當(dāng)用戶訪問該目錄時(shí),但沒有指定要訪問哪個(gè)文件,而且目錄下不存在默認(rèn)網(wǎng)頁時(shí),返回目錄中的文件和子目錄列表 |
MultiViews | 內(nèi)容協(xié)商的多重視圖,Apache的一個(gè)智能特性。 當(dāng)訪問目錄中不存在的對象時(shí) |
ExecCGI | 允許在該目錄下執(zhí)行CGI腳本 |
FollowSymLinks | 在該目錄下允許文件系統(tǒng)使用符號(hào)連接 |
Includes | 允許服務(wù)器端包含功能 |
IncludesNoExec | 允許服務(wù)器端包含功能,但禁止執(zhí)行CGI腳本 |
All | 包含除了MultiViews之外所有特性,如果沒有Options語句,默認(rèn)為All |
[root@localhost ~]# smbclient -L //192.168.0.103/
Enter SAMBA\root's password:
OS=[Windows 10 Home China 18362] Server=[Windows 10 Home China 6.3]
Sharename Type Comment
--------- ---- -------
ADMIN$ Disk 遠(yuǎn)程管理
C$ Disk 默認(rèn)共享
D$ Disk 默認(rèn)共享
F$ Disk 默認(rèn)共享
IPC$ IPC 遠(yuǎn)程 IPC
rpm Disk
Connection to 192.168.0.103 failed (Error NT_STATUS_RESOURCE_NAME_NOT_FOUND)
NetBIOS over TCP disabled -- no workgroup available
[root@localhost ~]# mkdir /aaa
[root@localhost ~]# mount.cifs //192.168.0.103/rpm /aaa
Password for root@//192.168.0.103/rpm:
[root@localhost ~]# cd /aaa
[root@localhost aaa]# ls
LAMP
[root@localhost aaa]# cd LAMP/
[root@localhost LAMP]# ls
apr-1.6.2.tar.gz ha.jpg
apr-util-1.6.0.tar.gz httpd-2.4.29.tar.bz2
awstats-7.6.tar.gz lf.jpg
cronolog-1.6.2-14.el7.x86_64.rpm mysql-5.6.26.tar.gz
Discuz_X2.5_SC_UTF8.zip nginx-1.12.0.tar.gz
error.png php-5.6.11.tar.bz2
[root@localhost LAMP]# tar jxvf httpd-2.4.29.tar.bz2 -C /opt/
[root@localhost LAMP]# tar zxvf apr-1.6.2.tar.gz -C /opt/
[root@localhost LAMP]# tar zxvf apr-util-1.6.0.tar.gz -C /opt/
[root@localhost LAMP]# cd /opt
[root@localhost opt]# ls
apr-1.6.2 apr-util-1.6.0 httpd-2.4.29 rh
[root@localhost opt]# mv apr-1.6.2/ httpd-2.4.29/srclib/apr
[root@localhost opt]# mv apr-util-1.6.0/ httpd-2.4.29/srclib/apr-util
[root@localhost opt]# yum install gcc gcc-c++ pcre pcre-devel zlib-devel expat-devel -y
[root@localhost opt]#cd httpd-2.4.29/
[root@localhost httpd-2.4.29]#./configure \
--prefix=/usr/local/httpd \
--enable-deflate \
--with-mpm=prefork \
--enable-expires \
--enable-so \
--enable-rewrite \
--enable-charset-lite \
--enable-cgi
[root@localhost httpd-2.4.29]# make && make install
[root@localhost httpd-2.4.29]# ln -s /usr/local/httpd/conf/httpd.conf /etc/httpd.conf
//建立軟連接
[root@localhost httpd-2.4.29]# vim /etc/httpd.conf
輸入/mpm查找此關(guān)鍵詞,將前面的#注釋刪除
Include conf/extra/httpd-mpm.conf //定位到這行將注釋刪除,啟用功能
輸入/Listen查找此關(guān)鍵詞,修改監(jiān)聽端口
Listen 192.168.18.128:80 //此行IPv4監(jiān)聽打開,并且監(jiān)聽地址為Linux系統(tǒng)的IP地址
#Listen 80 //此行IPv6監(jiān)聽進(jìn)行注釋禁用
輸入/ServerName查找此關(guān)鍵詞,修改域名
ServerName www.test.com:80 //改域名為www.test.com
修改完成按Esc退出插入模式,輸入:wq保存退出
[root@localhost httpd-2.4.29]# cd /usr/local/httpd/
[root@localhost httpd]# cd conf/
[root@localhost conf]# ls
extra httpd.conf magic mime.types original
[root@localhost conf]# cd extra/
[root@localhost extra]# ls
httpd-autoindex.conf httpd-languages.conf httpd-ssl.conf
httpd-dav.conf httpd-manual.conf httpd-userdir.conf
httpd-default.conf httpd-mpm.conf httpd-vhosts.conf
httpd-info.conf httpd-multilang-errordoc.conf proxy-html.conf
[root@localhost extra]# vim httpd-mpm.conf
//此處我們先不做修改,直接退出,先執(zhí)行過后,后期通過修改對比不同
[root@localhost extra]# cd ../../bin/
[root@localhost bin]# ls
ab apu-1-config dbmmanage fcgistarter htdigest httxt2dbm
apachectl apxs envvars htcacheclean htpasswd logresolve
apr-1-config checkgid envvars-std htdbm httpd rotatelogs
[root@localhost bin]# ./apachectl start
[root@localhost bin]# netstat -ntap | grep 80
tcp 0 0 192.168.18.128:80 0.0.0.0:* LISTEN 58773/httpd
[root@localhost bin]# lsof -i :80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
httpd 58773 root 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58775 daemon 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58776 daemon 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58777 daemon 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58778 daemon 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58779 daemon 3u IPv4 84859 0t0 TCP localhost.localdomain:http (LISTEN)
//其中root為主進(jìn)程,其他的5個(gè)為接收的子進(jìn)程
[root@localhost bin]# cd ../conf/extra/
[root@localhost extra]# vim httpd-mpm.conf
StartServers 10 //啟動(dòng)的時(shí)候創(chuàng)建的進(jìn)程數(shù)量改為10
MinSpareServers 10 //空閑最小改為10
MaxSpareServers 20 //大設(shè)為20
MaxRequestWorkers 200 //訪問設(shè)量為200
MaxConnectionsPerChild 0
//修改完成按Esc退出插入模式,輸入:wq保存退出
[root@localhost extra]# cd ../../bin/
[root@localhost bin]# ./apachectl stop
[root@localhost bin]# ./apachectl start
//重新關(guān)閉開啟服務(wù)
[root@localhost bin]# lsof -i :80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
httpd 58933 root 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58937 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58938 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58939 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58940 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58941 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58942 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58943 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58944 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58945 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
httpd 58946 daemon 3u IPv4 88357 0t0 TCP localhost.localdomain:http (LISTEN)
//除去一個(gè)主進(jìn)程,其他的子進(jìn)程變?yōu)?0個(gè)
[root@localhost bin]# ./httpd -l //查看工作模式
Compiled in modules:
core.c
mod_so.c
http_core.c
prefork.c //此時(shí)處于prefork工作模式
[root@localhost bin]# vim /etc/httpd.conf
輸入/htdocs查找此關(guān)鍵詞,找到如下字段,其中有兩個(gè)功能起到支持作用:
DocumentRoot "/usr/local/httpd/htdocs"
#
# Possible values for the Options directive are "None", "All",
# or any combination of:
# Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# Note that "MultiViews" must be named *explicitly* --- "Options All"
# doesn't give it to you.
#
# The Options directive is both complicated and important. Please see
# http://httpd.apache.org/docs/2.4/mod/core.html#options
# for more information.
#
Options Indexes FollowSymLinks
//1.Index:以列表形式展現(xiàn)
//2.FollowSymLinks并且支持鏈接性的文件
#
# AllowOverride controls what directives may be placed in .htaccess files.
# It can be "All", "None", or any combination of the keywords:
# AllowOverride FileInfo AuthConfig Limit
#
AllowOverride None
#
# Controls who can get stuff from this server.
#
Require all granted //黑白名單
#我們可以先關(guān)閉防火墻,使用宿主機(jī)的瀏覽器進(jìn)行驗(yàn)證
[root@localhost bin]# systemctl stop firewalld.service
[root@localhost bin]# setenforce 0
[root@localhost bin]# cd /usr/local/httpd/htdocs/
[root@localhost htdocs]# ls
index.html
[root@localhost htdocs]# cat index.html
It works!
[root@localhost htdocs]# ls
index.html
[root@localhost htdocs]# mv index.html a.html
[root@localhost htdocs]# ls
a.html
[root@localhost htdocs]# touch b.html c.html d.html
[root@localhost htdocs]# ls
a.html b.html c.html d.html
//此時(shí)會(huì)以文件列表的形式展現(xiàn),從另一個(gè)角度我們可以利用這點(diǎn)來做文件下載資源的提供,此時(shí)就不需要首頁識(shí)別
[root@localhost htdocs]# ln -s /usr/share/man/ ./
//把man手冊放入這個(gè)文件夾,看他能不能識(shí)別這個(gè)鏈接文件
[root@localhost htdocs]# ls
a.html b.html c.html d.html man
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。