溫馨提示×

溫馨提示×

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

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

LAMP環(huán)境搭建

發(fā)布時間:2020-07-30 22:03:03 來源:網(wǎng)絡(luò) 閱讀:368 作者:Cinyann 欄目:MySQL數(shù)據(jù)庫

Lamp環(huán)境搭建:(將解壓后的lamp目錄移動到“/”目錄下)


一、準(zhǔn)備工作 

1、安裝編譯工具gcc、gcc-c++

注意解決依賴關(guān)系,推薦使用yum安裝,若不能聯(lián)網(wǎng)可使用安裝光盤做為yum源——

1)編輯yum配置文件:

# mount /dev/cdrom /mnt/cdrom

# vim /etc/yum.repos.d/CentOS-Media.repo

[c6-media]

name=CentOS-$releasever - Media

baseurl=file:///mnt/cdrom   * 修改為光盤掛載點

gpgcheck=0

enabled=1  * 改為1意為啟用

gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

2)剪切/etc/yum.repos.d/CentOS-Base.repo

# mv /etc/yum.repos.d/CentOS-Base.repo /backup

3)依次安裝gcc、gcc-c++

# yum -y install gcc

# yum -y install gcc-c++


2、關(guān)閉系統(tǒng)RPM安裝包的Apache、MySQL的服務(wù)

關(guān)閉啟動的服務(wù)httpd、mysqld

# service httpd stop

# service mysqld stop

 

確定rpm包安裝的httpd和mysqld不能開機自啟動

chkconfig  --level  2345  httpd(mysqld)  off


3、關(guān)閉SELinux,允許防火墻80端口訪問

1)關(guān)閉SELinux

#vim /etc/selinux/config

SELINUX=disabled   * 若安裝時沒有禁用SELinux ,將enforcing改為disabled

修改后需重新啟動Linux方可生效!

2)關(guān)閉防火墻Netfilter/iptables

因尚未做防火墻講解,直接簡單的關(guān)閉所有防火墻設(shè)置:

# iptables  -F     * 如果沒有禁用防火墻,默認80端口禁止訪問

Iptables –A INPUT –p tcp –dport 80 –j ACCEPT

iptables   -Z    

iptables  -X


4、關(guān)閉不必要自啟動服務(wù)

# ntsysv

以下列出服務(wù)可保持自啟動,未列出的服務(wù)都可以關(guān)閉:

atd   

crond      # atd、crond計劃任務(wù)

irqbalance

microcode_ctl   # 系統(tǒng)irq端口調(diào)用,系統(tǒng)服務(wù)

network    #網(wǎng)絡(luò)設(shè)置

sendmail   #郵件

sshd      #遠程管理

syslog    #系統(tǒng)日志


5、拷貝源碼包,解包解壓縮(注意系統(tǒng)是否已安裝unzip軟件)

建議將LAMP環(huán)境安裝源碼包統(tǒng)一存放在一個目錄下,如/lamp

可編寫個批量處理腳本,一次性把所有.tar.gz的安裝包解包解壓縮

# vim tar-for-if.sh

#!/bin/bash

ls * > ./list.txt

for a in $(cat list.txt)

do

if [[ "$a" =~ "tar" ]]

then

tar -xf $a

elif [[ "$a" =~ "tgz" ]]

then

tar -xf $a

elif [[ "$a" =~ "gz" ]]

then

gunzip $a

elif [[ "$a" =~ "bz" ]]

then

bunzip2 $a

elif [[ "$a" =~ "zip" ]]

then

unzip $a

else

echo "$a is not a zip file."

fi

done


6、查看確認磁盤空間未滿

df -h

* 若/分區(qū)已滿,可以移動安裝包到其他分區(qū)或刪除其他無用文件

 

 

如何確定報錯:

1)安裝過程停止

2)停止后,一頁界面中出現(xiàn)error或者warning

 

如何確定安裝成功:

進入安裝目錄,確認安裝程序出現(xiàn),就是成功


二、編譯安裝

 

* 每個源碼包配置編譯安裝完成后,確認安裝目錄下是否生成安裝文件

   

# 安裝libxml2

Libxml2 是一個xml c語言版的解析器,本來是為Gnome項目開發(fā)的工具,是一個基于MIT License的免費開源軟件。它除了支持c語言版以外,還支持c++、PHP、Pascal、Ruby、Tcl等語言的綁定,能在Windows、Linux、Solaris、MacOsX等平臺上運行。功能還是相當(dāng)強大的,相信滿足一般用戶需求沒有任何問題。

libxml是一個用來解析XML文檔的函數(shù)庫。它用C語言寫成, 并且能為多種語言所調(diào)用,例如C語言C++,XSHC#Python,Kylix/DelphiRuby,和PHP等。Perl中也可以使用XML::LibXML模塊。它最初是為GNOME開發(fā)的項目,但現(xiàn)在可以用在各種各樣的方面。libXML 代碼可移植性非常好,因為它基于標(biāo)準(zhǔn)的ANSI C庫, 并采用MIT許可證。

 

#yum  install  -y  libxml2-devel    如果報錯,安裝此包后再嘗試安裝

 

yum -y install python-devel        必須安裝

 

cd /lamp/libxml2-2.9.1

./configure --prefix=/usr/local/libxml2/

make

make install

 

# 安裝libmcrypt                  

libmcrypt是加密算法擴展庫。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。

 cd /lamp/libmcrypt-2.5.8

 ./configure --prefix=/usr/local/libmcrypt/

 make

 make install

 * 需調(diào)用gcc-c++編譯器,未安裝會報錯

 

# 安裝libltdl,也在libmcrypt源碼目錄中,非新軟件

cd /lamp/libmcrypt-2.5.8/libltdl

./configure --enable-ltdl-install

make

make install

 

 

# 安裝mhash

Mhash是基于離散數(shù)學(xué)原理的不可逆向的php加密方式擴展庫,其在默認情況下不開啟。mhash的可以用于創(chuàng)建校驗數(shù)值,消息摘要,消息認證碼,以及無需原文的關(guān)鍵信息保存(如密碼)等。

cd /lamp/mhash-0.9.9.9

./configure

make

make install

 

 

# 安裝mcrypt  

mcrypt 是 php 里面重要的加密支持擴展庫。Mcrypt庫支持20多種加密算法和8種加密模式

cd /lamp/mcrypt-2.6.8

LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib  \

./configure --with-libmcrypt-prefix=/usr/local/libmcrypt

#以上為一條命令。LD_LIBRARY_PATH用于指定libmcrypt和mhash的庫的位置。

--with-libmcrypt-prefix用于指定libmcrypt軟件位置

make

make install

 

# 安裝zlib        

zlib是提供數(shù)據(jù)壓縮用的函式庫,由Jean-loup Gailly與Mark Adler所開發(fā),初版0.9版在1995年5月1日發(fā)表。zlib使用DEFLATE算法,最初是為libpng函式庫所寫的,后來普遍為許多軟件所使用。此函式庫為自由軟件,使用zlib授權(quán)

cd  /lamp/zlib-1.2.3

./configure

vi Makefile

#找到CFLAGS=-O3 -DUSE_MMAP

#在后面加入 –fPIC 變成

CFLAGS=-O3 -DUSE_MMAP -fPIC

 

make &&make install 

 

cd /lamp/zlib-1.2.3         

./configure

make

make install  >>  /root/zlib.log         (32位操作系統(tǒng)使用此命令)

* zlib指定安裝目錄可能造成libpng安裝失敗,故不指定,為卸載方便,建議make install執(zhí)行結(jié)果輸出到安裝日志文件,便于日后卸載

 

# 安裝libpng 

libpng 軟件包包含 libpng 庫.這些庫被其他程式用于解碼png圖片

cd /lamp/libpng-1.2.31

./configure --prefix=/usr/local/libpng

make

make install

 

# 安裝jpeg6         

用于解碼.jpg和.jpeg圖片

mkdir /usr/local/jpeg6

mkdir /usr/local/jpeg6/bin

mkdir /usr/local/jpeg6/lib

mkdir /usr/local/jpeg6/include

mkdir -p /usr/local/jpeg6/man/man1

#目錄必須手工建立

 

yum -y install "libtool*"

 

cd /lamp/jpeg-6b

[root@localhost jpeg-6b]# cp /usr/share/libtool/config/config.sub .

[root@localhost jpeg-6b]# cp /usr/share/libtool/config/config.guess .

#復(fù)制libtool中的文件,覆蓋jpeg-6b中的文件     (64位中的問題,32位沒有此報錯)

 

cd /lamp/jpeg-6b

./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static

make          

make install

* --enable-shared與--enable-static參數(shù)分別為建立共享庫和靜態(tài)庫使用的libtool

 

# 安裝freetype          

FreeType庫是一個完全免費(開源)的、高質(zhì)量的且可移植的字體引擎,它提供統(tǒng)一的接口來訪問多種字體格式文件,包括TrueType, OpenType, Type1, CID, CFF, Windows FON/FNT, X11 PCF等。支持單色位圖、反走樣位圖的渲染。FreeType庫是高度模塊化的程序庫,雖然它是使用ANSI C開發(fā),但是采用面向?qū)ο?/span>的思想,因此,F(xiàn)reeType的用戶可以靈活地對它進行裁剪。

cd /lamp/freetype-2.3.5

./configure --prefix=/usr/local/freetype/

make

make install


# 安裝Apache

configure: error: Bundled APR requested but not found at ./srclib/. Download and unpack the corresponding apr and apr-util packages to ./srclib/.

#如果報錯,則:

tar zxvf  apr-1.4.6.tar.gz

tar zxvf  apr-util-1.4.1.tar.gz  解壓過

cp -r  /lamp/apr-1.4.6  /lamp/httpd-2.4.7/srclib/apr

cp -r  /lamp/apr-util-1.4.1  /lamp/httpd-2.4.7/srclib/apr-util

#解壓apr和apr-util,復(fù)制并取消版本號

 

configure: error: pcre-config for libpcre not found. PCRE is required and available from

#如果報錯,則:

tar zxvf pcre-8.34.tar.gz

cd /lamp/pcre-8.34 

./configure && make && make install

 

checking whether to enable mod_ssl... configure: error: mod_ssl has been requested but can not be built due to prerequisite failures

#如果報錯,則:

yum install openssl-devel

 

安裝apache

cd /lamp/httpd-2.4.7

./configure --prefix=/usr/local/apache2 --sysconfdir=/usr/local/apache2/etc --with-included-apr --enable-so --enable-deflate=shared --enable-expires=shared --enable-rewrite=shared

make

make install

* 若前面配置zlib時沒有指定安裝目錄,Apache配置時不要添加--with-z=/usr/local/zlib/參數(shù)

 

啟動Apache測試:

/usr/local/apache2/bin/apachectl start

ps  aux | grep httpd

netstat –tlun | grep :80

* 若啟動時提示/usr/local/apache2/modules/mod_deflate.so無權(quán)限,可關(guān)閉SELinux或者執(zhí)行命令chcon -t texrel_shlib_t /usr/local/apache2/modules/mod_deflate.so ,類似此類.so文件不能載入或沒有權(quán)限的問題,都是SELinux問題,使用命令:“chcon -t texrel_shlib_t 文件名”即可解決,MySQL和Apache也可能有類似問題。

通過瀏覽器輸入地址訪問:http://Apache服務(wù)器地址,若顯示“It works”即表明Apache正常工作

 

設(shè)置Apache系統(tǒng)引導(dǎo)時啟動:

echo "/usr/local/apache2/bin/apachectl start" >> /etc/rc.d/rc.local

 

# 安裝ncurses

Ncurses 提供字符終端處理庫,包括面板和菜單。它提供了一套控制光標(biāo),建立窗口,改變前景背景顏色以及處理鼠標(biāo)操作的函數(shù)。使用戶在字符終端下編寫應(yīng)用程序時繞過了那些惱人的底層機制。簡而言之,他是一個可以使應(yīng)用程序直接控制終端屏幕顯示的函數(shù)庫。

1、yum -y install ncurses-devel

注:如果報錯,包找不到,是*通配符沒有識別,給文件名加雙引號  “ncurses*”

2、源代碼編譯:

cd /lamp/ncurses-5.9

./configure --with-shared --without-debug --without-ada --enable-overwrite

make

make install

* 若不安裝ncurses編譯MySQL時會報錯

* --without-ada參數(shù)為設(shè)定不編譯為ada綁定,因進入chroot環(huán)境不能使用ada ;--enable-overwrite參數(shù)為定義把頭文件安裝到/tools/include下而不是/tools/include/ncurses目錄

* --with-shared    生成共享庫

 

#安裝cmake和bison

mysql在5.5以后,不再使用./configure工具,進行編譯安裝。而使用cmake工具替代了./configure工具。cmake的具體用法參考文檔cmake說明。

bison是一個自由軟件,用于自動生成語法分析器程序,可用于所有常見的操作系統(tǒng)

yum -y install cmake

yum -y install bison

 

# 安裝MySQL              

groupadd mysql

useradd -g mysql mysql

* 添加用戶組mysql ,將mysql用戶默認組設(shè)置為mysql用戶組

 

cd /lamp/mysql-5.5.48

cmake  -DCMAKE_INSTALL_PREFIX=/usr/local/mysql    -DMYSQL_UNIX_ADDR=/tmp/mysql.sock  -DEXTRA_CHARSETS=all   -DDEFAULT_CHARSET=utf8    -DDEFAULT_COLLATION=utf8_general_ci    -DWITH_MYISAM_STORAGE_ENGINE=1   -DWITH_INNOBASE_STORAGE_ENGINE=1    -DWITH_MEMORY_STORAGE_ENGINE=1  -DWITH_READLINE=1    -DENABLED_LOCAL_INFILE=1   -DMYSQL_USER=mysql  -DMYSQL_TCP_PORT=3306

 

    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql        安裝位置

    -DMYSQL_UNIX_ADDR=/tmp/mysql.sock          指定socket(套接字)文件位置

    -DEXTRA_CHARSETS=all                    字符支持

    -DDEFAULT_CHARSET=utf8                    默認字符集

    -DDEFAULT_COLLATION=utf8_general_ci         默認字符校對

    -DWITH_MYISAM_STORAGE_ENGINE=1             安裝myisam存儲引擎

    -DWITH_INNOBASE_STORAGE_ENGINE=1            安裝innodb存儲引擎

    -DWITH_MEMORY_STORAGE_ENGINE=1              安裝memory存儲引擎

    -DWITH_READLINE=1                       支持readline庫

    -DENABLED_LOCAL_INFILE=1                  啟用加載本地數(shù)據(jù)

    -DMYSQL_USER=mysql                       指定mysql運行用戶

    -DMYSQL_TCP_PORT=3306                    指定mysql端口

 

 

make

make install

 

make clean

rm CMakeCache.txt

#如果報錯,清除緩存,請使用以上命令

 

cd /usr/local/mysql/

chown -R root .

chown -R mysql data

#修改mysql目錄權(quán)限

 

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

#復(fù)制mysql配置文件

/usr/local/mysql/scripts/mysql_install_db --user=mysql

#創(chuàng)建數(shù)據(jù)庫授權(quán)表,初始化數(shù)據(jù)庫

 

 

啟動MySQL服務(wù):

1.用原本源代碼的方式去使用和啟動mysql

/usr/local/mysql/bin/mysqld_safe --user=mysql &  執(zhí)行命令后,過一會要回車

2.重啟以后還要生效:

vim /etc/rc.local

/usr/local/mysql/bin/mysqld_safe --user=mysql &

3.設(shè)定mysql密碼

/usr/local/mysql/bin/mysqladmin -uroot password 123

   清空歷史命令    history  -c

* 給mysql用戶root加密碼123

*  注意密碼不能寫成 “123”   

/usr/local/mysql/bin/mysql -u root -p

mysql>show databases;

mysql>use test;

mysql>show tables;

mysql>\s          #查看字符集是否改為utf8

* 進入mysql以后用set來改密碼

mysql> exit

* 登錄MySQL客戶端控制臺設(shè)置指定root密碼

 

# 安裝PHP                

編譯前確保系統(tǒng)已經(jīng)安裝了libtool和libtool-ltdl軟件包,安裝:

yum -y install "libtool*"

 

cd /lamp/php-7.0.7

./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/ --with-apxs2=/usr/local/apache2/bin/apxs  --with-libxml-dir=/usr/local/libxml2/ --with-jpeg-dir=/usr/local/jpeg6/ --with-png-dir=/usr/local/libpng/ --with-freetype-dir=/usr/local/freetype/ --with-mcrypt=/usr/local/libmcrypt/   --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-soap --enable-mbstring=all --enable-sockets  --with-pdo-mysql=/usr/local/mysql --with-gd   --without-pear

 

l  若前面配置zlib時沒有指定安裝目錄,PHP配置時不要添加--with-zlib-dir=/usr/local/zlib/參數(shù)

選項:

    --with-config-file-path=/usr/local/php/etc/ 指定配置文件目錄

    --with-apxs2=/usr/local/apache2/bin/apxs    指定apache動態(tài)模塊位置

    --with-libxml-dir=/usr/local/libxml2/      指定libxml位置

    --with-jpeg-dir=/usr/local/jpeg6/          指定jpeg位置

    --with-png-dir=/usr/local/libpng/          指定libpng位置

    --with-freetype-dir=/usr/local/freetype/    指定freetype位置

     --with-mcrypt=/usr/local/libmcrypt/         指定libmcrypt位置

    --with-mysqli=/usr/local/mysql/bin/mysql_config     指定mysqli位置

    --with-gd                               啟用gd庫

    --enable-soap                          支持soap服務(wù)

    --enable-mbstring=all                  支持多字節(jié),字符串

    --enable-sockets                       支持套接字

    --with-pdo-mysql=/usr/local/mysql      啟用mysql的pdo模塊支持

    --without-pear                         不安裝pear(安裝pear需要連接互聯(lián)網(wǎng)。                                               PEAR是PHP擴展與應(yīng)用庫)

make

make install

 

生成php.ini

# mkdir /usr/local/php/etc/

 

cp /lamp/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini 

 

測試Apache與PHP的連通性,看Apache是否能解析php文件

vim /usr/local/apache2/etc/httpd.conf

AddType application/x-httpd-php .php .phtml

AddType application/x-httpd-php-source .phps

(注意大小寫)

* .phtml為將.phps做為PHP源文件進行語法高亮顯示

重啟Apache服務(wù):/usr/local/apache2/bin/apachectl stop

                  /usr/local/apache2/bin/apachectl start

 

* Apache無法啟動,提示cannot restore segment prot after reloc: Permission denied錯誤,為SELinux問題,可關(guān)閉SELinux或者執(zhí)行命令chcon -t texrel_shlib_t /usr/local/apache2/modules/libphp5.so  

測試:vim /usr/local/apache2/htdocs/test.php   

<?php

  phpinfo();

?>

通過瀏覽器輸入地址訪問:http://Apache服務(wù)器地址/test.php

Rpm包安裝的網(wǎng)頁默認目錄   /var/www/html/

* 有時第一次瀏覽器測試會失敗,關(guān)閉瀏覽器重啟再嘗試即可,非編譯錯誤

 

 

 

# 安裝openssl 

OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼算法、常用的密鑰和證書封裝管理功能及SSL協(xié)議,并提供豐富的應(yīng)用程序供測試或其它目的使用。

 

yum -y install openssl-devel   必須安裝

cd /lamp/php-7.0.7/ext/openssl

mv config0.m4 config.m4                否則報錯:找不到config.m4

/usr/local/php/bin/phpize

./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config

make

make install

 

# 編譯安裝memcache    

Memcache是一個高性能的分布式的內(nèi)存對象緩存系統(tǒng),通過在內(nèi)存里維護一個統(tǒng)一的巨大的hash表,它能夠用來存儲各種格式的數(shù)據(jù),包括圖像、視頻、文件以及數(shù)據(jù)庫檢索的結(jié)果等。簡單的說就是將數(shù)據(jù)調(diào)用到內(nèi)存中,然后從內(nèi)存中讀取,從而大大提高讀取速度。

 

https://github.com/websupport-sk/pecl-memcache/archive/php7.zip

 

unzip  pecl-memcache-php7.zip

cd  pecl-memcache-php7

/usr/local/php/bin/phpize

./configure --with-php-config=/usr/local/php/bin/php-config

make && make install


 

修改/usr/local/php/etc/php.ini

extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"

#打開注釋,并修改

extension="openssl.so";

extension="memcache.so";

#添加

#重啟apache,在phpinfo中可以找到這個模塊

 

#安裝memcache源代碼

首先安裝依賴包libevent

yum -y install “l(fā)ibevent-devel”     

#在CentOS 6.3第二張光盤中,請換盤

umount /mnt/cdrom

#放入CentOS 6.3第二張光盤

#mount /dev/sr0 /mnt/cdrom

 

cd /lamp/memcached-1.4.17

./configure --prefix=/usr/local/memcache

make && make install

 

useradd memcache

#添加memcache用戶,此用戶不用登錄,不設(shè)置密碼

/usr/local/memcache/bin/memcached -umemcache &   

netstat -an | grep :11211

寫入自啟動:

vi /etc/rc.d/rc.local

/usr/local/memcache/bin/memcached -umemcache &


 

項目遷移:

1、 把php項目拷貝到網(wǎng)站默認目錄下:    /usr/local/apache2/htdocs/

2、 手工建立數(shù)據(jù)庫表結(jié)構(gòu)

 

 

 


# 安裝phpMyAdmin

cp -r /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin

cd /usr/local/apache2/htdocs/phpmyadmin

cp config.sample.inc.php config.inc.php

vim config.inc.php

$cfg['Servers'][$i]['auth_type'] = 'cookie';

$cfg['Servers'][$i]['auth_type'] = 'http';

* 設(shè)置auth_type為http ,即設(shè)置為HTTP身份認證模式

通過瀏覽器輸入地址訪問:http://Apache服務(wù)器地址/phpmyadmin/index.php

用戶名為root ,密碼為MySQL設(shè)置時指定的root密碼123456(lampbrother)


向AI問一下細節(jié)

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

AI