'Linux 面試題,重點題目及答案詳解,熟記輕鬆能過面試'

"

Linux面試題:

1.Linux常用系統安全命令

sudo // 超級用戶

su // 用於切換當前用戶身份到其他身份,變更時需輸入所要變更的用戶賬號與密碼。

chmod // 用來變更文件或目錄的權限

setfacl // 設置文件訪問控制列表

2.Linux常用進程管理命令

w // 用於顯示已經登陸系統的用戶列表,並顯示用戶正在執行的指令。

top // 可以實時動態地查看系統的整體運行情況,是一個綜合了多方信息監測系統性能和運行信息的實用工具。

ps // 用於報告當前系統的進程狀態。

kill // 用來刪除執行中的程序或工作。

pkill // 可以按照進程名殺死進程。

pstree // 以樹狀圖的方式展現進程之間的派生關係,顯示效果比較直觀。

killall // 使用進程的名稱來殺死進程,使用此指令可以殺死一組同名進程。

3.Linux常用用戶管理命令

id // 可以顯示真實有效的用戶ID(UID)和組ID(GID)。

usermod // 用於修改用戶的基本信息。

useradd // 用於 Linux中創建的新的系統用戶。

groupadd // 用於創建一個新的工作組,新工作組的信息將被添加到系統文件中。

userdel // 用戶刪除給定的用戶,以及與用戶相關的文件。若不加選型,則進刪除用戶賬號,而不刪除相關文件。

4.Linux系統關機和重啟

shutdown reboot

5.Linux系統定時任務

contab -e //創建定時任務

6.Linux文件內容查看

head // 用於顯示文件的開頭的內容。在默認情況下,head命令顯示文件的頭10行內容。

tail // 用於輸入文件中的尾部內容。tail命名默認在屏幕上顯示指定文件的末尾10行。

more // 用來瀏覽文件檔案的內容(只能向前瀏覽)。

less // 用來瀏覽文字檔案的內容,允許用戶向前或向後瀏覽文件。使用該命令時,用PageUp鍵向上翻頁,用PageDown鍵向下翻頁。要退出less程序,應按Q鍵。

7.計劃每星期天早8點服務器定時重啟,如何實現?

Crontab-e

0008 * * 7 /sbin/init 6

8.linux下如何改IP,主機名,DNS

使用setup 命令可以修改IP 和DNS ,修改完後重啟網絡:service network restart

臨時修改即時生效,重啟後失效

hostname主機名: 修改主機名

ifconfigeth0 IP netmask 掩碼 :修改IP

永久修改主機名: 修改:/etc/sysconfig/network 文件 HOSTNAME=主機名

永久修改IP地址:修改 /etc/sysconfig/network-scripts/ifcfg-eth0 文件

修改完後重啟網絡:service network restart

9.如何用mysql 命令進行備份和恢復? 以test 庫為例,創建一個備份,並再用此備份進行恢復。

答案:mysqldump -u root -p test > test.bak

mysql -u root -p < test.bak

10.linux系統中如何獲取pid為100的進程所監聽的tcp端口,請給出詳細命令?

netstat -nlpt |grep 100

4.Linux常用命令

arch 顯示機器的處理器架構(1)

uname -m 顯示機器的處理器架構(2)

uname -r 顯示正在使用的內核版本

dmidecode -q 顯示硬件系統部件 - (SMBIOS / DMI)

hdparm -i /dev/hda 羅列一個磁盤的架構特性

hdparm -tT /dev/sda 在磁盤上執行測試性讀取操作

cat /proc/cpuinfo 顯示CPU info的信息

cat /proc/interrupts 顯示中斷

cat /proc/meminfo 校驗內存使用

cat /proc/swaps 顯示哪些swap被使用

cat /proc/version 顯示內核的版本

cat /proc/net/dev 顯示網絡適配器及統計

cat /proc/mounts 顯示已加載的文件系統

lspci -tv 羅列 PCI 設備

lsusb -tv 顯示 USB 設備

date 顯示系統日期

cal 2007 顯示2007年的日曆表

date 041217002007.00 設置日期和時間 - 月日時分年.秒

clock -w 將時間修改保存到 BIOS

關機 (系統的關機、重啟以及登出 )

shutdown -h now 關閉系統(1)

init 0 關閉系統(2)

telinit 0 關閉系統(3)

shutdown -h hours:minutes & 按預定時間關閉系統

shutdown -c 取消按預定時間關閉系統

shutdown -r now 重啟(1)

reboot 重啟(2)

logout 註銷

文件和目錄

cd /home 進入 ‘/ home’ 目錄’

cd … 返回上一級目錄

cd …/… 返回上兩級目錄

cd 進入個人的主目錄

cd ~user1 進入個人的主目錄

cd - 返回上次所在的目錄

pwd 顯示工作路徑

ls 查看目錄中的文件

ls -F 查看目錄中的文件

ls -l 顯示文件和目錄的詳細資料

ls -a 顯示隱藏文件

ls [0-9] 顯示包含數字的文件名和目錄名

tree 顯示文件和目錄由根目錄開始的樹形結構(1)

lstree 顯示文件和目錄由根目錄開始的樹形結構(2)

mkdir dir1 創建一個叫做 ‘dir1’ 的目錄’

mkdir dir1 dir2 同時創建兩個目錄

mkdir -p /tmp/dir1/dir2 創建一個目錄樹

rm -f file1 刪除一個叫做 ‘file1’ 的文件’

rmdir dir1 刪除一個叫做 ‘dir1’ 的目錄’

rm -rf dir1 刪除一個叫做 ‘dir1’ 的目錄並同時刪除其內容

rm -rf dir1 dir2 同時刪除兩個目錄及它們的內容

mv dir1 new_dir 重命名/移動 一個目錄

cp file1 file2 複製一個文件

cp dir/* . 複製一個目錄下的所有文件到當前工作目錄

cp -a /tmp/dir1 . 複製一個目錄到當前工作目錄

cp -a dir1 dir2 複製一個目錄

ln -s file1 lnk1 創建一個指向文件或目錄的軟鏈接

ln file1 lnk1 創建一個指向文件或目錄的物理鏈接

touch -t 0712250000 file1 修改一個文件或目錄的時間戳 - (YYMMDDhhmm)

file file1 outputs the mime type of the file as text

iconv -l 列出已知的編碼

iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding.

find . -maxdepth 1 -name *.jpg -print -exec convert “{}” -resize 80x60 “thumbs/{}” ; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick)

文件搜索

find / -name file1 從 ‘/’ 開始進入根文件系統搜索文件和目錄

find / -user user1 搜索屬於用戶 ‘user1’ 的文件和目錄

find /home/user1 -name *.bin 在目錄 ‘/ home/user1’ 中搜索帶有’.bin’ 結尾的文件

find /usr/bin -type f -atime +100 搜索在過去100天內未被使用過的執行文件

find /usr/bin -type f -mtime -10 搜索在10天內被創建或者修改過的文件

find / -name *.rpm -exec chmod 755 ‘{}’ ; 搜索以 ‘.rpm’ 結尾的文件並定義其權限

find / -xdev -name *.rpm 搜索以 ‘.rpm’ 結尾的文件,忽略光驅、捷盤等可移動設備

locate *.ps 尋找以 ‘.ps’ 結尾的文件 - 先運行 ‘updatedb’ 命令

whereis halt 顯示一個二進制文件、源碼或man的位置

which halt 顯示一個二進制文件或可執行文件的完整路徑

掛載一個文件系統

mount /dev/hda2 /mnt/hda2 掛載一個叫做hda2的盤 - 確定目錄 ‘/ mnt/hda2’ 已經存在

umount /dev/hda2 卸載一個叫做hda2的盤 - 先從掛載點 ‘/ mnt/hda2’ 退出

fuser -km /mnt/hda2 當設備繁忙時強制卸載

umount -n /mnt/hda2 運行卸載操作而不寫入 /etc/mtab 文件- 當文件為只讀或當磁盤寫滿時非常有用

mount /dev/fd0 /mnt/floppy 掛載一個軟盤

mount /dev/cdrom /mnt/cdrom 掛載一個cdrom或dvdrom

mount /dev/hdc /mnt/cdrecorder 掛載一個cdrw或dvdrom

mount /dev/hdb /mnt/cdrecorder 掛載一個cdrw或dvdrom

mount -o loop file.iso /mnt/cdrom 掛載一個文件或ISO鏡像文件

mount -t vfat /dev/hda5 /mnt/hda5 掛載一個Windows FAT32文件系統

mount /dev/sda1 /mnt/usbdisk 掛載一個usb 捷盤或閃存設備

mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 掛載一個windows網絡共享

磁盤空間

df -h 顯示已經掛載的分區列表

ls -lSr |more 以尺寸大小排列文件和目錄

du -sh dir1 估算目錄 ‘dir1’ 已經使用的磁盤空間’

du -sk * | sort -rn 以容量大小為依據依次顯示文件和目錄的大小

rpm -q -a --qf ‘%10{SIZE}t%{NAME}n’ | sort -k1,1n 以大小為依據依次顯示已安裝的rpm包所使用的空間 (fedora, redhat類系統)

dpkg-query -W -f=’Installed−Size;10t {Installed-Size;10}tInstalled−Size;10t{Package}n’ | sort -k1,1n 以大小為依據顯示已安裝的deb包所使用的空間 (ubuntu, debian類系統)

用戶和群組

groupadd group_name 創建一個新用戶組

groupdel group_name 刪除一個用戶組

groupmod -n new_group_name old_group_name 重命名一個用戶組

useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 創建一個屬於 “admin” 用戶組的用戶

useradd user1 創建一個新用戶

userdel -r user1 刪除一個用戶 ( ‘-r’ 排除主目錄)

usermod -c “User FTP” -g system -d /ftp/user1 -s /bin/nologin user1 修改用戶屬性

passwd 修改口令

passwd user1 修改一個用戶的口令 (只允許root執行)

chage -E 2005-12-31 user1 設置用戶口令的失效期限

pwck 檢查 ‘/etc/passwd’ 的文件格式和語法修正以及存在的用戶

grpck 檢查 ‘/etc/passwd’ 的文件格式和語法修正以及存在的群組

newgrp group_name 登陸進一個新的群組以改變新創建文件的預設群組

文件的權限 - 使用 “+” 設置權限,使用 “-” 用於取消

ls -lh 顯示權限

ls /tmp | pr -T5 -W$COLUMNS 將終端劃分成5欄顯示

chmod ugo+rwx directory1 設置目錄的所有人(u)、群組(g)以及其他人(o)以讀(r )、寫(w)和執行(x)的權限

chmod go-rwx directory1 刪除群組(g)與其他人(o)對目錄的讀寫執行權限

chown user1 file1 改變一個文件的所有人屬性

chown -R user1 directory1 改變一個目錄的所有人屬性並同時改變改目錄下所有文件的屬性

chgrp group1 file1 改變文件的群組

chown user1:group1 file1 改變一個文件的所有人和群組屬性

find / -perm -u+s 羅列一個系統中所有使用了SUID控制的文件

chmod u+s /bin/file1 設置一個二進制文件的 SUID 位 - 運行該文件的用戶也被賦予和所有者同樣的權限

chmod u-s /bin/file1 禁用一個二進制文件的 SUID位

chmod g+s /home/public 設置一個目錄的SGID 位 - 類似SUID ,不過這是針對目錄的

chmod g-s /home/public 禁用一個目錄的 SGID 位

chmod o+t /home/public 設置一個文件的 STIKY 位 - 只允許合法所有人刪除文件

chmod o-t /home/public 禁用一個目錄的 STIKY 位

文件的特殊屬性 - 使用 “+” 設置權限,使用 “-” 用於取消

chattr +a file1 只允許以追加方式讀寫文件

chattr +c file1 允許這個文件能被內核自動壓縮/解壓

chattr +d file1 在進行文件系統備份時,dump程序將忽略這個文件

chattr +i file1 設置成不可變的文件,不能被刪除、修改、重命名或者鏈接

chattr +s file1 允許一個文件被安全地刪除

chattr +S file1 一旦應用程序對這個文件執行了寫操作,使系統立刻把修改的結果寫到磁盤

chattr +u file1 若文件被刪除,系統會允許你在以後恢復這個被刪除的文件

lsattr 顯示特殊的屬性

打包和壓縮文件

bunzip2 file1.bz2 解壓一個叫做 'file1.bz2’的文件

bzip2 file1 壓縮一個叫做 ‘file1’ 的文件

gunzip file1.gz 解壓一個叫做 'file1.gz’的文件

gzip file1 壓縮一個叫做 'file1’的文件

gzip -9 file1 最大程度壓縮

rar a file1.rar test_file 創建一個叫做 ‘file1.rar’ 的包

rar a file1.rar file1 file2 dir1 同時壓縮 ‘file1’, ‘file2’ 以及目錄 ‘dir1’

rar x file1.rar 解壓rar包

unrar x file1.rar 解壓rar包

tar -cvf archive.tar file1 創建一個非壓縮的 tarball

tar -cvf archive.tar file1 file2 dir1 創建一個包含了 ‘file1’, ‘file2’ 以及 'dir1’的檔案文件

tar -tf archive.tar 顯示一個包中的內容

tar -xvf archive.tar 釋放一個包

tar -xvf archive.tar -C /tmp 將壓縮包釋放到 /tmp目錄下

tar -cvfj archive.tar.bz2 dir1 創建一個bzip2格式的壓縮包

tar -xvfj archive.tar.bz2 解壓一個bzip2格式的壓縮包

tar -cvfz archive.tar.gz dir1 創建一個gzip格式的壓縮包

tar -xvfz archive.tar.gz 解壓一個gzip格式的壓縮包

zip file1.zip file1 創建一個zip格式的壓縮包

zip -r file1.zip file1 file2 dir1 將幾個文件和目錄同時壓縮成一個zip格式的壓縮包

unzip file1.zip 解壓一個zip格式壓縮包

RPM 包 - (Fedora, Redhat及類似系統)

rpm -ivh package.rpm 安裝一個rpm包

rpm -ivh --nodeeps package.rpm 安裝一個rpm包而忽略依賴關係警告

rpm -U package.rpm 更新一個rpm包但不改變其配置文件

rpm -F package.rpm 更新一個確定已經安裝的rpm包

rpm -e package_name.rpm 刪除一個rpm包

rpm -qa 顯示系統中所有已經安裝的rpm包

rpm -qa | grep httpd 顯示所有名稱中包含 “httpd” 字樣的rpm包

rpm -qi package_name 獲取一個已安裝包的特殊信息

rpm -qg “System Environment/Daemons” 顯示一個組件的rpm包

rpm -ql package_name 顯示一個已經安裝的rpm包提供的文件列表

rpm -qc package_name 顯示一個已經安裝的rpm包提供的配置文件列表

rpm -q package_name --whatrequires 顯示與一個rpm包存在依賴關係的列表

rpm -q package_name --whatprovides 顯示一個rpm包所佔的體積

rpm -q package_name --scripts 顯示在安裝/刪除期間所執行的腳本l

rpm -q package_name --changelog 顯示一個rpm包的修改歷史

rpm -qf /etc/httpd/conf/httpd.conf 確認所給的文件由哪個rpm包所提供

rpm -qp package.rpm -l 顯示由一個尚未安裝的rpm包提供的文件列表

rpm --import /media/cdrom/RPM-GPG-KEY 導入公鑰數字證書

rpm --checksig package.rpm 確認一個rpm包的完整性

rpm -qa gpg-pubkey 確認已安裝的所有rpm包的完整性

rpm -V package_name 檢查文件尺寸、 許可、類型、所有者、群組、MD5檢查以及最後修改時間

rpm -Va 檢查系統中所有已安裝的rpm包- 小心使用

rpm -Vp package.rpm 確認一個rpm包還未安裝

rpm2cpio package.rpm | cpio --extract --make-directories bin 從一個rpm包運行可執行文件

rpm -ivh /usr/src/redhat/RPMS/arch/package.rpm 從一個rpm源碼安裝一個構建好的包

rpmbuild --rebuild package_name.src.rpm 從一個rpm源碼構建一個 rpm 包

YUM 軟件包升級器 - (Fedora, RedHat及類似系統)

yum install package_name 下載並安裝一個rpm包

yum localinstall package_name.rpm 將安裝一個rpm包,使用你自己的軟件倉庫為你解決所有依賴關係

yum update package_name.rpm 更新當前系統中所有安裝的rpm包

yum update package_name 更新一個rpm包

yum remove package_name 刪除一個rpm包

yum list 列出當前系統中安裝的所有包

yum search package_name 在rpm倉庫中搜尋軟件包

yum clean packages 清理rpm緩存刪除下載的包

yum clean headers 刪除所有頭文件

yum clean all 刪除所有緩存的包和頭文件

DEB 包 (Debian, Ubuntu 以及類似系統)

dpkg -i package.deb 安裝/更新一個 deb 包

dpkg -r package_name 從系統刪除一個 deb 包

dpkg -l 顯示系統中所有已經安裝的 deb 包

dpkg -l | grep httpd 顯示所有名稱中包含 “httpd” 字樣的deb包

dpkg -s package_name 獲得已經安裝在系統中一個特殊包的信息

dpkg -L package_name 顯示系統中已經安裝的一個deb包所提供的文件列表

dpkg --contents package.deb 顯示尚未安裝的一個包所提供的文件列表

dpkg -S /bin/ping 確認所給的文件由哪個deb包提供

APT 軟件工具 (Debian, Ubuntu 以及類似系統)

apt-get install package_name 安裝/更新一個 deb 包

apt-cdrom install package_name 從光盤安裝/更新一個 deb 包

apt-get update 升級列表中的軟件包

apt-get upgrade 升級所有已安裝的軟件

apt-get remove package_name 從系統刪除一個deb包

apt-get check 確認依賴的軟件倉庫正確

apt-get clean 從下載的軟件包中清理緩存

apt-cache search searched-package 返回包含所要搜索字符串的軟件包名稱

查看文件內容

cat file1 從第一個字節開始正向查看文件的內容

tac file1 從最後一行開始反向查看一個文件的內容

more file1 查看一個長文件的內容

less file1 類似於 ‘more’ 命令,但是它允許在文件中和正向操作一樣的反向操作

head -2 file1 查看一個文件的前兩行

tail -2 file1 查看一個文件的最後兩行

tail -f /var/log/messages 實時查看被添加到一個文件中的內容

什麼是MongoDB?

答:mongodb是基於分佈式文件存儲的nosql數據庫,是一種文檔型數據庫,適合存儲

海量數據並提高性能存取。2.mongodb三元素:

答:數據庫、集合(表)、文檔(行)

名字空間(namespace)是什麼?

答:MongoDB存儲BSON對象在叢集(collection)中。數據庫名字和叢集名字以句點連結起來叫做名字空間(namespace)。

MongoDB的特點是什麼?

答:(1)面向文檔(2)高性能(3)高可用(4)易擴展(5)豐富的查詢語言

MySQL與MongoDB本質之間最基本的差別是什麼?

答:mongodb的本質還是一個數據庫產品,3.0以上版本其穩定性和健壯性有很大提升。它與mysql的區別在於它不會遵循一些約束,比如:sql標準、ACID屬性,表結構等。其主要特性如下:

 面向集合文檔的存儲:適合存儲Bson(json的擴展)形式的數據;

 格式自由,數據格式不固定,生產環境下修改結構都可以不影響程序運行;

 強大的查詢語句,面向對象的查詢語言,基本覆蓋sql語言所有能力;

 完整的索引支持,支持查詢計劃;

 支持複製和自動故障轉移;

 支持二進制數據及大型對象(文件)的高效存儲;

 使用分片集群提升系統擴展性;

 使用內存映射存儲引擎,把磁盤的IO操作轉換成為內存的操作;。

各個數據庫存儲引擎區別?

答:mysql的存儲引擎是針對表進行設置的,一個庫的不同表可以設置不同的存儲引擎,mysql默認支持多種存儲引擎,以適用不同領域的數據庫應用需要,主要的幾個數據庫引擎如下:

 MyISAM存儲引擎

5.5之前默認的存儲引擎,不支持事務、不支持外鍵,表級鎖,內存和硬盤空間佔用率低,其優勢是訪問速度快,對事務完整性沒有要求,以select、insert為主的應用基本上都可以使用這個引擎;

 InnoDB存儲引擎

5.5之後默認的存儲引擎,提供了具有提交、回滾和奔潰恢復能力的事務安全,支持外鍵並提供了行級鎖,其劣勢在於寫的處理效率相對較低,並且會佔用更多的磁盤空間以保留數據和索引;

 MEMORY存儲引擎

使用存於內存中的內容來創建表,MEMORY類型的表數據存於內存訪問非常的快,默認使用HASH索引,一旦數據庫服務重啟或關閉,表中的數據就會丟失;

 MERGE存儲引擎

MERGE存儲引擎是一組MyISAM表組合,這些MyISAM表結構完全相同。MERGE表本身沒有數據,對MERGE表的CRUD操作都是通過內部的MyISAM表進行的;

mongoDB 主要使用在什麼應用場景?

 答:MongoDB 的應用已經滲透到各個領域,比如遊戲、物流、電商、內容管理、社交、物聯網、視頻直播等,以下是幾個實際的應用案例:

 遊戲場景,使用 MongoDB 存儲遊戲用戶信息,用戶的裝備、積分等直接以內嵌文檔的形式存儲,方便查詢、更新

 物流場景,使用 MongoDB 存儲訂單信息,訂單狀態在運送過程中會不斷更新,以MongoDB 內嵌數組的形式來存儲,一次查詢就能將訂單所有的變更讀取出來。

 社交場景,使用 MongoDB 存儲存儲用戶信息,以及用戶發表的朋友圈信息,通過地理位置索引實現附近的人、地點等功能

 物聯網場景,使用 MongoDB 存儲所有接入的智能設備信息,以及設備彙報的日誌信息,並對這些信息進行多維度的分析

 視頻直播,使用 MongoDB 存儲用戶信息、禮物信息等

6、數據庫範式?

範式內容

1NF每一列都是不可分割的基本數據項,同一列無二值;無重複的域;

2NF實例依賴於主鍵部分;

3NF屬性不依賴於其他非主屬性;

8、什麼情況下設置了索引但無法使用?

① 以“%”開頭的LIKE語句,模糊匹配

② OR語句前後沒有同時使用索引

③ 數據類型出現隱式轉化(如varchar不加單引號的話可能會自動轉換為int型

9、數據庫中的事務是什麼?

事務(transaction)是作為一個單元的一組有序的數據庫操作。如果組中的所有操作都成功,則認為事務成功,即使只有一個操作失敗,事務也不成功。如果所有操作完成,事務則提交,其修改將作用於所有其他數據庫進程。如果一個操作失敗,則事務將回滾,該事務所有操作的影響都將取消。ACID 四大特性,原子性、隔離性、一致性、持久性。

瞭解XSS攻擊嗎?如何防止SQL注入?

XSS是跨站腳本攻擊,首先是利用跨站腳本漏洞以一個特權模式去執行攻擊者構造的腳本,然後利用不安全的Activex控件執行惡意的行為。

使用htmlspecialchars()函數對提交的內容進行過濾,使字符串裡面的特殊符號實體化。

防止SQL注入的方式:

開啟配置文件中的magic_quotes_gpc 和 magic_quotes_runtime設置

執行sql語句時使用addslashes進行sql語句轉換

Sql語句書寫儘量不要省略雙引號和單引號。

過濾掉sql語句中的一些關鍵詞:update、insert、delete、select、 * 。

提高數據庫表和字段的命名技巧,對一些重要的字段根據程序的特點命名,取不易被猜到的。

Php配置文件中設置register_globals為off,關閉全局變量註冊

控制錯誤信息,不要在瀏覽器上輸出錯誤信息,將錯誤信息寫到日誌文件中。

5、Ndinx與apache的區別?

Nginx

輕量級,採用 C 進行編寫,同樣的 web 服務,會佔用更少的內存及資源

抗併發,nginx 以 epoll and kqueue 作為開發模型,處理請求是異步非阻塞的,負載能力比 apache 高很多,而 apache 則是阻塞型的。在高併發下 nginx 能保持低資源低消耗高性能 ,而 apache 在 PHP 處理慢或者前端壓力很大的情況下,很容易出現進程數飆升,從而拒絕服務的現象。

nginx 處理靜態文件好,靜態處理性能比 apache 高三倍以上

nginx 的設計高度模塊化,編寫模塊相對簡單

nginx 配置簡潔,正則配置讓很多事情變得簡單,而且改完配置能使用 -t 測試配置有沒有問題,apache 配置複雜 ,重啟的時候發現配置出錯了,會很崩潰

nginx 作為負載均衡服務器,支持 7 層負載均衡

nginx 本身就是一個反向代理服務器,而且可以作為非常優秀的郵件代理服務器

啟動特別容易, 並且幾乎可以做到 7*24 不間斷運行,即使運行數個月也不需要重新啟動,還能夠不間斷服務的情況下進行軟件版本的升級

社區活躍,各種高性能模塊出品迅速

Apache

apache 的 rewrite 比 nginx 強大,在 rewrite 頻繁的情況下,用 apache

apache 發展到現在,模塊超多,基本想到的都可以找到

apache 更為成熟,少 bug ,nginx 的 bug 相對較多

apache 超穩定

apache 對 PHP 支持比較簡單,nginx 需要配合其他後端用

apache 在處理動態請求有優勢,nginx 在這方面是雞肋,一般動態請求要 apache 去做,nginx 適合靜態和反向。

apache 仍然是目前的主流,擁有豐富的特性,成熟的技術和開發社區

"

相關推薦

推薦中...