1、安裝依賴庫和開發工具
yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel
e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers
2、安裝nginx 的依賴庫
yum -y install pcre-devel zlib-devel
3、安裝PHP所依賴的庫
yum -y install gd-devel libjpeg-devel libpng-devel freetype-devel libxml2-devel curl-devel freetype-devel
4、安裝MySQL所依賴的庫文件
yum -y install bison gcc gcc-c++ autoconf automake zlib* libxml* ncurses-devel libtool-ltdl-devel* mysql-devel
下載軟件包
在/opt目錄下分別創建nginx、mysql、php目錄來放置所需要的各種軟件包
5、安裝nginx:
nginx 的 gzip模塊需要 zlib 庫,rewrite模塊需要 pcre 庫,ssl 功能需要openssl庫
下載pcre庫:wget http://sourceforge.net/projects/pcre/files/pcre/8.33/pcre-8.33.tar.gz/download
下載zlib庫:wget http://zlib.net/zlib-1.2.8.tar.gz
下載ssl:wget http://www.openssl.org/source/openssl-1.0.1c.tar.gz
下載nginx:wget http://nginx.org/download/nginx-1.2.8.tar.gz
開始安裝:
(1)、安裝pcre庫
tar -zxvf pcre-8.33.tar.gz
cd pcre-8.33
./configure
make
make install
(2)、安裝zlib庫
tar -zxvf zlib-1.2.8.tar.gz
cd zlib-1.2.8
./configure
make
make install
(3)、安裝ssl(解壓縮即可)
tar -zxvf openssl-1.0.1c.tar.gz
(4)、安裝nginx (我們把 nginx 安裝在 /usr/local/nginx 目錄下)
tar -zxvf nginx-1.2.8.tar.gz
cd nginx-1.2.8
./configure
--prefix=/usr/local/nginx //安裝路徑
--pid-path=/usr/local/nginx/nginx.pid //pid文件路徑
--with-http_ssl_module //開啓HTTP SSL模塊,使NGINX可以支持HTTPS請求
--with-pcre=/opt/nginx/pcre-8.33//pcre源碼路徑
--with-zlib=/opt/nginx/zlib-1.2.8 //zlib源碼路徑
--with-openssl=/opt/nginx/openssl-1.0.1c//openssl 源碼路徑
make
make install
在安裝nginx的時候沒有給它指定用戶,默認是用Linux的系統用戶:nobody
安裝完成我們在 /usr/local/nginx文件夾下可以看到如下4個文件夾:
conf —— 配置文件目錄
logs —— 日誌目錄
html —— 默認站點根目錄
sbin —— nginx的可執行文件目錄
nginx的配置文件我們暫時先用默認的,等安裝完PHP—FPM,在回來更改nginx的配置文件,使它支持PHP請求
如果已經開啓了防火牆,在防火牆中添加80端口:
iptables -I INPUT -p tcp --dport 80 -j ACCEPT
service iptables save
service iptables restart
(5)、安裝完成,我們啓動nginx
/usr/local/nginx/sbin/nginx
然後我們用ps命令看下nginx進程是否啓動
我們通過瀏覽器訪問一下:http://192.168.1.61/
看到這個網頁內容,至此說明我們的nginx已經安裝成功
Nginx:管理
啓動:/usr/local/nginx/sbin/nginx
停止:/usr/local/nginx/sbin/nginx -s stop
重啓:/usr/local/nginx/sbin/nginx -s reload
(6)、我們把這個nginx 添加到開機啓動裏面:
vim /etc/rc.d/rc.local
把 /usr/local/nginx/sbin/nginx 添加到文件末尾即可
6、安裝MySql
安裝 mysql 需要依賴依賴cmake庫
下載cmake:wget http://www.cmake.org/files/v2.8/cmake-2.8.6.tar.gz
下載mysql:wget http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.33.tar.gz/from/http://cdn.mysql.com/
(1)、安裝cmake
tar -zxvf cmake-2.8.6.tar.gz
cd cmake-2.8.6
./configure
gmake && gmake install
(2)、添加mysql 用戶,並建立 mysql 數據文件夾
/usr/sbin/groupadd mysql //創建mysql 組
/usr/sbin/useradd -g mysql mysql //創建 mysql 用戶
mkdir -p /data/mysql
chown -R mysql:mysql /data/mysql
(3)、安裝mysql
tar -zxvf mysql-5.5.33.tar.gz
cd mysql-5.5.33
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/data/mysql
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
-DSYSCONFDIR=/etc/
-DMYSQL_USER=mysql
make && make install
cmake的時候,參數可以不用那麼多,只要一個-DCMAKE_INSTALL_PREFIX=/usr/local/mysql就行了,我們可以在my.cnf裏面配置
更改mysql安裝目錄的權限:chown -R mysql:mysql /usr/local/mysql
(4)、生成mysql的默認授權表
/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/data/mysql --user=mysql
(5)、修改mysql的配置文件
cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf
vi /etc/my.cnf
增加以下內容:
datadir = /data/mysql
log-error = /usr/local/mysql/mysql_error.log
pid-file = /usr/local/mysql/mysql.pid
(6)、啓動mysql
/usr/local/mysql/support-files/mysql.server start
(7)、修改mysql的默認密碼(默認密碼爲空)
/usr/local/mysql/bin/mysqladmin -u root password '123456'
(8)、mysql的管理
/usr/local/mysql/support-files/mysql.server {start|stop|restart|reload|force-reload|status}
(9)、開機啓動mysql
vi /etc/rc.d/rc.local
在最後添加 /usr/local/mysql/support-files/mysql.server start
OK,到此MySql安裝完成。
接下來安裝PHP、PHP—FPM
下載php:wget http://www.php.net/get/php-5.4.17.tar.gz/from/jp2.php.net/mirror
下載GD擴展所需要的庫文件:
下載zlib,安裝libpng和GD之前要先安裝zlib(zlib-1.2.8): wget http://sourceforge.net/projects/libpng/files/zlib/1.2.8/zlib-1.2.8.tar.gz/download?use_mirror=jaist&download
下載libpng:wget http://prdownloads.sourceforge.net/libpng/libpng-1.6.2.tar.gz
下載jpeg(jpegsrc.v9.tar.gz): wget http://www.ijg.org/files/jpegsrc.v9.tar.gz
下載freetype字體引擎: wget http://download.savannah.gnu.org/releases/freetype/freetype-2.4.12.tar.gz
下載mcrypt加密擴展,所需要的庫文件:
libmcrypt-2.5.7 : wget ftp://mcrypt.hellug.gr/pub/crypto/mcrypt/libmcrypt/libmcrypt-2.5.7.tar.gz
(1)、安裝zlib:
tar -zxvf zlib-1.2.8.tar.gz
cd zlib-1.2.8
./configure --prefix=/usr/local/bin/zlib
make && make install
(2)、安裝jpeg
tar -zxvf jpegsrc.v9.tar.gz
cd jpegsrc.v9
./configure --prefix=/usr/local/bin/jpeg --enable-shared --enable-static
make
make install
(3)、安裝png
tar -zxvf libpng-1.6.2.tar.gz
cd libpng-1.6.2
./configure --prefix=/usr/local/bin/libpng
make
make install
(4)、安裝freetype字體引擎
tar -zxvf freetype-2.4.12.tar.gz
cd freetype-2.4.12
./configure --prefix=/usr/local/lib/freetype
make
make install
(5)、安裝libmcrypt
tar -zxvf libmcrypt-2.5.7.tar.gz
cd libmcrypt-2.5.7
./configure
make
make install
cd libltdl/
./configure --enable-ltdl-install
make
make install
(6)、安裝PHP
tar -zxvf php-5.4.17.tar.gz
cd php-5.4.17
./configure
--prefix=/usr/local/php
--with-config-file-path=/usr/local/php/etc
--with-mysql=/usr/local/mysql
--with-mysqli=/usr/local/mysql/bin/mysql_config
--with-pdo-mysql=/usr/local/mysql
--with-jpeg-dir=/usr/local/bin/jpeg
--with-png-dir=/usr/local/bin/libpng
--with-zlib-dir=/usr/local/bin/zlib
--with-freetype-dir=/usr/local/bin/freetype
--with-gd
--with-mcrypt
--with-mhash
--with-openssl
--with-zlib
--with-bz2
--with-curl
--with-curlwrappers
--with-pcre-regex
--enable-fpm
--enable-cgi
--enable-bcmath
--enable-sockets
--enable-inline-optimization
--enable-mbstring
--enable-sysvsem
--enable-sysvshm
--enable-pcntl
--enable-zip
--enable-mbregex
--disable-rpath
make
make install
現在進行PHP、PHP-FPM的配置
進入到PHP安裝目錄的配置文件etc目錄下 :cp php-fpm.conf.default ./php-fpm.conf
進入到PHP的源碼目錄下,找到 php.ini-production 文件 複製到 /usr/local/php/etc/php.ini
php-fpm配置:
pid = run/php-fpm.pid
error_log = log/php-fpm.log
把這兩句前面的分號去掉。
管理PHP-FPM:
啓動php-fpm:/usr/local/php/sbin/php-fpm
關閉php-fpm:kill -INT `cat /usr/local/php/var/run/php-fpm.pid`
重啓php-fpm:kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`
現在修改 nginx 配置,來支持php:
#運行用戶
user nobody;
#啓動進程,通常設置成和cpu的數量相等
worker_processes 1;
#全局錯誤日誌及PID文件
error_log logs/error.log;
pid /usr/local/nginx/nginx.pid;
#工作模式及連接數上限
events {
#epoll是多路複用IO(I/O Multiplexing)中的一種方式,
#僅用於linux2.6以上內核,可以大大提高nginx的性能
use epoll;
#單個後臺worker process進程的最大併發鏈接數
worker_connections 1024;
# 併發總數是 worker_processes 和 worker_connections 的乘積
# 即 max_clients = worker_processes * worker_connections
# 在設置了反向代理的情況下,max_clients = worker_processes * worker_connections / 4 爲什麼
# 爲什麼上面反向代理要除以4,應該說是一個經驗值
# 根據以上條件,正常情況下的Nginx Server可以應付的最大連接數爲:4 * 8000 = 32000
# worker_connections 值的設置跟物理內存大小有關
# 因爲併發受IO約束,max_clients的值須小於系統可以打開的最大文件數
# 而系統可以打開的最大文件數和內存大小成正比,一般1GB內存的機器上可以打開的文件數大約是10萬左右
# 我們來看看360M內存的VPS可以打開的文件句柄數是多少:
# $ cat /proc/sys/fs/file-max
# 輸出 34336
# 32000 < 34336,即併發連接總數小於系統可以打開的文件句柄總數,這樣就在操作系統可以承受的範圍之內
# 所以,worker_connections 的值需根據 worker_processes 進程數目和系統可以打開的最大文件總數進行適當地進行設置
# 使得併發總數小於操作系統可以打開的最大文件數目
# 其實質也就是根據主機的物理CPU和內存進行配置
# 當然,理論上的併發總數可能會和實際有所偏差,因爲主機還有其他的工作進程需要消耗系統資源。
# ulimit -SHn 65535
}
http {
#設定mime類型,類型由mime.type文件定義
include mime.types;
default_type application/octet-stream;
#設定日誌格式
access_log logs/access.log;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
#sendfile 指令指定 nginx 是否調用 sendfile 函數(zero copy 方式)來輸出文件,
#對於普通應用,必須設爲 on,
#如果用來進行下載等應用磁盤IO重負載應用,可設置爲 off,
#以平衡磁盤與網絡I/O處理速度,降低系統的uptime.
sendfile on;
#tcp_nopush on;
#連接超時時間
#keepalive_timeout 0;
keepalive_timeout 65;
tcp_nodelay on;
#開啓gzip壓縮
gzip on;
gzip_disable "MSIE [1-6].";
#設定請求緩衝
client_header_buffer_size 128k;
large_client_header_buffers 4 128k;
#設定虛擬主機配置
server {
#偵聽80端口
listen 80;
#定義使用 www.testphp.cn訪問
server_name www.testphp.cn;
#定義服務器的默認網站根目錄位置
root /data/www/testphp;
#設定本虛擬主機的訪問日誌
access_log logs/testphp.access.log main;
#默認請求
location / {
#定義首頁索引文件的名稱
index index.php index.html index.htm;
}
# 定義錯誤提示頁面
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
#靜態文件,nginx自己處理
location ~ ^/(images|javascript|js|css|flash|media|static)/ {
#過期30天,靜態文件不怎麼更新,過期可以設大一點,
#如果頻繁更新,則可以設置得小一點。
expires 30d;
}
#PHP 腳本請求全部轉發到 FastCGI處理. 使用FastCGI默認配置.
location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
#禁止訪問 .htxxx 文件
location ~ /.ht {
deny all;
}
}
}