LAMP(Linux+Apache+MySQL+PHP)環境介紹、配置、搭建


這裏是一段防爬蟲文本,請讀者忽略。
本文原創首發於CSDN,作者IDYS
博客首頁:https://blog.csdn.net/weixin_41633902/
本文鏈接:https://blog.csdn.net/weixin_41633902/article/details/106303965


寫在開頭的話

  • 請記住:實踐是掌握知識的最快方法
  • 如果你只是懷着看看的態度去快速瀏覽文章,而不去認認真真的把文章裏面講的任何一個知識點去實踐一遍,那麼你永遠也掌握不了它
  • 生命不息,折騰不止!

LAMP的簡要介紹

  • web網站平臺-LAMP的搭建方式

Linux+Apache+MySQL+PHP


  • Apache

實現網頁共享傳輸

  • MySQL:

實現數據存儲(數據庫)

  • PHP

實現頁面解析的解析器


  • 瀏覽器:

僅能解析簡單的HTML語言,無法直接解析PHP語言

部署方式

  • yum安裝:
    • 優點:安裝部署便捷,快速
    • 缺點:軟件版本固定,且版本較低
  • 源碼安裝:
    • 優點:版本可自選,可自定義性強
    • 缺點:難度較大,維護相對困難

LAMP環境搭建

環境準備

準備本地yum源

這個不是必須選項,就是如果你是斷網的狀態,沒有和外界進行聯網時,那麼你肯定是無法用yum聯網安裝軟件包的,所以你只能配置本地yum源來安裝軟件包

  1. 插入兩張CD光盤

在這裏插入圖片描述

  1. 掛載光盤
[root@idyslamp media]# mkdir /media/cdrom{1..2}
[root@idyslamp media]# ls
cdrom1  cdrom2

# 掛載光盤
[root@idyslamp /]# mount /dev/sr0 /media/cdrom1
mount: block device /dev/sr0 is write-protected, mounting read-only
[root@idyslamp /]# mount /dev/sr1 /media/cdrom2
mount: block device /dev/sr1 is write-protected, mounting read-only
  1. 配置yum源
# 編輯 CentOS-Media.repo 文件
[root@idyslamp ~]vim /etc/yum.repos.d/CentOS-Media.repo 

# 做出如下修改

[c6-media]
name=CentOS-$releasever - Media
# 將yum源的本地路徑修改爲剛纔掛載軟件包的掛載點位置
baseurl=file:///media/cdrom1
        file:///media/cdrom2
# file:///media/cdrecorder/
# 不檢查gpgkey
gpgcheck=0
# 此yum源生效
enabled=1
  1. 調整yum源配置文件引導優先級
 mv CentOS-Base.repo CentOS-Base.repo.bak

安裝編譯文件

[root@idyslamp yum.repos.d]yum -y install gcc gcc-c++ make

關閉防火牆和SElinux

# 查看防火牆當前狀態
[root@idyslamp yum.repos.d]service iptables status
iptables:未運行防火牆。

# 查看防火牆自啓動狀態
[root@idyslamp yum.repos.d]chkconfig --list iptables 
iptables        0:關閉  1:關閉  2:啓用  3:啓用  4:啓用  5:啓用  6:關閉

# 關閉防火牆,再次查看防火牆自啓動狀態
[root@idyslamp yum.repos.d]chkconfig  iptables off   
[root@idyslamp yum.repos.d]chkconfig  --list iptables
iptables        0:關閉  1:關閉  2:關閉  3:關閉  4:關閉  5:關閉  6:關閉

# 臨時關閉SElinux
[root@idyslamp yum.repos.d]setenforce 0
[root@idyslamp /]getenforce 
Permissive

# 編輯SELinux配置文件
[root@idyslamp /]vim /etc/selinux/config 
# 修改的配置如下
SELINUX=disabled

環境搭建

安裝依賴包

  1. 上傳php7.x的軟件包到Linux上

  2. 解壓PHP的軟件包

# 載根目錄下創建lamp目錄
mkdir /lamp

# lamp軟件包移動到/lamp下面
mv root/LAMP-php7.zip lamp/

# 安裝unzip軟件包
yum -y install unzip

# 解壓lamp軟件包
uzip LAMP-php7.zip 

# 解壓所有的以.tar.gz結尾的壓縮文件
ls *.tar.gz | xargs -n1 -I {} tar -zxf {}

# 解壓zip文件
unzip pecl-memcache-php7.zip 
  1. 安裝libxml2-devlpython-devl
yum -y install libxml2-devel python-devel
  1. 安裝編譯libxml2

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

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

# 現在可以看到/usr/local/libxml2文件夾存在
[root@idyslamp libxml2-2.9.1] ls /usr/local/libxml2/
bin  include  lib  share
  1. 安裝libmcrypt

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

./configure --prefix=/usr/local/libmcrypt
echo $?
make
make install

安裝libmcrypt的子模塊:ltdl
./configure --enable-ltdl-install
make
make install

libmcrypt依賴着 mhashmcrypt

  1. 安裝編譯mhash

mhash 是基於離散數學原理的不可逆向的 php 加密方式擴展庫,其在默認情況下不開啓。mhash 的可 以用於創建校驗數值,消息摘要,消息認證碼,以及無需原文的關鍵信息保存(如密碼)等。

[root@idyslamp mhash-0.9.9.9] ./configure && make && make install
  1. 安裝mcrypt(提供加密的函數庫)

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

[root@idyslamp mcrypt-2.6.8] export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
[root@idyslamp mcrypt-2.6.8]   ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt
  1. 安裝 zlib

zlib 是提供數據壓縮用的函式庫,由 Jean-loup Gailly 與 Mark Adler 所開發,初版 0.9 版在 1995 年 5 月 1 日發表。zlib 使用 DEFLATE 算法,最初是爲 libpng 函式庫所寫的,後來普遍爲許多軟件所使用。此函式庫爲自由軟件,使用 zlib 授權

[root@idyslamp lamp] cd /lamp/zlib-1.2.3
[root@idyslamp zlib-1.2.3] ./configure

# 修改Makefile文件,加入修改如下
[root@idyslamp zlib-1.2.3] vim Makefile
CFLAGS=-O3 -DUSE_MMAP -fPIC

[root@idyslamp zlib-1.2.3] make
[root@idyslamp zlib-1.2.3] make install
  1. 安裝 libpng

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

[root@idyslamp libpng-1.2.31] ./configure  --prefix=/usr/local/libpng
[root@idyslamp libpng-1.2.31] make
[root@idyslamp libpng-1.2.31] make install
  1. 安裝 jpeg6

jpeg6 提供用於解碼.jpg 和.jpeg 圖片的庫文件

# 創建如下目錄
[root@idyslamp /] mkdir -p /usr/local/jpeg6/{bin,lib,include,man/man1}

# 查看目錄情況
[root@idyslamp /] tree /usr/local/jpeg6/
/usr/local/jpeg6/
├── bin
├── include
├── lib
└── man
    └── man1
    
cd /lamp/jpeg-6b/
yum -y install libtool*

[root@idyslamp jpeg-6b] cp -a /usr/share/libtool/config/config.* ./
cp:是否覆蓋"./config.guess"? y
cp:是否覆蓋"./config.sub"? y

[root@idyslamp jpeg-6b] ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static && make && make install
  1. 安裝 freetype

FreeType 庫是一個完全免費(開源)的、高質量的且可移植的字體引擎,它提供統一的接口來訪問多種 字體格式文件,支持單色位圖、反走樣位圖的渲染。

[root@idyslamp freetype-2.3.5] ./configure --prefix=/usr/local/freetype/
[root@idyslamp freetype-2.3.5] make
[root@idyslamp freetype-2.3.5] make install

安裝 Apache

  1. 源碼包 2.4.*版本中默認沒有集成 apr 的依賴包,所以需要提前解決依賴問題
cd /lamp/httpd-2.4.7/srclib/
[root@idyslamp srclib] cp -a /lamp/apr-1.4.6 ./apr
[root@idyslamp srclib] cp -a /lamp/apr-util-1.4.1 ./apr-util
[root@idyslamp srclib] ls
apr  apr-util  Makefile.in
  1. Apache 默認需要依賴 pcre 軟件,但由於 Apache 軟件版本較高,則系統預安裝的 pcre 無法使用, 所以需要人爲手動安裝適合版本
[root@idyslamp pcre-8.34] cd /lamp/pcre-8.34
[root@idyslamp pcre-8.34] ./configure && make && make install
  1. Apache 的加密傳輸模塊 mod_ssl,需要安裝此軟件產生
[root@idyslamp pcre-8.34]  yum install openssl-devel
  1. httpd 軟件安裝
[root@idyslamp httpd-2.4.7] cd /lamp/httpd-2.4.7
[root@idyslamp 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 --enable-ssl
[root@idyslamp httpd-2.4.7] make && make install 

若前面配置 zlib 時沒有指定安裝目錄,Apache 配置時不要添加–with-z=/usr/local/zlib/參數, --enable-ssl 選項是爲了後期實現 https 提前設置的參數


  1. 啓動 Apache 測試
  • 在開始啓動的過程中發現了一個報錯
# 報錯如下
[root@idyslamp httpd-2.4.7] /usr/local/apache2/bin/apachectl start
AH00557: httpd: apr_sockaddr_info_get() failed for idyslamp
AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1. Set the 'ServerName' directive globally to suppress this message
  • 修改apache的配置文件/usr/local/apache2/etc/httpd.conf,修改190行的配置文件
[root@idyslamp httpd-2.4.7] vim /usr/local/apache2/etc/httpd.conf 
# 修改如下
ServerName localhost:80
  • 再次啓動apache
[root@idyslamp httpd-2.4.7] /usr/local/apache2/bin/apachectl start
httpd (pid 98752) already running

# 現在80端口,已經運行
[root@idyslamp httpd-2.4.7] netstat -lntp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address               Foreign Address             State       PID/Program name   
tcp        0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      1384/sshd           
tcp        0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      1463/master         
tcp        0      0 :::80                       :::*                        LISTEN      98752/http

# 查看apache 進程是否正在運行
[root@idyslamp httpd-2.4.7]  ps aux | grep httpd
root      98752  0.0  0.1  75216  2804 ?        Ss   21:13   0:00 /usr/local/apache2/bin/httpd -k start
daemon    98753  0.0  0.2 419476  4584 ?        Sl   21:13   0:00 /usr/local/apache2/bin/httpd -k start
daemon    98754  0.0  0.2 419476  4588 ?        Sl   21:13   0:00 /usr/local/apache2/bin/httpd -k start
daemon    98755  0.0  0.2 485012  4596 ?        Sl   21:13   0:00 /usr/local/apache2/bin/httpd -k start
root      98843  0.0  0.0 103332   896 pts/2    S+   21:20   0:00 grep httpd
  • 在客戶端瀏覽器的URL上輸入192.168.200.138:80,你的話就是這樣YOURSERVICEIP:80,把IP改爲你的服務器IP
  • 檢查apachectl語法錯誤
[root@idyslamp httpd-2.4.7] /usr/local/apache2/bin/apachectl -t
Syntax OK

# 關閉apache服務
[root@idyslamp httpd-2.4.7] /usr/local/apache2/bin/apachectl stop
  • 關於報錯:

報錯提示:若啓動時提示/usr/local/apache2/modules/mod_deflate.so無權限,可關閉 SELinux 解 決,類似此類.so 文件不能載入或沒有權限的問題,都是 SELinux 問題,MySQLApache 都可能有類 似問題。


安裝mysql

安裝依賴包

  1. 安裝 ncurses

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

[root@idyslamp httpd-2.4.7]  cd /lamp/ncurses-5.9
[root@idyslamp ncurses-5.9] yum -y install ncurses-devel

# 檢測
[root@idyslamp ncurses-5.9] ./configure --with-shared --without-debug --without-ada --enable-overwrite

# 編譯,安裝
[root@idyslamp ncurses-5.9] make && make install;echo $?
  1. 安裝cmake 和 bison

mysql 在 5.5 以後,不再使用./configure 工具,進行編譯安裝。而使用cmake 工具替代了./configure 工具。bison 是一個自由軟件,用於自動生成語法分析器程序,可用於所有常見的操作系統

# 安裝cmake
[root@idyslamp ncurses-5.9] yum -y install cmake bison;echo $? 

安裝mysql

  1. 創建Mysql系統用戶
[root@idyslamp ~] useradd -r -s /sbin/nologin mysql
[root@idyslamp ~] cat /etc/passwd | grep mysql     
mysql:x:498:498::/home/mysql:/sbin/nologin
  1. 檢查、編譯、並且安裝mysql
# 檢查
[root@idyslamp mysql] 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

# 編譯安裝,然後查看是否允許
[root@idyslamp mysql] make && make install && echo $?
  1. 更改Mysql目錄的用戶歸屬
[root@idyslamp mysql] cd /usr/local/mysql/
[root@idyslamp mysql] chown -R root .
[root@idyslamp mysql] chown -R mysql data
  1. 複製Mysql配置文件,並且初始化授權表
# 生成配置文件
[root@idyslamp mysql] cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf 

# 創建數據庫授權表
[root@idyslamp mysql] ./scripts/mysql_install_db --user=mysql
  1. 啓動Mysql服務
[root@idyslamp mysql] ./bin/mysqld_safe --user=mysql
  1. 添加Mysq用戶名密碼
[root@idyslamp ~] /usr/local/mysql/bin/mysqladmin -uroot password root
  1. 登錄Mysql
[root@idyslamp ~] /usr/local/mysql/bin/mysql -uroot -proot
  1. mysql的一些基本操作
# 使用mysql這個數據庫
use mysql;

# 展示mysql下有幾個數據庫
show databases;

# 查看有所有的表
show tables

# 查詢mysql
mysql> select User,Password from user; 

安裝PHP

PHP基本安裝

  1. 檢查、編譯、安裝
[root@idyslamp 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 && make && make install && echo $?
  1. 複製php配置文件
[root@idyslamp php-7.0.7] mkdir /usr/local/php/etc
[root@idyslamp php-7.0.7] cp php.ini-production /usr/local/php/etc/php.ini
  1. 修改Apache配置文件,使其識別*.php 文件,並能通過 php 模塊調用 php 進行頁面解析
[root@idyslamp /] vim /usr/local/apache2/etc/httpd.conf
# 添加如下代碼
    AddType application/x-httpd-php .php .phtml
    AddType application/x-httpd-php-source .phps
  1. 開啓Apache服務
[root@idyslamp /] /usr/local/apache2/bin/apachectl start
  1. 在目錄下編寫php文件,然後在瀏覽器訪問,看其是否可以解析
[root@idyslamp /] cd /usr/local/apache2/htdocs/
[root@idyslamp htdocs] vim test.php
<?php
        phpinfo();
?>

php附加擴展安裝

  1. 安裝openssl,爲其提供加密
# 將某個配置文件改名
[root@idyslamp openssl] mv config0.m4 config.m4

# 生成編譯文件
[root@idyslamp openssl] /usr/local/php/bin/phpize 

# 檢查、編譯、安裝
[root@idyslamp openssl] ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config && make && make install && echo $?


  1. 爲php安裝memcache模塊
# 進入目錄
[root@idyslamp openssl] cd /lamp/pecl-memcache-php7

# 生成configure文件
[root@idyslamp pecl-memcache-php7] /usr/local/php/bin/phpize

# 檢查、編譯、安裝
[root@idyslamp pecl-memcache-php7] ./configure --with-php-config=/usr/local/php/bin/php-config && make && make install && echo $?
  1. 修改 php 配置文件,使其識別並調用 opensslmemcache 兩個模塊
# 編譯php配置文件
[root@idyslamp pecl-memcache-php7]  vim /usr/local/php/etc/php.ini
# 添加如下內容
extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
# 取消分號註釋,並添加以上路徑(此路徑來自於模塊安裝命令的結果)
extension="openssl.so";
extension="memcache.so";
# 添加以上兩個庫文件的調用
  1. 安裝 memcached 服務
# yum 安裝libevent-devel
[root@idyslamp pecl-memcache-php7] yum -y install libevent-devel

# 檢查、安裝、編譯
[root@idyslamp memcached-1.4.17] ./configure --prefix=/usr/local/memcache && make && make install && echo $?

# 添加memcache用戶
[root@idyslamp memcached-1.4.17] useradd -r -s /sbin/nologin memcache

# 後臺啓動memcache服務
[root@idyslamp memcached-1.4.17] /usr/local/memcache/bin/memcached -umemcache &

# 查詢memcache是否安裝成功
[root@idyslamp memcached-1.4.17] netstat -an | grep :11211
  1. 部署phpmyadmin
# 複製文件夾
[root@idyslamp lamp] cp -a phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin

# 進入安裝目錄
[root@idyslamp lamp] cd /usr/local/apache2/htdocs/phpmyadmin/

# 修改配置文件
[root@idyslamp phpmyadmin] cp -a config.sample.inc.php config.inc.php
[root@idyslamp phpmyadmin] vim config.inc.php
#做出如下修改
$cfg['Servers'][$i]['auth_type'] = 'http';
$cfg['Servers'][$i]['auth_type'] = 'cookie';
  1. 設置 Apache、MySQL、Memcache 開機自啓

藉助系統自帶腳本/etc/rc.local,此腳本開機後會自動加載,我們可以將源碼安裝的服務啓動命令 寫入該腳本,間接實現開機自啓動

[root@idyslamp htdocs] vim /etc/rc.local 
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.

touch /var/lock/subsys/local
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &

CentOS7上搭建LAMP

環境準備

  1. 首先關閉防火牆
[root@idys ~] systemctl stop firewalld
[root@idys ~] systemctl disable firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

# 查看防火牆規則,可以顯示防火牆已經全部關閉了
[root@idys ~] iptables -F
  1. 關閉SElinux
# 查看SELinux狀態
[root@idys ~] getenforce 
Enforcing
[root@idys ~] setenforce 0
Permissive
[root@idys ~] vi /etc/selinux/config 
SELINUX=disabled
  1. 掛載光驅文件
[root@idys ~] vim /etc/fstab
# 添加以下行
UUID=2019-09-09-19-08-41-00               /media/cdrom            iso9660 defaults        0 0
# 然後依據配置文件全部掛載
[root@idys ~] mount -a
  1. 配置本地yum源,做出如下修改
[root@idys yum.repos.d] vi CentOS-Media.repo
[c7-media]
name=CentOS-$releasever - Media
baseurl=file:///media/cdrom/
#baseurl=file:///media/CentOS/
#        file:///media/cdrom/
#        file:///media/cdrecorder/
gpgcheck=1
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
  1. CentOS-Base.repo改名
[root@idys yum.repos.d] mv CentOS-Base.repo CentOS-Base.repo.bak
  1. 安裝gccgcc-c++make等編譯工具
[root@idys yum.repos.d] yum -y install gcc gcc-c++ make;echo $? #使用echo $? 是爲了查看是否執行成功
  1. 查看是否有安裝Apachemysql服務
[root@idys /] systemctl list-unit-files | grep -E "httpd|mysqld" 
  1. 上傳lamp環境所必備的源碼包

  2. 安裝unzip,然後解壓LAMP環境源碼包到指定路徑

[root@idys tmp] yum -y install unzip

# 將其解壓到/lamp目錄下
unzip LAMP-php7.zip -d /lamp/

10 .解壓lamp目錄下所有壓縮文件

cd /lamp/
mv LAMP-php7/* ./
rmdir LAMP-php7/
ls ./*.gz | xargs -n1 -i tar -xvf {} # 解壓所有以.gz結尾的壓縮文件
unzip pecl-memcache-php7.zip # 再解壓這個文件

編譯安裝

  1. 安裝libxml2
  • 安裝編譯安裝依賴的包
[root@idys lamp] yum -y install libxml2-devel python-devel;echo $?
  • 檢查
[root@idys libxml2-2.9.1] ./configure --prefix=/usr/local/libxml2
  • 編譯、安裝
[root@idys libxml2-2.9.1] make && make install;echo $?
  1. 安裝libcrypt
  • 檢查環境
[root@idys libmcrypt-2.5.8] ./configure --prefix=/usr/local/libmcrypt;echo $? 
  • 編譯安裝
[root@idys libmcrypt-2.5.8] make && make install;echo $?
  1. 安裝libltdl,在libmcrypt目錄下
  • 進入目錄
[root@idys libmcrypt-2.5.8] cd /lamp/libmcrypt-2.5.8/libltdl/
  • 檢查
[root@idys libltdl] ./configure --enable-ltdl-install;echo $?
  • 編譯安裝
[root@idys libltdl] make && make install;echo $?
  1. 編譯安裝mhash
  • 進入目錄
[root@idys libltdl] cd /lamp/mhash-0.9.9.9
  • 檢查
[root@idys mhash-0.9.9.9] ./configure;echo $?
  • 編譯安裝
[root@idys mhash-0.9.9.9] make && make install;echo $?
  1. 安裝mcrypt
  • 定義LD_LIBRARY_PATH用於指定libmcryptmhash的位置
[root@idys mcrypt-2.6.8] export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
  • 檢查
[root@idys mcrypt-2.6.8] ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt/
  • 編譯安裝
[root@idys mcrypt-2.6.8] make && make install;echo $?
  1. 安裝zlib
  • 進入目錄
[root@idys mcrypt-2.6.8] cd /lamp/zlib-1.2.3
  • 檢查
[root@idys zlib-1.2.3] ./configure;echo $?
  • 編輯該目錄下的MakeFile文件 在CFLAGS最後上加上-fPIC注意是小fPIC
[root@idys zlib-1.2.3] vi Makefile
CFLAGS=-O3 -DUSE_MMAP -fPIC #隔一個空格然後加上-fPIC
  • 編譯安裝
[root@idys zlib-1.2.3] make && make install;echo $?
  1. 安裝libpng
  • 進入目錄
[root@idys zlib-1.2.3] cd /lamp/libpng-1.2.31
  • 檢查
[root@idys libpng-1.2.31] ./configure --prefix=/usr/local/libpng
  • 編譯安裝
[root@idys libpng-1.2.31] make && make install;echo $?
  1. 安裝jpeg6
  • 創建目錄
[root@idys libpng-1.2.31] mkdir -p /usr/local/jpeg6/{bin,lib,include,man/man1}
  • 查看目錄創建情況
[root@idys libpng-1.2.31] tree /usr/local/jpeg6/
/usr/local/jpeg6/
├── bin
├── include
├── lib
└── man
    └── man1

5 directories, 0 files
  • 查看libtool軟件包
[root@idys libpng-1.2.31] yum list | grep libtool
libtool-ltdl.x86_64                         2.4.2-22.el7_3             @anaconda
libtool.x86_64                              2.4.2-22.el7_3             c7-media 
libtool-ltdl.i686                           2.4.2-22.el7_3             c7-media 
libtool-ltdl-devel.i686                     2.4.2-22.el7_3             c7-media 
libtool-ltdl-devel.x86_64                   2.4.2-22.el7_3             c7-media
  • 安裝依賴軟件包
[root@idys libpng-1.2.31] yum -y install libtool*
  • 賦值模板文件到源碼包目錄下
[root@idys jpeg-6b] cp -ai /usr/share/libtool/config/{config.sub , config.guess} ./ 
  • 檢查
[root@idys jpeg-6b] ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static

–enable-shared 與–enable-static 參數分別爲建立共享庫和靜態庫使用的 libtool

  • 編譯安裝
[root@idys jpeg-6b] make && make install;echo $?
  1. 安裝freetype
  • 檢查
[root@idys jpeg-6b] cd /lamp/freetype-2.3.5
[root@idys freetype-2.3.5] ./configure --prefix=/usr/local/freetype;echo $?
  • 編譯、安裝
[root@idys freetype-2.3.5] make && make install;echo $?
  1. 安裝Apache
  • 源碼包 2.4.*版本中默認沒有集成 apr 的依賴包,所以需要提前解決依賴問題
[root@idys httpd-2.4.7] cp -a /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
[root@idys httpd-2.4.7] cp -a /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util

解壓 apr 和 apr-util,複製整個目錄並取消目錄上的版本號到指定位置,./configure 時會檢測

  • .Apache 默認需要依賴 pcre 軟件,但由於 Apache 軟件版本較高,則系統預安裝的 pcre 無法使用, 所以需要人爲手動安裝適合版本
[root@idys httpd-2.4.7] cd /lamp/pcre-8.34
[root@idys pcre-8.34] ./configure;echo $?
make && make install;echo $?
  • Apache 的加密傳輸模塊 mod_ssl,需要安裝此軟件產生
[root@idys pcre-8.34] yum -y install openssl-devel
  • httpd 軟件安裝
# 檢查
[root@idys 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 --enable-ssl

# 編譯安裝
[root@idys httpd-2.4.7] make && make install;echo $?

若前面配置 zlib 時沒有指定安裝目錄,Apache 配置時不要添加--with-z=/usr/local/zlib/參數, --enable-ssl 選項是爲了後期實現 https 提前設置的參數

  • 啓動Apache測試
# 修改Apache的配置文件httpd.conf
[root@idys httpd-2.4.7] vim /usr/local/apache2/etc/httpd.conf 
# 在190行左右,修改Servername的配置爲 localhost:80
ServerName localhost:80

# 啓動Apache
[root@idys httpd-2.4.7] /usr/local/apache2/bin/apachectl start

# 查看Apache啓動狀態
[root@idys httpd-2.4.7] ps aun | grep httpd
       0  84129  0.0  0.0 110276   884 pts/0    S+   10:34   0:00 grep --color=auto httpd

[root@idys httpd-2.4.7] netstat -tlun | grep 80
tcp6       0      0 :::80                   :::*                    LISTEN 

注意事項:在 CentOS 7 操作系統上 Apache 默認監聽了 Ipv6 地址的 80 端口,沒有監聽 Ipv4 的地址, 所以需要修改下配置文件使其監聽。 Listen 0.0.0.0:80,但是我發現其實沒有修改這個選項,也可以訪問Apache,只不過監聽端口爲tcp6的監聽端口

  1. 安裝ncurses
[root@idys httpd-2.4.7] yum -y install ncurses-devel
  • 檢查
[root@idys ncurses-5.9] ./configure --with-shared --without-debug --without-ada --enable-overwrite
[root@idys ncurses-5.9] echo $?
0
  • 安裝編譯
[root@idys ncurses-5.9] make && make install;echo $?

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

  1. 安裝cmakebison
[root@idys ncurses-5.9] yum -y install bison
  1. 安裝Mysql
  • 創建用戶
[root@idys ncurses-5.9] adduser -r -s /sbin/nologin mysql
  • cmake
[root@idys 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;echo $?
  • 編譯安裝
[root@idys mysql-5.5.48] make && make install;echo $?
  • 選項說明
選項 作用
-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 啓用加載本地數據
-DMYSQL_USER=mysql 指定 mysql 運行用戶
-DMYSQL_TCP_PORT=3306 指定 mysql 端口
  • 修改 MySQL 目錄的用戶歸屬
[root@idys mysql-5.5.48] cd /usr/local/mysql/
[root@idys mysql] chown -R root .
[root@idys mysql] chown -R mysql data
  • 生成配置文件,並初始化授權表
[root@idys mysql] cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf
cp: overwrite ‘/etc/my.cnf’? y

# 複製 MySQL 配置文件到指定位置,覆蓋掉系統自帶文件
  • 創建數據庫授權表,初始化數據庫,相當於安裝完操作系統後的引導設置(添加第一個用戶)
[root@idys mysql] ./scripts/mysql_install_db --user=mysql 
  • 啓動mysql
[root@idys mysql] /usr/local/mysql/bin/mysqld_safe --user=mysql
  • 設定mysql用戶名密碼
[root@idys mysql] bin/mysqladmin -uroot -password 123456
  • 登錄mysql
[root@idys mysql] bin/mysql -u root -p123456
  1. 安裝PHP
[root@idys mysql] cd /lamp/php-7.0.7
[root@idys 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
[root@idys php-7.0.7] echo $?
0
[root@idys php-7.0.7] make && make install;echo $?
  • 配置參數說明
選項 作用
–with-config-file-path=/usr/local/php/etc/ 指定配置文件目錄
–with-apxs2=/usr/local/apache2/bin/apxs 指定 apache 動態模塊位置
–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 服務
–enable-mbstring=all 支持多字節,字符串
–enable-sockets 支持套接字
–with-pdo-mysql=/usr/local/mysql 啓用 mysql 的 pdo 模塊支持
–without-pear 不安裝 pear(安裝 pear 需要連接互聯網)

注意:PHP 安裝後需要調整相應配置文件和參數才能正常運行

  • 生成 php 配置文件
[root@idys php-7.0.7] cd /usr/local/php/
[root@idys php] mkdir etc
[root@idys php] cp /lamp/php-7.0.7/php.ini-production ./etc/php.ini
  • 修改 Apache 配置文件,使其識別*.php 文件,並能通過 php 模塊調用 php 進行頁面解析
[root@idys php] vim /usr/local/apache2/etc/httpd.conf
# 在最後一行添加以下內容
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
  • 重啓 Apache 服務
[root@idys htdocs] ../bin/apachectl stop
[root@idys htdocs] ../bin/apachectl start
  • 測試 php 頁面是否能正常解析(即 apache 和 php 連通性)
[root@idys htdocs] vim test.php
# 添加如下內容
<?php
phpinfo();
?>

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

  1. 爲 PHP 安裝 openssl 模塊
[root@idys ~] cd /lamp/php-7.0.7
[root@idys php-7.0.7] cd ext/openssl/
[root@idys openssl] mv config0.m4 config.m4

# 生成編譯工具
[root@idys openssl] /usr/local/php/bin/phpize 
Configuring for:
PHP Api Version:         20151012
Zend Module Api No:      20151012
Zend Extension Api No:   320151012

[root@idys openssl] ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config
[root@idys openssl] echo $?
0
[root@idys openssl] make && make install;echo $?
  1. PHP 安裝 memcache 模塊
[root@idys openssl] cd /lamp/pecl-memcache-php7

# 生成編譯工具
[root@idys pecl-memcache-php7] /usr/local/php/bin/phpize 

[root@idys pecl-memcache-php7] ./configure --with-php-config=/usr/local/php/bin/php-config;echo $?

[root@idys pecl-memcache-php7] make && make install;echo $?
  1. 修改 php 配置文件,使其識別並調用 opensslmemcache 兩個模塊
[root@idys pecl-memcache-php7] cd /usr/local/php/etc/
[root@idys etc] vim php.ini 
# 添加如下內容,此路徑來自模塊安裝命令的結果
extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
# (添加兩個庫文件的調用)
extension="openssl.so"; 
extension="memcache.so";
  • 重啓 apache,刷新 phpinfo 頁面,並查看是否有兩個新增的模塊
  1. 安裝 memcached 服務
# 下載安裝包
[root@idys tmp] wget http://mirror.centos.org/centos/7/os/x86_64/Packages/libevent-devel-2.0.21-4.el7.x86_64.rpm

[root@idys tmp] yum -y install libevent-devel

[root@idys lamp] cd /lamp/memcached-1.4.17

[root@idys memcached-1.4.17] ./configure --prefix=/usr/local/memcache

[root@idys memcached-1.4.17] make && make install;echo $?
  • 添加memcache用戶,同時開啓memcache服務
[root@idys memcached-1.4.17] useradd -r -s /sbin/nologin memcache
# 添加 memcache 用戶,此用戶不用登錄,不設置密碼

/usr/local/memcache/bin/memcached -umemcache &
#啓動 memcache 服務,並設置爲後臺運行

[root@idys memcached-1.4.17] netstat -an | grep :11211
tcp        0      0 0.0.0.0:11211           0.0.0.0:*               LISTEN     
tcp6       0      0 :::11211                :::*                    LISTEN     
udp        0      0 0.0.0.0:11211           0.0.0.0:*                          
udp6       0      0 :::11211                :::*  
檢查 memcache 是否正常啓動,並監聽了 11211 端口
  1. 安裝 phpMyAdmin
# 複製文件
[root@idys memcached-1.4.17] cp -a /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin


[root@idys memcached-1.4.17] cd /usr/local/apache2/htdocs/phpmyadmin/

[root@idys phpmyadmin] cp -a config.sample.inc.php config.inc.php   
$cfg['Servers'][$i]['auth_type'] = 'cookie'; #在這行下面添加$cfg['Servers'][$i]['auth_type'] = 'http'; 含義設置 auth_type 爲 http ,即設置爲 HTTP 身份認證模式
$cfg['Servers'][$i]['auth_type'] = 'http';
  • 輸入http://YOURIPADDR/phpmyadmin/index.php
  • 然後輸入你設置的mysql用戶名和密碼

  1. 設置 Apache、MySQL、Memcache 開機自啓
  • 藉助系統自帶腳本/etc/rc.local,此腳本開機後會自動加載,我們可以將源碼安裝的服務啓動命令寫入該腳本,間接實現開機自啓動
# 編輯rc.local文件,添加如下3行
[root@idys phpmyadmin] vim /etc/rc.local 
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &
  1. 項目發佈
  • 把 php 項目拷貝到網站默認目錄下:/usr/local/apache2/htdocs/**
  • 使用 phpMyAdmin 創建網站所需數據庫

注意事項:注意目錄權限和歸屬,防止權限過大或者權限過小

# 下載一個blog項目
[root@idys lamp] wget http://typecho.org/downloads/1.1-17.10.30-release.tar.gz

[root@idys lamp] tar -zxvf 1.1-17.10.30-release.tar.gz  解壓項目

將項目移動到Apache的htdocs下,並且改名爲blog
[root@idys lamp] cp -a build /usr/local/apache2/htdocs/blog

# 查看Apache運行的用戶實例
[root@idys lamp] ps aux | grep httpd
root     101685  0.0  0.5 263632 11400 ?        Ss   17:10   0:00 /usr/local/apache2/bin/httpd -k start
daemon   101687  0.0  1.1 815796 23728 ?        Sl   17:10   0:00 /usr/local/apache2/bin/httpd -k start
daemon   101688  0.0  1.6 890220 32496 ?        Sl   17:10   0:00 /usr/local/apache2/bin/httpd -k start
daemon   101689  0.0  1.7 890112 34500 ?        Sl   17:10   0:00 /usr/local/apache2/bin/httpd -k start
daemon   101771  0.0  1.3 817764 26860 ?        Sl   17:10   0:00 /usr/local/apache2/bin/httpd -k start
root     103233  0.0  0.0 112716   960 pts/0    S+   17:57   0:00 grep --color=auto httpd

# 給運行apache的用戶賦予對博客目錄的權限
[root@idys lamp] setfacl -m u:daemon:rwx /usr/local/apache2/htdocs/blog/


寫在最後的話:

  • 無論每個知識點的難易程度如何,我都會盡力將它描繪得足夠細緻
  • 歡迎關注我的CSDN博客,IDYS’BLOG
  • 持續更新內容
    linux基礎 | 數據通信(路由交換,WLAN) | Python基礎 | 雲計算
  • 如果你有什麼疑問,或者是難題。歡迎評論或者私信我。你若留言,我必回覆!
  • 雖然我現在還很渺小,但我會做好每一篇內容。謝謝關注!

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章