溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

基于CentOS6.7編譯安裝LAMP

發(fā)布時(shí)間:2020-07-18 12:45:56 來(lái)源:網(wǎng)絡(luò) 閱讀:1295 作者:good_joe 欄目:數(shù)據(jù)庫(kù)

一、所需軟件下載

測(cè)試機(jī)環(huán)境為:

基于CentOS6.7編譯安裝LAMP

Httpd2.4 下載:http://mirrors.cnnic.cn/apache//httpd/httpd-2.4.25.tar.bz2

Apr 下載http://mirrors.hust.edu.cn/apache//apr/apr-1.5.2.tar.bz2

Apr-util 下載

http://mirrors.hust.edu.cn/apache//apr/apr-util-1.5.4.tar.bz2

Mariadb 10.1.21 下載https://downloads.mariadb.org/ 官網(wǎng)下載目前不知道什么原因下載不了,需要通過(guò)特殊渠道(你懂得)來(lái)獲取最新的軟件。

php5.6.30 下載:http://php.net/get/php-5.6.30.tar.bz2/from/a/mirror

目前最新版已到7.1.2還是保守一點(diǎn)選擇了5.6的版本。編譯php時(shí)會(huì)依賴到其他的包,所以提前通過(guò)yum 安裝

yum install libxml2-devel bzip2-devellibmcrypt -y

Xcache php加速工具 下載:http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz

編譯xcache 需要依賴的包有m4和autoconf兩個(gè)包

yum install m4 autoconf -y

phpmyadmin 下載:

https://files.phpmyadmin.net/phpMyAdmin/4.6.6/phpMyAdmin-4.6.6-all-languages.zip


二、httpd安裝


centos6.7中安裝的apr版本較低,編譯httpd2.4所需較新的版本,而直接通過(guò)yum升級(jí)系統(tǒng)現(xiàn)有版本apr包時(shí)可能會(huì)將其他依賴此程序包的軟件,因?yàn)閍pr的升級(jí)造成無(wú)法啟動(dòng),所以保險(xiǎn)起見(jiàn)自己手動(dòng)編譯新版本。

1、apr安裝

~]# tar –jxf apr-1.5.2.tar.bz2 –C /usr/local/src 
~]# tar –jxf apr-util-1.5.4.tar.bz2 –C /usr/local/src
~]# cd /usr/local/src/apr-1.5.2
~]# ./confirure –prefix=/usr/local/apr
~]# make && make install     #apr安裝完成
~]# cd /usr/local/src/apr-util-1.5.4
~]# ./configure –prefix=/usr/local/apr-util –with-apr=/usr/local/apr  #with-apr參數(shù)指定編譯apr-util時(shí)所依賴的程序包,如不指定則編譯時(shí)會(huì)查找系統(tǒng)默認(rèn)的安裝路徑去查找。
~]# make && make install

很多人都會(huì)有疑問(wèn)apr到底有什么作用,為什么每次編譯都要用到這個(gè)包?

APR(Apache portable Run-time librariesApache可移植運(yùn)行庫(kù))的目的如其名稱一樣,主要為上層的應(yīng)用程序提供一個(gè)可以跨越多操作系統(tǒng)平臺(tái)使用的底層支持接口庫(kù)。

APR最大的作用就是socket調(diào)度。

2、httpd安裝

將下載的httpd-2.4.25解壓至/usr/local/src目錄中

~]# tar –jxf httpd-2.4.25.tar.bz2 –C /usr/local/src
~]# cd /usr/local/src/httpd-2.4.25
~]# ./configure –prefix=/usr/local/apache –sysconfdir=/etc/apache–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=prefork
~]# make –j 4 && make install
#安裝完成之后進(jìn)行啟動(dòng)前配置,添加啟動(dòng)用戶和組
~]# groupadd –r –g 80 apache
~]# useradd –r –g apache –u 80 apache
#為apache提供服務(wù)腳本
~]# vim /etc/rc.d/init.d/apache
#!/bin/bash
#
#httpd        Startup script for theApache HTTP Server
#
#chkconfig: - 85 15
#description: Apache is a World Wide Web server. It is used to serve \
#        HTML files and CGI.
#processname: httpd
# config:/etc/httpd/conf/httpd.conf
# config:/etc/sysconfig/httpd
#pidfile: /var/run/httpd.pid
 
# Sourcefunction library.
./etc/rc.d/init.d/functions
 
if [ -f/etc/sysconfig/httpd ]; then
        . /etc/sysconfig/httpd
fi
 
# Starthttpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}
 
# Thiswill prevent initlog from swallowing up a pass-phrase prompt if
# mod_sslneeds a pass-phrase from the user.
INITLOG_ARGS=""
 
# SetHTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# withthe thread-based "worker" MPM; BE WARNED that some modules may not
# workcorrectly with a thread-based MPM; notably PHP will refuse to start.
 
# Path tothe apachectl script, server binary, and short-form for messages.
apachectl=/usr/local/apache/bin/apachectl
httpd=${HTTPD-/usr/local/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
RETVAL=0
 
start() {
  echo -n $"Starting $prog: "
  LANG=$HTTPD_LANG daemon --pidfile=${pidfile}$httpd $OPTIONS
  RETVAL=$?
  echo
  [ $RETVAL = 0 ] && touch${lockfile}
  return $RETVAL
}
 
stop() {
  echo -n $"Stopping $prog: "
  killproc -p ${pidfile} -d 10 $httpd
  RETVAL=$?
  echo
  [ $RETVAL = 0 ] && rm -f ${lockfile}${pidfile}
}
reload(){
    echo -n $"Reloading $prog: "
    if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t>&/dev/null; then
        RETVAL=$?
        echo $"not reloading due toconfiguration syntax error"
        failure $"not reloading $httpd dueto configuration syntax error"
    else
        killproc -p ${pidfile} $httpd -HUP
        RETVAL=$?
    fi
    echo
}
 
# See howwe were called.
case"$1" in
  start)
  start
  ;;
  stop)
  stop
  ;;
  status)
        status -p ${pidfile} $httpd
  RETVAL=$?
  ;;
  restart)
  stop
  start
  ;;
  condrestart)
  if [ -f ${pidfile} ] ; then
    stop
    start
  fi
  ;;
  reload)
        reload
  ;;
  graceful|help|configtest|fullstatus)
  $apachectl $@
  RETVAL=$?
  ;;
  *)
  echo $"Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
  exit 1
esac
 
exit $RETVAL
~]# chmod +x /etc/rc.d/init.d/apache
~]# chkconfig –add apache
~]# service apache start         #測(cè)試啟動(dòng)是否成功

默認(rèn)情況下系統(tǒng)防火墻會(huì)將80端口禁止通信,網(wǎng)上好多編譯安裝時(shí),為了方便都會(huì)將防火墻關(guān)閉,我覺(jué)得生產(chǎn)環(huán)境中關(guān)閉防火墻畢竟不×××全,估計(jì)也沒(méi)人這么干,現(xiàn)在就將用到的80端口以及mariadb和php用到的3306、9000端口都開(kāi)放。

~]# iptables –I INPUT –p ctp –m multiport –dports80,8080,3306,9000 –m state –state NEW,ESTABLISHED –j ACCEPT
#注:防火墻策略一般是自上而下審核,所以為了避免與其他策略沖突,直接將此條策略加入到最上方。
~]# setenforce 0    #設(shè)置selinux為Permissive模式,后續(xù)可能會(huì)將htdocs目錄指向其他路徑,如果不設(shè)為Permissive會(huì)無(wú)法訪問(wèn)。

最后在瀏覽器中填入測(cè)試機(jī)的IP地址,配置成功會(huì)有以下顯示。

基于CentOS6.7編譯安裝LAMP

三、mariadb安裝


首先將mysql用戶mysql組。

~]# groupadd –r –g 36 mysql
~]# useradd –r –g mysql –u 36 mysql

此處使用的是二進(jìn)制格式的程序包,解壓至特定路徑后簡(jiǎn)單配置后即可使用。

在生產(chǎn)環(huán)境當(dāng)中數(shù)據(jù)庫(kù)文件會(huì)單獨(dú)存放在一個(gè)較大的空間當(dāng)中,在此測(cè)試機(jī)中模擬有兩塊硬盤(pán),在兩塊硬盤(pán)當(dāng)中各劃分出50G的空間來(lái)組成邏輯卷來(lái)存放數(shù)據(jù)文件,下邊就來(lái)進(jìn)行具體操作。

~]# yum install lvm2                 #此步如果系統(tǒng)中已安裝lvm管理工具可跳過(guò)
~]# pvcreate /dev/sd{a,b}3     #將硬盤(pán)a,b中的分區(qū)添加到物理卷
~]# vgcreate –s 16M datavg /dev/sd{a,b}3    #將物理卷中的兩塊物理卷加入到datavg物理卷組中
~]# lvcreate –L 50G –n marialv datavg          #將物理卷組中分出50G空間來(lái)創(chuàng)建marialv邏輯卷
~]# mkfs –t ext4 –m 1 –L “mariadata” –b 2048/dev/datavg/marialv  #格式化marialv邏輯卷
~]# mount /dev/datavg/marialv /data/
~]# mkdir /data/mariadb –p            #創(chuàng)建數(shù)據(jù)存放路徑
~]# chown mysq:mysql /data/mariadb #更改mariadb目錄的屬組屬主為mysql
#至此數(shù)據(jù)存放位置準(zhǔn)備完畢,如果需要開(kāi)機(jī)掛載此目錄則需要修改/etc/fstab文件
~]# tar –zxf mariadb-10.1.21-linux-x86_64.tar.gz –C/usr/local
~]# cd /usr/local
~]# ln –s mariadb-10.1.21 mysql             #默認(rèn)安裝配置都要mysql目錄中,所以需要將解壓后的數(shù)據(jù)庫(kù)做一個(gè)鏈接,也方便日后數(shù)據(jù)庫(kù)升級(jí),直接將鏈接更新即可。
~]# cd mysql
~]# chown –R root:mysql ./*                    #將程序包中的所有文件屬主屬組修改為root用戶mysql組
~]# scripts/mysql_install_db  --datadir=/data/mariadb –user=mysql   #此步驟需要注意,mysql_install_db只能在scripts目錄中執(zhí)行,執(zhí)行完畢之后如果不出意外安裝完成了o(╯□╰)o

先不要急著運(yùn)行,后續(xù)還要有點(diǎn)小調(diào)整,因?yàn)閙ariadb還木有配置文件和啟動(dòng)腳本呢!下邊就來(lái)將這兩項(xiàng)做好。

還是在mysql目錄中操作,這點(diǎn)需要注意

mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld  #添加啟動(dòng)腳本
mysql]# chkconfig –add mysqld
mysql]# mkdir /etc/mariadb
mysql]# cp support-files/my-larg.cnf  /etc/mariadb/my.cnf
#在support-files目錄中提供了三個(gè)針對(duì)不同硬件的配置文件,可以根據(jù)自己系統(tǒng)硬件的不同來(lái)自行選配,這里選擇的是my-larg.cnf
#編輯my.cnf并添加以下三個(gè)選項(xiàng)
mysql]# vim /etc/mariadb/my.cnf

[client]
#password   = your_password
port        = 3306
#socket     = /tmp/mysql.sock
socket      = /data/mariadb /mysql.sock
 
# Herefollows entries for some specific programs
# TheMariaDB server
[mysqld]
port        = 3306
socket = /data/mariadb /mysql.sock
#…省略其他不變的選項(xiàng)
thread_concurrency= 8                  #這個(gè)參數(shù)可以根據(jù)自己服務(wù)器硬件配置來(lái)更改,一般為CPU個(gè)數(shù)乘以2
datadir=/data/mariadb                      #數(shù)據(jù)庫(kù)存放路徑
innodb_file_per_table= on               #每個(gè)數(shù)據(jù)表存儲(chǔ)類型都是獨(dú)立的
skip_name_resolve = on                    #跳過(guò)數(shù)據(jù)庫(kù)反向解析主機(jī)名

mysql]#bin/mysql_secure_installation         #可以為root設(shè)置密碼,刪除匿名用戶等一些操作
配置完成可以運(yùn)行service mysqld start啟動(dòng)服務(wù)
 ~]#ss –nat|grep 3306    #可以看到端口已經(jīng)啟動(dòng)

基于CentOS6.7編譯安裝LAMP

四、PHP安裝

PHP的編譯安裝方式可以根據(jù)httpd編譯的方式不同也會(huì)有不同的編譯方式,之前的httpd mpm采用了event模式編譯,此處的php也采用modules模式編譯。

安裝之前先解決依賴關(guān)系,安裝bzip2-devel、libmcrypt-devel、libxml2-devel程序開(kāi)發(fā)包。

~]# yum install bzip-devel libmcrypt-devel libxml2-devel –y
~]# tar -Jxf php-5.6.30.tar.xz -C /usr/local/src     #解壓到src目錄中
~]# cd /usr/local/src/php-5.6.30
~]# ./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/php–with-config-file-scan-dir=/etc/php/php.d –with-bz2 –enable-maintainer-zts   #這堆參數(shù)太特么的燒腦了,背了兩天o(╯□╰)o

下邊來(lái)介紹下這些參數(shù)都有什么作用。

prefix:指定安裝路徑

with-mysql:指明依賴mysql位置

with-openssl:在依賴openssl模塊時(shí),是系統(tǒng)默認(rèn)的安裝位置時(shí)不用指定,可以自己找到。

with-mysqli:對(duì)于Mysql數(shù)據(jù)庫(kù)交互的另一種接口。

enable-mbstring:?jiǎn)?dòng)多字節(jié)字符的支持,對(duì)于中文務(wù)必開(kāi)啟。

with-freetype-dir:指明字體格式,讓php頁(yè)面支持更多字體顯示。

with-jpeg-dir:可以使用php處理jpeg格式的圖片。

with-png-dir:可以使用php處理png格式的圖片。

with-zlib:?jiǎn)?dòng)zlib壓縮傳輸功能。

with-libxml-dir:支持處理XML格式文檔。

enable-xml:xml功能。

enable-sockets:?jiǎn)⒂胮hp支持基于socket方式進(jìn)行通信。

with-apxs2:指定httpd第三方模塊編譯工具。

with-mcrypt:支持加解密庫(kù)。

with-config-file-scan-dir:指定PHP所有配置文件存放路徑。

with-bz2:支持bz2加密。

enable-maintainer-zts 如果httpd編譯是使用prefork模式,此項(xiàng)即可省略,若是使用event或worker模式編譯,此參數(shù)務(wù)必添加。

php]# make –j 4&& make install
#編譯完成之后使用httpd–M 即可看到php5模塊已經(jīng)加入到httpd中。
php]# cp php.ini-production/etc/php/php.ini  #為php添加配置文件
~]# vim/etc/apache/httpd.conf  #修改httpd配置文件以讓其支持php格式的文件
#查找AddType并在下邊添加兩條配置信息
AddTypeapplication/x-httpd-php .php
AddTypeapplication/x-httpd-php-source .phps
#查找DirectoryIndex在index.html前添加index.php
~]# serviceapache reload    #httpd重讀配置文件
~]# mv/usr/local/apache/htdocs/index.html /usr/local/apache/htdocs/index.php
<?php
  $link = mysql_connect(‘127.0.0.1’,’testuser’,’testuser’);
  If($link)
    echo “Mysql connect success !”;
  else
    echo “Mysql connect error !”;
  mysql_close();
  phpinfo();
?>

在瀏覽器中鍵入測(cè)試機(jī)的IP地址,正常情況下出現(xiàn)此測(cè)試頁(yè)面,證明安裝成功!

基于CentOS6.7編譯安裝LAMP

五、安裝Xcache為PHP提速

~]# tar -zxf xcache-3.2.0.tar.gz -C /usr/local/src/
~]# cd /usr/local/src/xcache-3.2.0/
xcache-3.2.0]# /usr/local/php/bin/phpize              #使用php的phpize工具生成configure編譯腳本
xcache-3.2.0]# ./configure –enable-xcache –with-php-config=/usr/local/php/bin/php-config
xcache-3.2.0]# make && make install
#注:安裝結(jié)束時(shí)會(huì)有以下信息:
#Installing sharedxtensions:/usr/local/php/lib/php/extensions/no-debug-non-zts-20131226
#將路徑復(fù)制下來(lái)

接下來(lái)將php于xcache整合

xcache-3.2.0]#cp xcache.ini /etc/php/php.d/
xcache-3.2.0]#vim /etc/php/php.d/xcache.ini
#找到zend_extension開(kāi)頭的行,修改為如下行:
zend_extension =/usr/local/php/lib/php/extensions/no-debug-non-zts-20131226/xcache.so

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

基于CentOS6.7編譯安裝LAMP

至此以modules模式安裝php完成??!你以為萬(wàn)事大吉了???騷年你還是太年輕了,下邊再來(lái)試試fcgi模式重新編譯安裝php?。。阋詾檫@半個(gè)月我閑著沒(méi)事干呢,哼?。?/span>

六、開(kāi)始

歇會(huì)!就這么任性!還得新開(kāi)一段,嘿嘿!

七、fpm模式編譯安裝PHP

http為了避免沖突可以重新編譯一次,方法與之前相同此處不做說(shuō)明,但要注意一點(diǎn)的是,如果要更改之前的安裝路徑什么的,最好要make clean一下。

下邊來(lái)重新編譯php:

php]# ./configure –prefix=/usr/local/php5.6 –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/php5.6 –with-config-file-scan-dir=/etc/php5.6/php.d–with-bz2

可以看出來(lái)fpm模式編譯則不需要apxsmaintainer兩個(gè)參數(shù)

php]# make –j 4 && make install
php]# cp php.ini-production /etc/php5.6/php.ini

該方式安裝的php是以獨(dú)立服務(wù)的方式向外提供服務(wù)的,所以需要為其提供啟動(dòng)腳本和配置文件。

配置文件在編譯包的sapi/fpm目錄中已經(jīng)存在,直接復(fù)制到/etc/rc.d/init.d目錄中即可

php]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm
php]# chmod +x /etc/rc.d/init.d/php-fpm                #為腳本設(shè)置執(zhí)行權(quán)限
php]# chkconfig –add php-fpm
php]# cp /usr/local/php5.6/etc/php-fpm.conf.default/usr/local/php5.6/etc/php-fpm.conf
#為啟動(dòng)腳本添加配置文件,并添加和修改配置信息
php5.6]# vim /usr/local/php5.6/etc/php-fpm.conf
pm.max_children= 50
pm.start_servers= 5
pm.min_spare_servers= 2
pm.max_spare_servers= 8
[global]
; Pid file
; Note: thedefault prefix is /usr/local/php/var
; Default Value:none
;pid =run/php-fpm.pid
pid = /usr/local/php5.6/var/run/php-fpm.pid
php配置完成啟動(dòng)試試
~]# service php-fpm start     #不出意外的話啟動(dòng)成功

下邊配置httpd的配置選項(xiàng)來(lái)讓其支持php格式文件

~]# vim /etc/apache/httpd.conf
#查找到mod_proxy和mod_proxy_fcgi兩個(gè)模塊將其注釋去掉,啟動(dòng)該功能,
LoadModule proxy_modulemodules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
 
AddTypeapplication/x-httpd-php .php
AddType application/x-httpd-php-source .phps
DirectoryIndex index.php index.html
#保存退出,重新載入httpd配置
~]# service apache reload

哦對(duì)了,還有一項(xiàng)特別重要的事項(xiàng):fpm模式編譯的Php向httpd提供服務(wù)時(shí),此時(shí)的httpd則相當(dāng)于服務(wù)器中的前端,當(dāng)接收到php動(dòng)態(tài)請(qǐng)求時(shí)則通過(guò)反向代理配置將請(qǐng)求送到后端Php服務(wù)器當(dāng)中處理,下面來(lái)啟用httpd中的虛擬機(jī)配置,并將虛擬機(jī)配置反向代理

1. httpd2.4配置虛擬主機(jī)的操作與2.2有所不同,2.4當(dāng)中將虛擬主機(jī)設(shè)置為單獨(dú)的模塊來(lái)加載,需要啟用而且要將DocumentRoot 中心主機(jī)禁用,下邊貼出配置:

~]# vim /etc/apache/httpd.conf
#DocumentRoot "/usr/local/apache/htdocs"  #該項(xiàng)注釋
# Virtual hosts
Include /etc/apache/extra/httpd-vhosts.conf  #將該項(xiàng)啟用
#保存退出

2. 編輯/etc/apache/extra/httpd-vhosts.conf 虛擬主機(jī)配置文件,httpd2.4的虛擬主機(jī)都在此文件中配置

<VirtualHost*:80>
DocumentRoot "/usr/local/apache/htdocs/"
ServerName www.testphp.com
ErrorLog "logs/testphp.com-error_log"
CustomLog "logs/testphp.com-access_log" combined
<Directory “/usr/local/apache/htdocs”>
      Options None
      AllowOverride None
      <RequireAll>
       Require allgranted
      <RequireAll>
ProxyRequests Off                 #關(guān)閉正向代理
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/apache/htdocs/$1
</Directory>
</VirtualHost>

保存退出后,重新加載httpd配置

至此所有配置以全部完成,這半個(gè)多月的煎熬總算是整理完成了,后續(xù)看看將https加入到中間來(lái),進(jìn)一步擴(kuò)充其中的功能,先到這吧,歇了!

基于CentOS6.7編譯安裝LAMP


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI