編譯安裝LAM(MySQL)P

編譯安裝LAM(MySQL)P


  Linux+Apache+MySQL+PHP,其中MySQL逐漸被Mariadb取代。這裏依舊使用MySQL進行編譯,MySQL在國內下載鏡像站點,目前好像就只有mirrors.sohu.com依舊提供。這裏都是選擇的比較穩定的版本進行編譯。

  一、環境和軟件包版本介紹

   1. Linux :
        [root@localhost ~]# cat /etc/redhat-release 
        CentOS release 6.8 (Final)
        [root@localhost ~]# uname -r
        2.6.32-642.el6.x86_64
   2.Apache : 2.4版本
        [root@localhost ~]#  ls httpd-2.4.10.tar.bz2 
        httpd-2.4.10.tar.bz2
   3.MySQL : MySQL 5.5.52,據說MySQL8.0版本出來,很久不更新,一次更新就跨越多個版本。。不過絕大部分公司都轉向了Mariadb,這裏使用MySQL也只是學習一下怎麼構建這個平臺,隨後將有基於Mariadb的平臺構建。
        [root@localhost ~]# ls mysql-5.5.52-linux2.6-x86_64.tar.gz 
        mysql-5.5.52-linux2.6-x86_64.tar.gz
   4.PHP : PHP5.6.26
        [root@localhost ~]# ls php-5.6.26.tar.bz2 
        php-5.6.26.tar.bz2

  二、前期準備和Apache編譯

   1.下載開發包組
        [root@localhost ~]# yum groupinstall -y "Development Tools"
        [root@localhost ~]# yum groupinstall -y "Server Platform Development"
   2.解決以來關係,Aapache編譯需要依賴,apr、apr-util、pcre-devel
#安裝pcre開發包
[root@localhost ~]# yum install -y pcre-devel
#編譯安裝apr程序包
[root@localhost ~]# tar -xf apr-1.5.0.tar.bz2 
[root@localhost ~]# cd apr-1.5.0
[root@localhost apr-1.5.0]# ./configure --prefix=/usr/local/apr
[root@localhost apr-1.5.0]#make&&make install
#編譯安裝apr-util程序包
[root@localhost ~]# tar xf apr-util-1.5.2.tar.bz2 
[root@localhost ~]# cd apr-util-1.5.2
[root@localhost apr-util-1.5.2]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
[root@localhost apr-util-1.5.2]#make&&make install
#編譯安裝httpd程序包
[root@localhost ~]# tar xf httpd-2.4.10.tar.bz2 
[root@localhost ~]# cd httpd-2.4.9
[root@localhost httpd-2.4.10]# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --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
#導出庫文件,man文檔和添加當前二進制程序路徑到PATH環境變量

#導出庫文件
[root@localhost httpd-2.4.10]# cd /usr/include/
[root@localhost include]# ln -sv /usr/local/apache/include/  httpd
`httpd' -> `/usr/local/apache/include/'
#添加man文檔路徑
[root@localhost man]# vim /etc/man.config

bE0zGOv.png

#添加二進制程序路徑
[root@localhost man]# vim /etc/profile.d/httpd.sh

vWRvJEj.png

[root@localhost man]# . /etc/profile.d/httpd.sh
[root@localhost man]# echo $PATH
/usr/local/apache/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

#修改配置文件和添加服務腳本
#這裏只需要將原rpm包的啓動腳本拷貝進來,進行簡單修改即可

[root@localhost init.d]# vim httpd

Jg2cUYY.png

#添加腳本,並且啓動程序
[root@localhost init.d]# chkconfig --add httpd 
[root@localhost init.d]# chkconfig --list httpd
httpd           0:off   1:off   2:off   3:off   4:off   5:off   6:off
[root@localhost init.d]# service httpd start
如果你一直按照這個過程操作過來,有可能出現
[root@localhost htdocs]# service httpd status
httpd dead but subsys locked
這時請將原來的paifile 的路徑在啓動服務腳本httpd和配置文件httpd.conf中修改爲PidFile=/var/run/httpd.pid
補充:
(1)構建MPM爲靜態模塊
在全部平臺中,MPM都可以構建爲靜態模塊。在構建時選擇一種MPM,鏈接到服務器中。如果要改變MPM,必須重新構建。爲了使用指定的MPM,請在執行configure腳本 時,使用參數 --with-mpm=NAME。NAME是指定的MPM名稱。編譯完成後,可以使用 ./httpd -l 來確定選擇的MPM。 此命令會列出編譯到服務器程序中的所有模塊,包括 MPM。
(2)構建 MPM 爲動態模塊
在Unix或類似平臺中,MPM可以構建爲動態模塊,與其它動態模塊一樣在運行時加載。 構建 MPM 爲動態模塊允許通過修改LoadModule指令內容來改變MPM,而不用重新構建服務器程序。在執行configure腳本時,使用--enable-mpms-shared選項即可啓用此特性。當給出的參數爲all時,所有此平臺支持的MPM模塊都會被安裝。還可以在參數中給出模塊列表。默認MPM,可以自動選擇或者在執行configure腳本時通過--with-mpm選項來指定,然後出現在生成的服務器配置文件中。編輯LoadModule指令內容可以選擇不同的MPM

  三、MySQL編譯安裝

MySQ的數據文件我們應該單獨放在一個可以擴展的分區上面,因爲隨着時間增長他會逐漸變大

   1. 創建邏輯分區
[root@localhost ~]# fdisk /dev/sdb
#注意:修改分區類型8e
[root@localhost ~]# pvcreate /dev/sdb5
[root@localhost ~]# vgcreate data /dev/sdb5
[root@localhost ~]# lvcreate -n mydata -L 6G data
[root@localhost ~]# mkfs.ext4  /dev/mapper/data-mydata 
#文件的系統其他屬性根據實際需要自行制定,這裏使用默認
[root@localhost ~]# mount /dev/mapper/data-mydata /data
[root@localhost data]# mkdir data
#作爲數據庫存放目錄
[root@localhost data]# groupadd -r mysql
[root@localhost data]# useradd -r -g mysql -s /sbin/nologin -M -d /data/data mysql
#創建用戶和用戶組
[root@localhost data]# tar xf /root/mysql-5.5.52-linux2.6-x86_64.tar.gz -C /usr/local
#解壓MySQL壓縮文件
[root@localhost local]# ln -sv mysql-5.5.52-linux2.6-x86_64/ mysql
`mysql' -> `mysql-5.5.52-linux2.6-x86_64/'
#創建軟連接便於管理
[root@localhost mysql]# chown -R mysql. .
[root@localhost mysql]# scripts/mysql_install_db --user=mysql --data=/data/data
[root@localhost mysql]#  chown -R root  .
#記得屬主修改回來,爲了安全。
[root@localhost local]# cd mysql
[root@localhost support-files]# cp my-large.cnf  /etc/my.cnf
#這裏根據你的需要拷貝配置文件一下紅圈內都是配置文件
#並修改此文件中thread_concurrency的值爲你的CPU個數乘以2,比如這裏使用如下行:
thread_concurrency = 2
#另外還需要添加如下行指定mysql數據文件的存放位置:
datadir = /mydata/data

UIAnGaq.png[root@localhost data]# chown -R mysql. /data #將數據庫文件的屬主和屬組都設置爲mysql [root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld [root@localhost mysql]# chmod +x /etc/init.d/mysqld [root@localhost mysql]# chkconfig --add /etc/init.d/mysqld [root@localhost mysql]# chkconfig --list mysqld #這裏可以測試啓動,不過還沒添加mysql的man文檔,命令路徑,頭文件,庫文件 nA2EtFh.png

[root@localhost local]# cd /usr/include/
[root@localhost include]# ln -sv /usr/local/mysql/include/ mysql

[root@localhost lib]# vim /etc/ld.so.conf.d/mysql.conf

Y8nSiEV.png

[root@localhost lib]# ldconfig 
[root@localhost lib]# vim /etc/profile.d/mysqld.sh

YBHXycw.png

[root@localhost lib]# . /etc/profile.d/mysqld.sh

可以嘗試啓動,如果存在錯誤,就在/data/data/localhost.localdomain.err查看爲什麼啓動錯誤,這個文件存在未指定的數據庫存放路徑下,文件名爲你的主機名.err。

可以開始登陸mysql,登陸上mysql後,我們需要將所有的匿名賬戶刪除,把所有的賬戶都設置密碼,具體操作如下。
        # 所有語句均是SQL語句,需要在mysql客服端執行。
        use mysql
        SELECT user,host,password FROM user;
        DROP USER ''@'localhost';
        UPDATE user SET password=PASSWORD('114477') WHERE user='root';
        FLUSH PRIVILEGES;
        #操作完後我們發現需要密碼登陸,爲了方便我們也可以在家目錄下創建一個隱藏文件。
        [root@localhost ~]# vim .my.cnf
        #如此再次登陸mysql發現就不需要密碼了

jMPFqEU.png


  四、PHP編譯安裝

   1.PHP編譯安裝還需要依賴'Desktop Platform Development'
[root@localhost yum.repos.d]# yum groupinstall -y 'Desktop Platform Development'
[root@localhost yum.repos.d]# yum -y install bzip2-devel libmcrypt-devel
[root@localhost ~]# tar xf php-5.4.26.tar.bz2
[root@localhost ~]# cd php-5.4.26
[root@localhost php-5.4.26]# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml  --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  --enable-maintainer-zts
[root@localhost php-5.4.26]# make
#make 結束後,會提示你讓你make test,但是我嘗試幾次make test 都失敗了,錯誤提示各種各樣,百思不得其解。換了php版本依舊這樣,最後在網上求助一網友,他告訴我直接make && make install ,不用make test 。結果居然成功,沒有報錯。
[root@localhost php-5.4.26]# make install
[root@localhost php-5.4.26]# cp php.ini-production /etc/php.ini
#這裏有個開發配置文件,和生產配置文件。我這裏使用的生產配置文件。
#編輯apache配置文件httpd.conf,以apache支持php
# vim /etc/httpd/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
如下圖

0WaGpvg.png4YqZUCZ.pngpSquc8n.png[root@localhost ~]# cd /usr/local/apache/htdocs/ [root@localhost htdocs]# mv index.html index.php [root@localhost htdocs]# vim index.php 0ECPB1S.png

[root@localhost ~]#  ab -c 100 -n 1000 http://192.168.32.5/index.php
#進行壓力測試,結果如下
Server Software:        Apache/2.4.10 
#服務器Apache版本
Server Hostname:        192.168.32.5
#服務器主機名
Server Port:            80
#服務器開啓端口
Document Path:          /index.php
#請求的文件的相對路徑
Document Length:        69411 bytes
#請求的文件的大小
Concurrency Level:      100
#併發用戶數
Time taken for tests:   3.910 seconds
#測試一共使用時間
Complete requests:      1000
#測試完成的請求個數
Failed requests:        96
   (Connect: 0, Receive: 0, Length: 96, Exceptions: 0)
#測試失敗的個數
Write errors:           0
#寫錯誤
Total transferred:      69592892 bytes
#總共傳送的字節,包括首部因此HTML大
HTML transferred:       69410892 bytes
#傳送的HTML的字節
Requests per second:    255.73 [#/sec] (mean)
#吞吐率
#概念:服務器併發處理能力的量化描述,單位是reqs/s,指的是某個併發用戶數下單位時間內處理的請求數。某個併發用戶數下單位時間內能處理的最大請求數,稱之爲最大吞吐率。
#計算公式:總請求數 / 處理完成這些請求數所花費的時間。
Time per request:       391.040 [ms] (mean)
#用戶平均請求等待時間,計算公式:處理完成所有請求數所花費的時間/ (總請求數 / 併發用戶數)
Time per request:       3.910 [ms] (mean, across all concurrent requests)
#服務器平均請求等待時間,計算公式:處理完成所有請求數所花費的時間 / 總請求數
Transfer rate:          17379.75 [Kbytes/sec] received
#平均每秒網絡上的流量,可以幫助排除是否存在網絡流量過大導致響應時間延長的問題
Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    2   3.5      1      18
#連接
Processing:     6  287 413.1    159    3138
#處理
Waiting:        3  269 415.6    142    3137
#等待 
Total:          7  289 413.4    160    3148
#
Percentage of the requests served within a certain time (ms)
  50%    160
  66%    203
  75%    232
  80%    268
  90%   1007
  95%   1111
  98%   1184
  99%   3014
 100%   3148 (longest request)
#//整個場景中所有請求的響應情況。在場景中每個請求都有一個響應時間,其中50%的用戶響應時間小於160 毫秒,60% 的用戶響應時間小於203 毫秒,最大的響應時間小於3148 毫秒。由於對於併發請求,cpu實際上並不是同時處理的,而是按照每個請求獲得的時間片逐個輪轉處理的,所以基本上第一個Time per request時間約等於第二個Time per request時間乘以併發請求數

  五、啓用xcache加速

#1.安裝xcache
[root@localhost ~]# tar xf xcache-3.2.0.tar.gz 
[root@localhost ~]# cd xcache-3.2.0
[root@localhost xcache-3.2.0]# /usr/local/php/bin/phpize
#切記這個命令需要在被擴展的目錄下才能執行,不然他會提示錯誤 
[root@localhost xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
[root@localhost xcache-3.2.0]# make && make install
#Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-zts-20131226/
#將這條路徑複製到一個文本文件中,隨後會用到

#2、編輯php.ini,整合php和xcache:
#首先將xcache提供的樣例配置導入php.ini
[root@localhost xcache-3.2.0]# mkdir /etc/php.d
[root@localhost xcache-3.2.0]# cp xcache.ini /etc/php.d
[root@localhost xcache-3.2.0]#vim /etc/php.d/xcache.ini

r7dy64V.pngGQBjuJT.png

注意:如果php.ini文件中有多條zend_extension指令行,要確保此新增的行排在第一位。

  五、PHP-fpm編譯安裝

[root@localhost ~]# yum -y groupinstall "X Software Development
#httpd和mysql的編譯還是前面的操作
如果想讓編譯的php支持mcrypt擴展,此處還需要下載如下兩個rpm包並安裝之:
(libmcrypt-2.5.7-5.el5.i386.rpm
libmcrypt-devel-2.5.7-5.el5.i386.rpm
mhash-0.9.9-1.el5.centos.i386.rpm
mhash-devel-0.9.9-1.el5.centos.i386.rpm)版本和你當前服務的版本相通的rpm包

#1.開始編譯
[root@localhost ~]#tar xf php-5.4.26.tar.bz2
[root@localhost ~]# cd php-5.4.26
[root@localhost php-5.4.26]# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --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
#說明:如果使用PHP5.3以上版本,爲了鏈接MySQL數據庫,可以指定mysqlnd,這樣在本機就不需要先安裝MySQL或MySQL開發包了。mysqlnd從php 5.3開始可用,可以編譯時綁定到它(而不用和具體的MySQL客戶端庫綁定形成依賴),但從PHP 5.4開始它就是默認設置了。
#e.g. # ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

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

2、配置php-fpm

#爲php-fpm提供SysV init腳本,並將其添加至服務列表:
[root@localhost php-5.4.26]# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
#源碼目錄下
[root@localhost php-5.4.26]# chmod +x /etc/rc.d/init.d/php-fpm
[root@localhost php-5.4.26]# chkconfig --add php-fpm
[root@localhost php-5.4.26]# chkconfig php-fpm on

#編輯php-fpm的配置文件:
[root@localhost php-5.4.26]#vim /usr/local/php/etc/php-fpm.conf
#配置fpm的相關選項爲你所需要的值,並啓用pid文件(如下最後一行):
#pm.max_children = 50
#pm.start_servers = 5
#pm.min_spare_servers = 2
#pm.max_spare_servers = 8
#pid = /usr/local/php/var/run/php-fpm.pid 

接下來就可以啓動php-fpm了:
[root@localhost php-5.4.26]#service php-fpm start
#接下來可以啓動測試。
#在加上xcache會更加提高效率,將前面的xcache編譯執行一次
執行編譯完成後,因爲php是通過php-fpm管理,重新啓動php-fpm即可

總結:

  1.本次實驗中遇到了編譯httpd出錯,當時解決方案是將--enable-mpms-shared=most,這個參數改爲--enable-mpms-shared=all

  2.遇到不知道如何使用MySQL,完全不熟悉MySQL語句。和mysql完全啓動不起來,然後根據/data/data/localhost.localdomain.err查看爲什麼啓動錯誤,這個文件存在未指定的數據庫存放路徑下,文件名爲你的主機名.err。發現pid文件路徑寫錯了。MySQL服務腳本無法創建pid文件。

  3.編譯安裝xcache出錯,原因因爲/usr/local/php/bin/phpize這個命令需在被擴展的模塊的源碼目錄下才能執行。

  4.存在疑問,是php-fpm這個如何在不同主機上面配置,需要進一步學習。


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