centos下配置nginx+mysql+php+php-fpm方法

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
增加
以下內容:

basedir = /usr/local/mysql  
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;

        }
 
    }
}


發佈了31 篇原創文章 · 獲贊 7 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章