編譯安裝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
#添加二進制程序路徑 [root@localhost man]# vim /etc/profile.d/httpd.sh
[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
#添加腳本,並且啓動程序 [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
[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文檔,命令路徑,頭文件,庫文件
[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
[root@localhost lib]# ldconfig [root@localhost lib]# vim /etc/profile.d/mysqld.sh
[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發現就不需要密碼了
四、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 如下圖
[root@localhost ~]# cd /usr/local/apache/htdocs/ [root@localhost htdocs]# mv index.html index.php [root@localhost htdocs]# vim index.php
[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
注意:如果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即可