天天看點

CentOS 5.5(X64)下編譯安裝LAMP平台

CentOS 5.5(X64)下編譯安裝LAMP平台

軟體版本都是最新穩定版本:apache 2.2.19 mysql 5.5.14 php 5.3.6

軟體源代碼包存放位置                /home/baison/src

源碼包編譯安裝位置(prefix)        /usr/local/webserver

腳本以及維護程式存放位置        /home/baison/script

1、移除系統自帶的rpm包的http mysql php

yum remove httpd mysql mysql-server php php-cli php-common php-devel php-gd  -y

2 安裝必備的開發包

yum -y install ntp vim-enhanced gcc gcc-c++ flex bison autoconf automake bzip2-devel \

ncurses-devel zlib-devel libjpeg-devel libpng-devel libtiff-devel freetype-devel libXpm-devel \

gettext-devel  pam-devel libtool libtool-ltdl openssl openssl-devel fontconfig-devel \

libxml2-devel curl-devel  libicu libicu-devel libmcrypt libmcrypt-devel libmhash libmhash-devel 

3 sudo權限配置,為了系統的安裝生産環境下一般為普通使用者配置sudo權限,進行系統管理

#useradd baison   //建立baison使用者

#passwd baison   //為baison使用者設定密碼

#rpm -q sudo    //确認軟體包安裝

#visudo        //在配置檔案最後一行添加下面一行,授予baison使用者具有管理者權限

baison   ALL=(ALL) ALL 

儲存退出

我們一般登入系統進行維護的時候不适用root,防止權限過大誤操作造成系統資料丢失,是以我們一般使用普通使用者登入系統,然後需要root權限加上sudo就會有root權限

#su –   baison  //切換baison使用者進行編譯安裝

cd /home/baison

mkdir src script   //建立二個目錄分别放源碼包和腳本

mkdir /usr/local/webserver //軟體安裝位置

4同步系統時間:

#sudo vim /etc/ntp.conf  //添加下面三行内容(19行下面添加)

server 3.cn.pool.ntp.org

server 3.asia.pool.ntp.org

server 0.asia.pool.ntp.org

#sudo /sbin/service ntpd stop

#sudo /usr/sbin/ntpdate  cn.pool.ntp.org  //更新時間

#sudo /sbin/service ntpd start

sudo /sbin/chkconfig ntpd on

5 Install mysql編譯安裝mysql

 編譯環境前提(mysql 5.5.x 不再用 configure,而用cmake)

#cd /home/baison/src

wget http://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz

 #tar xvf  cmake-2.8.4.tar.gz

 # cd cmake-2.8.4

 # ./configure 

sudo make

sudo make install

cd /home/baison/src

wget http://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.14.tar.gz/from/http://mysql.stu.edu.tw/

 # tar zxvf mysql-5.5.14.tar.gz

 # cd mysql-5.5.14

 # cmake -DCMAKE_INSTALL_PREFIX=/usr/local/webserver/mysql \

         -DMYSQL_DATADIR=/data/mysql/data \

         -DWITH_MYISAM_STORAGE_ENGINE=1 \

         -DWITH_INNOBASE_STORAGE_ENGINE=1 \

         -DWITH_ARCHIVE_STORAGE_ENGINE=1 \

         -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

         -DENABLED_LOCAL_INFILE=1 \

         -DDEFAULT_CHARSET=utf8 \

         -DDEFAULT_COLLATION=utf8_general_ci \

         -DEXTRA_CHARSETS=all \

         -DMYSQL_TCP_PORT=3306 

# sudo make 

# sudo make install

mysql 配置

 #userdel -r mysql

 # sudo groupadd -g 3306 mysql

 # sudo useradd -u 3306 -g mysql -M -s /sbin/nologin mysql

 #sudo  mkdir -p /data/mysql/data

 # sudo mkdir -p /data/mysql/log

 # sudo chown -R mysql:mysql /data/mysql

 # sudo chmod -R 755 /data/mysql

 # sudo cp support-files/my-medium.cnf /etc/my.cnf

 #sudo /usr/local/webserver/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/webserver/mysql --datadir=/data/mysql/data &   //初始化資料庫

 # sudo cp support-files/mysql.server /etc/init.d/mysqld

 # chmod +x /etc/init.d/mysqld

 # sudo /sbin/chkconfig --add mysqld

 # sudo /sbin/chkconfig mysqld on

 #sudo /sbin/service  mysqld start

 # netstat -tnlp |grep 3306

# cd /usr/local/bin //進入使用者的預設搜尋路徑下建立mysql指令的軟連接配接,可以直接執行mysql指令

 # sudo ln -s /usr/local/webserver/mysql/bin/mysql mysql

 # sudo ln -s /usr/local/webserver/mysql/bin/mysqldump mysqldump

 # sudo ln -s /usr/local/webserver/mysql/bin/mysqladmin  mysqladmin

 # mysqladmin -u root -p password '123456'  //設定資料庫密碼

 # mysql -u root -p

 mysql> flush privileges;

sudo vim /etc/my.cnf  //Mysql 優化,在[mysqld]配置參數下面添加下面幾行(大概37行下面),根據伺服器不同配置進行不同的設定

max_allowed_packet = 500M  //先找到這行内容,修改成500

innodb_file_per_table

log-bin-trust-function-creators=1

skip-name-resolv//禁用DNS解析

sync-binlog=1

lower_case_table_names=1

max_connections = 1500 (預設100)

log-error=/data/mysql/log/mysql.err.log  //指定錯誤日志位置

max_heap_table_size = 256M

join_buffer_size = 128M

thread_cache_size = 1200   //線程緩存

thread_concurrency = 4  //設定成cpu數x2,隻有一個設定2

thread_stack = 256K  

query_cache_type = 1   //指定是否使用查詢緩沖,可以設定為0、1、2,該變量是SESSION級的變量

query_cache_size = 512M  //查詢緩沖大小

query_cache_limit = 4M   //單個查詢緩沖大小。預設1M

query_cache_min_res_unit = 4k    //指定配置設定緩沖區空間的最小機關,預設為4K        

tmp_table_size = 256M       

myisam_sort_buffer_size = 64M

back_log = 1024//設定緩存隊列數,節省連接配接開銷

long_query_time = 3  

open_files_limit    = 10240

interactive_timeout = 120

wait_timeout = 120

external-locking = FALSE//禁用檔案系統外部鎖

table_cache = 1024//高速緩存大小,4G記憶體設定為2048

修改配置檔案裡下面的參數,去掉前面的#

innodb_buffer_pool_size = 2048M (預設16M,可以為系統記憶體50%~70%)

innodb_additional_mem_pool_size = 256M (預設2M)

innodb_log_file_size = 512M    (預設5M,innodb_buffer_pool_size的四分之一)

innodb_log_buffer_size = 16M  //設定位每秒的資料量

innodb_max_dirty_pages_pct = 90

innodb_file_io_threads = 4

innodb_thread_concurrency = 16

innodb_flush_log_at_trx_commit = 0

innodb_flush_method=O_DIRECT

innodb_open_files=4096

innodb_lock_wait_timeout = 120

innodb_file_per_table=1

:wq //儲存退出

sudo rm -rvf  /data/mysql/data/ib_logfile* //删除原來的預設檔案

sudo /sbin/service mysqld restart

6、apache安裝

wget http://labs.renren.com/apache-mirror//httpd/httpd-2.2.19.tar.gz

tar xvf httpd-2.2.19.tar.gz

cd httpd-2.2.19

./configure --prefix=/usr/local/webserver/apache \

--enable-so --enable-rewrite \

 --enable-mods-shared=most 

sudo make 

sudo /usr/local/webserver/apache/bin/apachectl start

sudo netstat -tnlp |grep httpd

sudo cp /usr/local/webserver/apache/bin/apachectl /etc/init.d/httpd

sudo /sbin/service  httpd start

netstat -tnlp |grep 80

sudo vim /etc/init.d/httpd (第二行添加注釋資訊,添加為系統服務)

# chkconfig: 35 61 61

# description: Apache

:wq 儲存退出

sudo /sbin/chkconfig --add httpd

 sudo /sbin/chkconfig httpd on

wget http://cn.php.net/get/php-5.3.6.tar.gz/from/this/mirror

tar xvf php-5.3.6.tar.gz

cd php-5.3.6

sudo ./configure --prefix=/usr/local/webserver/php \

--mandir=/usr/local/share/man \

--infodir=/usr/local/share/info \

--with-apxs2=/usr/local/webserver/apache/bin/apxs \

--enable-cgi --with-mysql=/usr/local/webserver/mysql/ \

--with-config-file-path=/usr/local/webserver/php/etc \

--with-pdo-mysql=/usr/local/webserver/mysql \

--with-mysqli=/usr/local/webserver/mysql/bin/mysql_config \

--enable-zip --enable-sqlite-utf8 -enable-sockets \

--enable-soap --enable-pcntl --enable-mbstring \

--enable-intl --enable-calendar --enable-bcmath \

--enable-exif --with-mcrypt --with-mhash --with-gd \

--with-png-dir --with-jpeg-dir --with-freetype-dir \

--with-libxml-dir --with-curl --with-curlwrappers \

--with-zlib   --with-openssl --with-kerberos=shared \

--with-gettext=shared --with-xmlrpc=shared 

sudo cp php.ini-recommended /usr/local/webserver/php/etc/php.ini   //拷貝配置檔案

整合Apache與PHP及系統初始化配置

sudo vim /usr/local/apache/conf/httpd.conf

查找AddType application/x-gzip .gz .tgz,在該行下面添加

AddType application/x-httpd-php .php

查找DirectoryIndex index.html 把該行修改成

DirectoryIndex index.html index.htm index.php

測試apache和php是否整合成功,下面我們測試apache和php是否整合成功,在apache文檔跟目錄下建立一個小小的php程式

# cd /usr/local/webserver/apache/htdocs

# sudo vi index.php  //在index.php檔案中寫入下面三行

<?php

phpinfo();

?>

重新開機apache服務

sudo /sbin/service  httpd restart

通路,在浏覽器中輸入http://localhost/index.php 出現php資訊界面則說明整合成功

本文轉自 張玉坡 51CTO部落格,原文連結:http://blog.51cto.com/fighter/606686