CentOS 6.3編譯安裝LAMP環(huán)境筆記
最近抽空在虛擬機上測試成功了LAMP各個最新版本的整合編譯安裝,算是把之前的博文整合精簡,以下內(nèi)容均在CENTOS6.3(安裝minimal desktop和默認(rèn)開發(fā)包)下測試安裝成功,并做了相應(yīng)優(yōu)化配置,如有遺漏,還請留言指教。
LINUX操作系統(tǒng):centOS6.3 64bit(安裝了系統(tǒng)默認(rèn)開發(fā)包)
APACHE:httpd-2.4.4
MYSQL:mysql-5.6.10
PHP:php-5.4.13
注:推薦安裝centos6.3系統(tǒng)時,在系統(tǒng)安裝向?qū)е?。將默認(rèn)開發(fā)包勾上,避免后期編譯報錯
一.安裝開發(fā)包(使用默認(rèn)CENTOS更新源):
# yum -y install wget gcc-c++ ncurses ncurses-devel cmake make perl bison openssl openssl-devel gcc* libxml2 libxml2-devel curl-devel libjpeg* libpng* freetype*
二.關(guān)閉iptables和SELINUX
# service iptables stop
# setenforce 0
# vi /etc/sysconfig/selinux
---------------
SELINUX=disabled
---------------
三.安裝mysql數(shù)據(jù)庫
1.下載編譯包:
2.安裝前的初始配置工作:
# useradd -d /usr/local/mysql/ mysql #創(chuàng)建一個Mysql用戶,指定家目錄到/use/local目錄下。
# mkdir /usr/local/mysql/data
# mkdir /usr/local/mysql/log #新建mysql下data和log子目錄
# chown -R mysql:mysql /usr/local/mysql/data/
# chown -R mysql:mysql /usr/local/mysql/log/
# chmod 750 /usr/local/mysql/data
# chmod 750 /usr/local/mysql/log #修改目錄的所屬者以及所屬組
3.解包編譯安裝
# tar -zxv -f mysql-5.6.10.tar.gz
# cd mysql-5.6.10
# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DDEFAULT_CHARSET=gbk \
-DDEFAULT_COLLATION=gbk_chinese_ci \
-DEXTRA_CHARSETS=all \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT=3306 \
-DSYSCONFDIR=/etc \
-DWITH_SSL=yes
# make & make install
編譯注解:
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #安裝目錄
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ #Unix socket文件路徑,自定義此路徑防報錯
-DDEFAULT_CHARSET=gbk \ #默認(rèn)字符
-DDEFAULT_COLLATION=gbk_chinese_ci \ #校驗字符
-DEXTRA_CHARSETS=all \ #安裝所有擴展字符集
-DWITH_MYISAM_STORAGE_ENGINE=1 \ #安裝myisam存儲引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安裝innodb存儲引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \ #安裝archive存儲引擎
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ #安裝blackhole存儲引擎
-DWITH_MEMORY_STORAGE_ENGINE=1 \ #安裝memory存儲引擎
-DWITH_FEDERATED_STORAGE_ENGINE=1 #安裝frderated存儲引擎
-DWITH_READLINE=1 \ #快捷鍵功能
-DENABLED_LOCAL_INFILE=1 \ #允許從本地導(dǎo)入數(shù)據(jù)
-DMYSQL_DATADIR=/usr/local/mysql/data \ #數(shù)據(jù)庫存放目錄
-DMYSQL_USER=mysql \ #數(shù)據(jù)庫屬主
-DMYSQL_TCP_PORT=3306 \ #數(shù)據(jù)庫端口
-DSYSCONFDIR=/etc \ #MySQL配輯文件
-DWITH_SSL=yes #數(shù)據(jù)庫SSL
4.編寫mysql配置項:
# vi /etc/my.cnf
[mysql]
# CLIENT #
port = 3306
socket = /tmp/mysql.sock
[mysqld]
# GENERAL #
user = mysql
default_storage_engine = InnoDB
socket = /tmp/mysql.sock
pid_file = /var/run/mysqld/mysqld.pid
# MyISAM #
key_buffer_size = 32M
myisam_recover = FORCE,BACKUP
# SAFETY #
max_allowed_packet = 16M
max_connect_errors = 1000000
skip_name_resolve
sql_mode = STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE,ONLY_FULL_GROUP_BY
sysdate_is_now = 1
innodb = FORCE
innodb_strict_mode = 1
# DATA STORAGE #
datadir = /usr/local/mysql/data
# BINARY LOGGING #
log-bin =/usr/local/mysql/log/bin.log
expire_logs_days = 30
sync_binlog = 1
# CACHES AND LIMITS #
key_buffer = 256M
max_allowed_packet = 32M
sort_buffer_size = 16M
read_buffer_size = 4M
read_rnd_buffer_size = 16M
thread_stack = 8M
tmp_table_size = 32M
max_heap_table_size = 32M
query_cache_type = 1
query_cache_size = 128M
query_cache_limit = 2M
max_connections = 2048
thread_cache_size = 512
open_files_limit = 65535
table_definition_cache = 1024
table_open_cache = 2048
# INNODB #
innodb_log_files_in_group = 2
innodb_log_file_size = 64M
innodb_flush_log_at_trx_commit = 1
innodb_file_per_table = 1
# 2G這個值配置低的話建議改小即可
innodb_buffer_pool_size = 2G
# LOGGING #
log-error=/usr/local/mysql/log/error.log
general_log=1
general_log_file=/usr/local/mysql/log/mysql.log
slow_query_log=1
slow_query_log_file=/usr/local/mysql/log/slowquery.log
log-output=FILE
# 避免MySQL的外部鎖定,減少出錯幾率增強穩(wěn)定性 #
skip-external-locking
# 禁止sql讀取本地文件 #
local-infile=0
5.將mysql的庫文件路徑加入系統(tǒng)的庫文件搜索路徑中
方法一:直接做軟鏈接
# ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
方法二:利用ldconfig導(dǎo)入系統(tǒng)庫(推薦)
# echo "/usr/local/mysql/lib" >> /etc/ld.so.conf.d/mysql.conf
# ldconfig
6.輸出mysql的頭文件到系統(tǒng)頭文件
# ln -s /usr/local/mysql/include/mysql /usr/include/mysql
7.進入安裝路徑,初始化配置腳本
# scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data
8.復(fù)制mysql啟動腳本到系統(tǒng)服務(wù)目錄
9.系統(tǒng)啟動項相關(guān)配置
# chkconfig --level 35 mysqld on #設(shè)置mysql啟動
10.啟動mysql
# service mysqld start
注:編譯時若socket路徑自定義為/var/lib/mysql/mysql.sock,這里需要創(chuàng)建一個mysql接口的軟鏈接,防止登陸后臺或安裝論壇報錯.
# ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
11. 設(shè)置初始賬戶,并登陸后臺:
# /usr/local/mysql/bin/mysqladmin -u root password 123456 #設(shè)置密碼
# /usr/local/mysql/bin/mysql -u root -p123456 #連接數(shù)據(jù)庫
-----------------------------------
mysql> create database phpwind; #創(chuàng)建數(shù)據(jù)庫
mysql> grant all privileges on *.* to root@'%' identified by '123456' with grant option; #給root用戶非本地鏈接所有權(quán)限,并改密碼和賦予其給其他人下發(fā)權(quán)限.
mysql> show variables; #查看mysql設(shè)置.
-----------------------------------
注:從啟MYSQL也可使用以下命令開啟此服務(wù)
# /usr/local/mysql/bin/safe_mysqld
如果不設(shè)置chkconfig啟動項,也可在/etc/rc.local下添加如下命令,使mysql服務(wù)利用系統(tǒng)啟動腳本運行.
# echo "/usr/local/mysql/bin/safe_mysqld --user=mysql &" >> /etc/rc.local
12 添加mysql命令集到系統(tǒng)全局變量
注:如果系統(tǒng)之前未安裝mysql客戶端,可以將編譯好的mysql命令集導(dǎo)入系統(tǒng)全局變量
以后就可以直接使用mysql命令集,而不需要使用絕對路徑訪問.
# source /etc/profile
四.安裝apache網(wǎng)站服務(wù)
1.pcre依賴包安裝
# wget http://sourceforge.net/projects/pcre/files/pcre/8.32/pcre-8.32.tar.gz/download
# tar -xzvf pcre-8.32.tar.gz
# cd pcre-8.32
# ./configure --prefix=/usr/local/pcre
# make && make install
2.下載apache
其實這里在apache官網(wǎng)找不到httpd-2.4.4-deps.tar.bz2的編譯包,不知道官方怎么想的,最后研究了下最近的2.43deps版本,解壓該編譯包,發(fā)現(xiàn)里面放的其實就是apr和apr-util兩個apache的依賴包,現(xiàn)在的方法是直接把2.43的包解壓到apache安裝根目錄即可連同apache編譯安裝,最后能正常安裝使用,算是一個無奈之舉,但安裝起來較網(wǎng)上單獨編譯安裝依賴包要簡便一些.
# wget http://archive.apache.org/dist/httpd/httpd-2.4.3-deps.tar.bz2
# wget http://archive.apache.org/dist/httpd/httpd-2.4.4.tar.bz2
3.解包
注:httpd-2.4.3-deps.tar.bz2已集成APR,安裝apache前檢查pcre是否安裝成功.
# tar jxvf httpd-2.4.4.tar.bz2
# tar jxvf httpd-2.4.3-deps.tar.bz2
# cp -rf httpd-2.4.3/* httpd-2.4.4
# cd httpd-2.4.4
4.偽裝Apache版本信息
修改 include/ap_release.h文件 "Apache" 參數(shù)為 "Microsoft-IIS/5.0"
修改 os/unix/os.h文件 "Unix" 參數(shù)為 "Win32"
# cd httpd-2.4.4
# vi include/ap_release.h
#define AP_SERVER_BASEPRODUCT "Apache"
改為
#define AP_SERVER_BASEPRODUCT "Microsoft-IIS/5.0"
# vi os/unix/os.h
#define PLATFORM "Unix"
改成
#define PLATFORM "Win32"
--------------隨 筆-----------------
這里走了一些彎路,網(wǎng)上很多資料上寫到apache2.4版本打開默認(rèn)多線程模式時,都是在修改conf/extra/httpd-mpm.conf下prefork MPM處參數(shù),但當(dāng)我實際操作的時候發(fā)現(xiàn),修改后系統(tǒng)的apache進程并未增加,但在2.2下修改此參數(shù)則沒有任何問題,最近研究worker模式下才發(fā)現(xiàn)到,實際你啟用worker模式后,執(zhí)行此命令
返回的結(jié)果如下:
mod_so.c
http_core.c
worker.c
看到worker.c,這里就想到是不是使用默認(rèn)的線程模式顯示的*.c的這個*就是apache根目錄conf/extra/httpd-mpm.conf下對應(yīng)的參數(shù),想到這個疑問然后就使用默認(rèn)線程模式從新編譯了下apache,執(zhí)行命令
返回:
core.c
mod_so.c
http_core.c
event.c
OK,到conf/extra/httpd-mpm.conf下,查看有如下幾行參數(shù)
<IfModule mpm_event_module>
StartServers 3
MinSpareThreads 75
MaxSpareThreads 250
ThreadsPerChild 25
MaxRequestWorkers 400
MaxConnectionsPerChild 0
</IfModule>
將StartServers 參數(shù)修改成10
[root@lamp apache2]# lsof -i:80
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
httpd 1302 root 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21852 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21854 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21855 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21856 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21857 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21858 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21859 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21860 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21936 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
httpd 21937 daemon 4u IPv6 106523 0t0 TCP *:http (LISTEN)
問題解決,看來2.4版本的apache默認(rèn)線程是需要修改event參數(shù),這里請注意.
5.編譯安裝:
編譯默認(rèn)event MPM模式(推薦)
編譯worker MPM模式(可選,能正常開啟服務(wù),但本人未做過相關(guān)網(wǎng)站測試,不推薦生產(chǎn)環(huán)境下使用)
# make && make install
# 防止apache啟動報錯.
# vi /usr/local/apache2/conf/httpd.conf
------------------------
ServerName localhost:80
------------------------
6.啟動apache
設(shè)置開機啟動
7.配置apache:
1).禁止地址目錄訪問和索引:
搜索 Options Indexes FollowSymLinks
將其前面加#注釋
# Options Indexes FollowSymLinks
-----------------
2).隱藏版本號:
加入以下兩行:
ServerTokens ProductOnly
ServerSignature Off
------------------
3).優(yōu)化線程數(shù):
如果apche訪問量過大,將會導(dǎo)致頁面打開遲緩,下載速度也降低,如果由于經(jīng)費和環(huán)境問題,可以通過對Apache2增加模塊MPM來進行優(yōu)化, 這里我選擇線程型MPM加以優(yōu)化:
注:此方法僅對編譯安裝apache有效:
a.開啟mpm:
找到以下這行內(nèi)容,去掉注釋.
b.優(yōu)化配置:
找到如下代碼,修改成以下參數(shù)即可.
------------------------
<IfModule mpm_event_module>
StartServers 5
ServerLimit 5000
MaxClients 4000
MinSpareThreads 100
MaxSpareThreads 400
ThreadLimit 200
ThreadsPerChild 100
MaxRequestWorkers 400
MaxRequestsPerChild 100
</IfModule>
------------------------
# worker MPM配置:
-----------------------
<IfModule mpm_event_module>
StartServers 5
ServerLimit 5000
MaxClients 4000
MinSpareThreads 100
MaxSpareThreads 400
ThreadLimit 200
ThreadsPerChild 100
MaxRequestWorkers 400
MaxRequestsPerChild 100
</IfModule>
-----------------------
------------------------------------------------------
其中最重要的參數(shù)是 ThreadsPerChild和 MaxClients:
#ThreadsPerChild
每個子進程建立的線程數(shù),子進程在啟動時建立這些線程后就不再建立新的線程了
#MaxClients
允許同時伺服的最大接入請求數(shù)量(在worker下就是最大線程數(shù)量)
#ServerLimit:
對最大子進程數(shù)的上限,該值必須大于等于MaxClients/ThreadsPerChild
#ThreadLimit:
對ThreadsPerChild的上限,該值必須大于等于 ThreadsPerChild,如果將ThreadLimit設(shè)置成一個高出實際需要很多的ThreadsPerChild值,將會有過多的共享內(nèi)存被 分配,應(yīng)當(dāng)和ThreadsPerChild可能達(dá)到的最大值保持一致.
#StartServers:
服務(wù)器啟動時的服務(wù)進程數(shù)目,該值肯定小于等于ServerLimit
#MinSpareThreads和MaxSpareThreads:
通過新建或結(jié)束子進程的方式,將空閑線程的總數(shù)維持在這個范圍內(nèi)
#MaxRequestsPerChild:
用于控制服務(wù)器建立新進程和結(jié)束舊進程的頻 率,其實是一個為了防止內(nèi)存溢出的參數(shù),每個子進程在其生存期內(nèi)允許伺服的最大請求數(shù)量。到達(dá)MaxRequestsPerChild的限制后,子進程將 會結(jié)束。對于KeepAlive鏈接,只有第一個請求會被計數(shù)。事實上,它改變了每個子進程限制最大鏈接數(shù)量的行為。
可以通過檢查HTTPServer/logs/error_log日志,判斷MaxClients是否需要增加,如果有報錯,就說明apache自上次重啟至今,曾經(jīng)發(fā)生過達(dá)到MaxClients的情況:
4).關(guān)閉TRACE Method.
-----------------------
TraceEnable off
-----------------------
5).實現(xiàn)service和chkconfig系統(tǒng)控制httpd開啟關(guān)閉
# vi /etc/ld.so.conf.d/apache2.4.4.conf
-----------
/usr/local/apache2/lib
------------
# ldconfig
# cp /usr/local/apache2/bin/apachectl /etc/init.d/httpd
# vi /etc/init.d/httpd
在首行#!/bin/sh 下面添加:
#chkconfig:345 61 61
#description:Apache httpd
---------------
# chkconfig --add httpd
# chkconfig httpd on
# service httpd restart
6).修改log日志格式實現(xiàn)每天保存.
#vi /usr/local/apache2/conf/httpd.conf
找到CustomLog和ErrorLog行,注釋掉修改為以下參數(shù)
CustomLog "|/usr/local/apache2/bin/rotatelogs /usr/local/apache2/logs/%Y_%m_%d.access_log 86400 480" combined
ErrorLog "|/usr/local/apache2/bin/rotatelogs /usr/local/apache2/logs/%Y_%m_%d.error_log 86400 480"
---------------------------------
7).修改apache權(quán)限:
------------------
User www
Group www
------------------
注:這里其實就相當(dāng)于用戶執(zhí)行WEB瀏覽會觸發(fā)httpd進程,該進程由于屬主屬組都為www,所以對屬主屬組為www的目錄都有讀寫權(quán)限,當(dāng)然前提你的目錄u=r+w+x,這樣就保證開發(fā)人員在執(zhí)行PHP語句時能對項目目錄下的文件具有讀寫權(quán)限,避免運維人員手動對需要讀寫的子目錄再設(shè)置777權(quán)限,保證項目順利實施.
五.安裝php模塊
1.處理依賴包
暫無..
2.安裝PHP
# tar -jxvf php-5.4.13.tar.bz2
# cd php-5.4.13
此處編譯安裝了我們項目經(jīng)常用到的PHP模塊,如有其它需要可以自定義添加.
# 注:其中最后一個參數(shù)--enable-maintainer-zts在安裝PHP5.4最新版本時必須添加(5.3貌似不需要),表示打開PHP進程安全Thread Safe,默認(rèn)不添加為NON Thread Safe,開啟apache服務(wù)會報錯.....(此處被坑了一下午...#$%^&*)
# make
# make install
安裝結(jié)束后:
添加php配置文件,需要CP一個源碼里面的php.ini-development或php.ini-production 到/usr/local/php/lib為php.ini
#cp php.ini-development /usr/local/php5/lib/php.ini
3.配置APACHE的PHP模塊:
編輯Apache配置文件,
并添加以下一行:
AddType application/x-httpd-php .php
--------------------------------------------
并在 DirectoryIndex 一行后面加上 index.php
如果PHP無法加載,檢查httpd.conf配置下是否有該行配置(默認(rèn)安裝PHP后會自動將該行寫入)
4.測試PHP加載:
注: 編譯安裝的apache 網(wǎng)頁存放路徑跟rpm包安裝的不一樣。編譯安裝的路徑在/usr/local/apache2/htdocs/
可添加以下內(nèi)容info.php到/usr/local/apache2/htdocs/下,測試php模塊是否加載.
---------------
<?php
echo phpinfo();
?>
---------------
檢查80端口是否打開
瀏覽器輸入 http://localhost/info.php
顯示有如下測試頁面內(nèi)容,PHP模塊即在APACHE下加載成功
測試本地mysql是否正常連接
---------------------
<html><body><h1>The page to test mysql local connection.</h1></body></html>
<?php
$conn=mysql_connect('localhost','root','123456');
if ($conn)
echo "<h2>Success...</h2>";
else
echo "<h2>Failure...</h2>";
?>
---------------------
瀏覽器輸入 http://localhost
顯示如下頁面,表示連接成功.
5.PHP配置項: (默認(rèn)路徑/usr/local/php5/lib/php.ini)
-------------------------
# 隱藏PHP版本信息:
expose_php = Off
# 關(guān)閉警告及錯誤信息,爆路徑:
display_errors = Off
# 調(diào)整時區(qū),防止phpinfo()函數(shù)報錯.
date.timezone =PRC
# 開啟php錯誤日志并設(shè)置路徑.
log_errors = On
error_log = /usr/local/apache2/logs/php_error.log
--------------大功告成O(∩_∩)O~-----------------
- CentOS 5.5使用yum來安裝LAMP(php運行環(huán)境)
- CentOS 6.2使用yum安裝LAMP以及phpMyadmin詳解
- Centos7.2 系統(tǒng)上yum安裝lamp環(huán)境
- centos6.5 lamp 環(huán)境(使用yum安裝方法)
- 詳解linux centos yum安裝LAMP環(huán)境
- CentOS平臺快速搭建LAMP環(huán)境的方法
- Centos7.4環(huán)境安裝lamp-php7.0教程
- centos7.2搭建LAMP環(huán)境的具體操作方法
- centos7.0之Lnmp和Lamp詳細(xì)介紹
- CentOS 6.6安裝配置LAMP服務(wù)器(Apache+PHP5+MySQL)
- CentOS使用本地yum源搭建LAMP環(huán)境圖文教程
相關(guān)文章
Linux Centos 下使用yum 命令安裝mysql實現(xiàn)步驟
這篇文章主要介紹了Linux Centos 下使用yum 命令安裝mysql實現(xiàn)步驟的相關(guān)資料,需要的朋友可以參考下2017-03-03Linux系統(tǒng)查看CPU、機器型號、內(nèi)存等信息
今天小編就為大家分享一篇關(guān)于Linux系統(tǒng)查看CPU、機器型號、內(nèi)存等信息,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03