LAMP系列之一Apache服務器、MySQL服務器和PHP服務器實現互通

一、LAMP簡介

      LAMP(Linux- Apache-MySQL-PHP)網站架構是目前流行的Web框架,該框架由:Linux操作系統,Apache網絡服務器,MySQL數據庫,PHP編程語言組成,所有組成產品均是開源軟件,是國際上流行成熟的架構框架,很多流行的商業應用都採取這個架構。

      LAMP具有通用、跨平臺、高性能、低價格的優勢,因此LAMP無論是性能、質量還是價格都是企業搭建網站的首選平臺。

二、相關說明

      1、本篇(LAMP系列之一)主要介紹整個平臺架構的搭建:Apache2.4.9的編譯安裝,mysql-5.5.33的安裝,php-5.4.26的編譯安裝,以及整個平臺的互聯;第二篇將介紹《LAMP的php加速軟件xcache安裝以及性能測試》;第三篇將介紹《LAMP對Apache使用NFS用DNS實現負載均衡》。

      2、爲了真實的實現,模擬環境將使用3臺服務器,Apache服務器,php服務器和Mysql數據庫服務器

      3、關於IP:Apache(172.16.22.100),php(172.16.22.101),Mysql(172.16.22.102)

      4、關於DNS服務器的搭建本文不做詳介,而是使用修改hosts文件來做名稱解析

clip_p_w_picpath001

三、Apache2.4.9的編譯安裝

     1、解決依賴關係

     httpd-2.4.9需要較新版本的apr和apr-util,因此需要事先對其進行升級。事先我們還應該裝好開發包組和pcre。

    #yum -y install pcre-devel    
    #yum -y groupinstall "Development tools"    
    #yum -y groupinstall "Server Platform Development"

對於安裝過程中使用的apr,apr-util和httpd就使用下圖中的這幾個:

clip_p_w_picpath002

    1)編譯安裝apr

         # tar xf apr-1.5.0.tar.bz2    
         # cd apr-1.5.0    
         # ./configure --prefix=/usr/local/apr    
         # make && make install

    2)編譯安裝apr-util

         # tar xf apr-util-1.5.3.tar.bz2    
         # cd apr-util-1.5.3    
         # ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr    
         # make && make install

     2、編譯安裝httpd-2.4.9

         # tar xf httpd-2.4.9.tar.bz2    
         # cd httpd-2.4.9    
         # ./configure --prefix=/usr/local/apache24 --sysconfdir=/etc/httpd24 --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=event    
         # make && make install    
     在httpd-2.4.9的安裝路徑選擇上,爲了不和系統上的httpd衝突,我們指定將其安裝路徑改爲/usr/local/apache24,配置文件裝到/etc/httd24中,同時將服務也要改爲httpd24

     選項說明:--prefix指定安裝路徑,--sysconfdir指定配置文件路徑,--enalbe-so支持基於DMO的方式動態加載模塊,--enable-ssl支持https協議,--enable-cgi支持cgi機制,--enable-rewrite支持URL重寫,--with-zlib支持網頁數據壓縮,--enable-modules=most啓用大多數的常用模塊,--with-mpm=event默認的mpm模塊爲event  --with-pcre用peer作正則表達式

    3、修改httpd的主配置文件,設置其pid文件的路徑。/var/run作用是服務的鎖文件目錄,因爲在httpd2.4中,其pid的位置變的很詭異,不在/var/run下,所以我們就給它修改到/var/run下,只要設置對了就好了。

          修改:vim /etc/httpd24/httpd.conf添加

                 PidFile "/var/run/httpd24.pid"

   4、提供SysV服務腳本/etc/rc.d/init.d/http24

       這個腳本就不用寫,可以直接修改httpd的服務腳本就好了,先拷貝一份

       [root@apache-server ~]# cp /etc/rc.d/init.d/httpd /etc/rc.d/init.d/httpd24

      將httpd的腳本,改爲httpd24並編輯/etc/rc.d/init.d/httpd24 ,只需把這幾個變量改了就好了,下面的start(),stop()等參數都是調用的這幾個變量,所以別的無需修改。保存退出後不需要再給執行權限了,已經有了。

clip_p_w_picpath003

    5、輸出二進制程序

        #vim /etc/profile.d/httpd24.sh    
                export PATH=/usr/local/apache24/bin:$PATH    
        #source /etc/profile.d/httpd.sh

    6、把httpd24添加到系統服務,並測試

clip_p_w_picpath004

     7、導出頭文件

clip_p_w_picpath005

      8、導出man幫助手冊,編輯vim /etc/man.config

clip_p_w_picpath006

四、安裝mysql-5.5.33

     下載mysql-5.5.33-linux2.6-x86_64.tar.gz軟件包

     1、準備數據存放的文件系統

     因爲數據總是在動態增長的,所以我們要創建一個邏輯捲來保存數據。使用/dev/sdb1這個分區來創建邏輯卷。

      1)準備磁盤爲LVM格式

clip_p_w_picpath007

      2)創建lvm並格式化

clip_p_w_picpath008

            [root@mysql-server ~]# mke2fs -t ext4 -L MYDATA -b 4096 -m 3 /dev/myvg/mylv

     2、設置開機自動掛載

      這裏假設其邏輯卷的掛載目錄爲/data,而後需要創建/mydata/data目錄做爲mysql數據的存放目錄。

          [root@mysql-server ~]#vim /etc/fatab

                  /dev/mapper/myvg-mylv /mydata/data ext4 defaults 0 0

     3、查看掛載情況

          [root@mysql-server ~]#mkdir -p /mydata/data

          [root@mysql-server ~]#mount -a

     4、爲mysql準備系統用戶和組

clip_p_w_picpath009

     5、修改屬主和屬組

clip_p_w_picpath010

     6、解壓mysql軟件包並查看配置文檔。開始配置就可以了

[root@mysql-server ~]#tar xf mysql-5.5.33-linux2.6-x86_64.tar.gz -C /usr/local/mysql

clip_p_w_picpath011

     7、進入/usr/local/mysql文件夾,修改屬主與屬組

             [root@mysql-server mysql]# chown -R root:mysql .

     8、初始化系統庫,進入到/usr/local/mysql

clip_p_w_picpath012

     9、爲mysql提供主配置文件my.cnf,並修改此文件中thread_concurrency的值爲你的CPU個數乘以2,另外還需要添加如下行指定mysql數據文件的存放位置

       [root@mysql-server ~]# cd /usr/local/mysql    
       [root@mysql-server ~]# \cp support-files/my-large.cnf  /etc/my.cnf

     在/etc/my.cnf文件中,修改

         thread_concurrency = 4

         #爲你的CPU個數乘以2

         datadir = /mydata/data

         #添加mysql數據文件的存放位置

      10、爲mysql提供sysv服務腳本並添加爲系統服務

clip_p_w_picpath013

      11、啓動mysql服務,看能否正常啓動

             [root@mysql-server mysql]#/etc/init.d/mysqld start

      12、後續操作

            爲了使用mysql的安裝符合系統使用規範,並將其開發組件導出給系統使用,這裏還需要進行如下步驟:

           1)輸出mysql的man手冊至man命令的查找路徑:

               編輯/etc/man.config,添加如下行即可:

                   MANPATH /usr/local/mysql/man

           2)輸出mysql的頭文件至系統頭文件路徑/usr/include:

                這可以通過簡單的創建鏈接實現:

               # ln -sv /usr/local/mysql/include /usr/include/mysql

           3)輸出mysql的庫文件給系統庫查找路徑:

              # echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

              而後讓系統重新載入系統庫:

              # ldconfig

          4)修改PATH環境變量,讓系統可以直接使用mysql的相關命令。具體實現過程這裏不再給出。

             # vim /etc/profile.d/mysql.sh

             #export PATH=/usr/local/mysql/bin:$PATH

             # source /etc/profile.d/mysql.sh

五、編譯安裝php-5.4.26

     下載php-5.4.26.tar.bz2軟件包

     1、編譯安裝php ,步驟和上面的都一樣,就不再給圖了,只給步驟

因爲我們這裏php和mysql服務器是分開部署的,不在本地,所以得考慮到數據庫的連接問題。

說明:如果使用PHP5.3以上版本,爲了鏈接MySQL數據庫,可以指定mysqlnd,這樣在本機就不需要先安裝MySQL或MySQL開發包了。mysqlnd從php 5.3開始可用,可以編譯時綁定到它(而不用和具體的MySQL客戶端庫綁定形成依賴),但從PHP 5.4開始它就是默認設置了。

     準備環境:安裝如下包,gcc包、libxml2-devel包、opensll-devel包、bzip2-devel包、libmcrypt-devel包

     [root@php-server ~]# tar xf php-5.4.26.tar.bz2    
     [root@php-server ~]# cd php-5.4.26    
     [root@php-server ~]# ./configure --prefix=/usr/local/php5 --with-openssl --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --enable-fpm --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

     [root@php-server ~]#make && make install

   說明:

         1)、這裏爲了支持apache的worker或event這兩個MPM,編譯時使用了--enable-maintainer-zts選項。

         2)、如果使用PHP5.3以上版本,爲了鏈接MySQL數據庫,可以指定mysqlnd,這樣在本機就不需要先安裝MySQL或MySQL開發包了。mysqlnd從php 5.3開始可用,可以編譯時綁定到它(而不用和具體的MySQL客戶端庫綁定形成依賴),但從PHP 5.4開始它就是默認設置了。

     2、爲php提供配置文件(我的php解壓在了/root/soft下,安裝在了/usr/local/php下)

    [root@php-server ~]# cp /root/php-5.4.26/php.ini-production /etc/php.ini

六、配置php-fpm

     因爲Apache服務器連接php服務器是通過fastcgi協議的,因此我們還需通過php-fpm對其進行配置。

    1、爲php-fpm提供SysV init腳本,並將其添加至服務列表:

        # cp /root/soft/php-5.4.26/sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm    
        # chmod +x /etc/rc.d/init.d/php-fpm    
        # chkconfig --add php-fpm    
        # chkconfig php-fpm on

    2、爲php-fpm提供配置文件:

        # cp /usr/local/php5/etc/php-fpm.conf.default /usr/local/php5/etc/php-fpm.conf

    3、配置php-fpm的相關選項,並啓用pid文件。啓動服務

       #vim /etc/php-fpm.conf

          pm.max_children = 50    
          pm.start_servers = 5    
          pm.min_spare_servers = 2

          pm.max_spare_servers = 8

          pid = /usr/local/php5/var/run/php-fpm.pid

       #servecie php-fpm start (啓動服務)

     4、修改fpm的默認監聽端口

         默認情況下,fpm監聽在127.0.0.1的9000端口,也可以使用如下命令驗正其是否已經監聽在相應的套接字。

       # netstat -tnlp | grep php-fpm

          tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN   689/php-fpm

        所以我們要把監聽端口改到我們的php服務器上

      #vim /usr/local/php5/etc/php-fpm.conf

           修改listen = 127.0.0.1:9000

           爲listen = 172.16.22.101:9000

       #servecie php-fpm restart (重啓服務)

       接下來就可以啓動php-fpm並驗證其否成功監聽了

      # ss -tnl (成功監聽php服務器的9000端口)

   使用如下命令來驗正(如果此命令輸出有中幾個php-fpm進程就說明啓動成功了):

       # ps aux | grep php-fpm

七、配置httpd-2.4.9

     1、啓用httpd的相關模塊

     在Apache httpd 2.4以後已經專門有一個模塊針對FastCGI的實現,此模塊爲mod_proxy_fcgi.so,它其實是作爲mod_proxy.so模塊的擴充,因此,這兩個模塊都要加載

         LoadModule proxy_module modules/mod_proxy.so

         LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

     編輯vim /etc/httpd24/httpd.conf文件

clip_p_w_picpath014

       2、繼續編輯Apache的主配置文件,讓apache能識別php格式的頁面,並支持php格式的主頁

            vim /etc/httpd24/httpd.conf

        1)添加如下二行

           AddType application/x-httpd-php .php

           AddType application/x-httpd-php-source .phps

        2)定位至 DirectoryIndex index.html

            修改爲:DirectoryIndex index.php index.html

      3、配置虛擬主機支持使用fcgi

        1)要使用虛擬主機,首先要關閉中心主機,再開啓虛擬主機的模塊兒,也是在/etc/httpd24/httpd.conf中

clip_p_w_picpath015

        2)配置虛擬主機

            [root@apache-server ~]# vim /etc/httpd24/extra/httpd-vhosts.conf

clip_p_w_picpath016

     說明:ProxyPassMatch:把以.php結尾的文件請求發送到php-fpm進程,php-fpm至少需要知道運行的目錄和URI,所以這裏直接在fcgi://127.0.0.1:9000後指明瞭這兩個參數,其它的參數的傳遞已經被mod_proxy_fcgi.so進行了封裝,不需要手動指定。所以php服務器都應該建立/var/www/html/這個目錄,然後把.php的動網頁文件放到這個目錄中來,Apache下只要保存靜態的index.html網頁,php服務器上只需保存動態的index.php即可。

    4、查看9000端口是誰在使用,並修改/var/www/html/目錄下的屬主數組權限。

        #lsof -i:9000

        #chown -R nobody:nobody /var/www/html/

八、測試Apache服務器與php服務器的互連

      在php服務器下的/var/www/html/目錄中創建index.php,Apache會自己去調用php服務器中的index.php。

      給php服務器中的主頁文件來個測試頁,並重啓下服務:

       #service httpd24 restart

clip_p_w_picpath017

        到windows上去訪問下www.whb.com試試,下面就是見證奇蹟的時刻

clip_p_w_picpath018

     Apache與php服務器的互聯成功

        補充:Apache httpd 2.4以前的版本中,要麼把PHP作爲Apache的模塊運行,要麼添加一個第三方模塊支持PHP-FPM實現。

九、測試php服務器與mysql服務器的互聯

     1、在php服務器上的index.php中加入連接mysql服務器的選項

clip_p_w_picpath019

     2、在mysql服務器上爲PHP服務器授權。index.php中要連接數據庫,必須要獲得mysql的授權。

 clip_p_w_picpath020

       3、測試能否成功連上mysql數據庫

clip_p_w_picpath021

            一切搞定,Apache服務器,php服務器,Mysql服務器,都可以實現聯通了。一個基本架構終於搞成了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章