目錄php
lamp架構html
lamp其實就是由Linux+Apache+Mysql/MariaDB+Php/Perl/Python
的一組動態網站或者服務器的開源軟件,除Linux外其它各部件自己都是各自獨立的程序,可是由於常常被放在一塊兒使用,擁有了愈來愈高的兼容度,共同組成了一個強大的Web應用程序平臺。python
LAMP指的是Linux(操做系統)、Apache(HTTP服務器)、MySQL(也指MariaDB,數據庫軟件)和PHP(有時也是指Perl或Python)的第一個字母,通常用來創建web應用平臺。mysql
web服務器的資源分爲兩種,靜態資源和動態資源linux
階段①顯示的是httpd服務器(即apache)和php服務器經過FastCGI協議進行通訊,且php做爲獨立的服務進程運行web
階段②顯示的是php程序和mysql數據庫間經過mysql協議進行通訊。php與mysql本沒有什麼聯繫,可是由Php語言寫成的程序能夠與mysql進行數據交互。同理perl和python寫的程序也能夠與mysql數據庫進行交互sql
CGI與FastCGI。數據庫
CGI(Common Gateway Interface,通用網關接口),CGI是外部應用程序(CGI程序)與WEB服務器之間的接口標準,是在CGI程序和Web服務器之間傳遞信息的過程。CGI規範容許Web服務器執行外部程序,並將它們的輸出發送給Web瀏覽器,CGI將web的一組簡單的靜態超媒體文檔變成一個完整的新的交互式媒體。apache
FastCGI(Fast Common Gateway Interface)是CGI的改良版,CGI是經過啓用一個解釋器進程來處理每一個請求,耗時且耗資源,而FastCGI則是經過master-worker形式來處理每一個請求,即啓動一個master主進程,而後根據配置啓動幾個worker進程,當請求進來時,master會從worker進程中選擇一個去處理請求,這樣就避免了重複的生成和殺死進程帶來的頻繁cpu上下文切換而致使耗時json
httpd與php結合的方式有如下三種:
較於CGI方式,FastCGI更爲經常使用,不多有人使用CGI方式來加載動態資源
經過上面的圖說明一下web的工做流程:
環境說明:
系統平臺 | IP | 須要安裝的服務 |
---|---|---|
centos7 redhat7 |
192.168.112.156 | httpd-2.4 mysql-5.7 php php-mysql |
lamp平臺軟件安裝次序:httpd --> mysql --> php
注意:php要求httpd使用prefork MPM
//安裝開發工具包 [root@cwh ~]# yum groups mark install 'Development Tools' [root@cwh ~]# yum group list 已加載插件:product-id, search-disabled-repos, subscription-manager This system is not registered with an entitlement server. You can use subscription-manager to register. Repodata is over 2 weeks old. Install yum-cron? Or run: yum makecache fast 可用的環境分組: 最小安裝 基礎設施服務器 文件及打印服務器 基本網頁服務器 虛擬化主機 帶 GUI 的服務器 已安裝的組: 開發工具 可用組: 傳統 UNIX 兼容性 兼容性程序庫 圖形管理工具 安全性工具 控制檯互聯網工具 智能卡支持 科學記數法支持 系統管理 系統管理工具 完成 //建立apache服務的用戶和組 [root@cwh ~]# groupadd -r apache [root@cwh ~]# useradd -r -M -s /sbin/nologin -g apache apache //安裝依賴包 [root@cwh ~]# yum -y install openssl-devel pcre-devel expat-devel libtool //下載和安裝apr以及apr-util [root@cwh ~]# wget http://mirrors.shu.edu.cn/apache//apr/apr-1.6.5.tar.bz2 [root@cwh ~]# wget http://www.apache.org/dist/apr/apr-util-1.6.1.tar.bz2 [root@cwh ~]# ls anaconda-ks.cfg apr-1.6.5.tar.bz2 apr-util-1.6.1.tar.bz2 [root@cwh ~]# tar xf apr-1.6.5.tar.bz2 [root@cwh ~]# tar xf apr-util-1.6.1.tar.bz2 [root@cwh ~]# ls anaconda-ks.cfg apr-1.6.5 apr-1.6.5.tar.bz2 apr-util-1.6.1 apr-util-1.6.1.tar.bz2 [root@cwh ~]# cd apr-1.6.5 [root@cwh apr-1.6.5]# vim configure cfgfile="${ofile}T" trap "$RM \"$cfgfile\"; exit 1" 1 2 15 # $RM "$cfgfile" //將此行加上註釋,或者刪除此行 [root@cwh apr-1.6.5]# ./configure --prefix=/usr/local/apr [root@cwh apr-1.6.5]# make && make install [root@cwh apr-1.6.5]# cd ../apr-util-1.6.1 [root@cwh apr-util-1.6.1]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr [root@cwh apr-util-1.6.1]# make && make install //編譯安裝httpd [root@cwh ~]# wget http://mirror.bit.edu.cn/apache//httpd/httpd-2.4.37.tar.bz2 --2019-05-13 16:15:41-- http://mirror.bit.edu.cn/apache//httpd/httpd-2.4.37.tar.bz2 正在解析主機 mirror.bit.edu.cn (mirror.bit.edu.cn)... 202.204.80.77, 219.143.204.117, 2001:da8:204:2001:250:56ff:fea1:22 正在鏈接 mirror.bit.edu.cn (mirror.bit.edu.cn)|202.204.80.77|:80... 已鏈接。 已發出 HTTP 請求,正在等待迴應... 302 Found 位置:http://64.123.28.147/files/92060000007D8B8B/mirrors.hust.edu.cn/apache//httpd/httpd-2.4.37.tar.bz2 [跟隨至新的 URL] --2019-05-13 16:15:41-- http://64.123.28.147/files/92060000007D8B8B/mirrors.hust.edu.cn/apache//httpd/httpd-2.4.37.tar.bz2 正在鏈接 64.123.28.147:80... 已鏈接。 已發出 HTTP 請求,正在等待迴應... 200 OK 長度:7031632 (6.7M) [application/octet-stream] 正在保存至: 「httpd-2.4.37.tar.bz2」 100%[=====================================================================================================================================================>] 7,031,632 6.62MB/s 用時 1.0s 2019-05-13 16:15:42 (6.62 MB/s) - 已保存 「httpd-2.4.37.tar.bz2」 [7031632/7031632]) [root@cwh ~]# ls anaconda-ks.cfg apr-1.6.5 apr-1.6.5.tar.bz2 apr-util-1.6.1 apr-util-1.6.1.tar.bz2 httpd-2.4.37.tar.bz2 [root@cwh ~]# tar xf httpd-2.4.37.tar.bz2 [root@cwh ~]# cd httpd-2.4.37 [root@cwh httpd-2.4.37]# ./configure --prefix=/usr/local/apache \ --sysconfdir=/etc/httpd24 \ --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 [root@cwh httpd-2.4.37]# make && make install //安裝後配置 [root@cwh httpd-2.4.37]# cd [root@cwh ~]# echo 'export PATH=/usr/local/apache/bin:$PATH' > /etc/profile.d/httpd.sh [root@cwh ~]# . /etc/profile.d/httpd.sh [root@cwh ~]# ln -s /usr/local/apache/include/ /usr/include/httpd [root@cwh ~]# echo 'MANPATH /usr/local/apache/man' >> /etc/man.config //取消ServerName前面的註釋 [root@cwh ~]# sed -i '/#ServerName/s/#//g' /etc/httpd24/httpd.conf //啓動apache [root@cwh ~]# apachectl start [root@cwh ~]# ss -antl |grep 80 LISTEN 0 128 :::80 :::*
//安裝依賴包 [root@cwh ~]# yum -y install ncurses-devel openssl-devel openssl cmake mariadb-devel //建立用戶和組 [root@cwh ~]# groupadd -r mysql [root@cwh ~]# useradd -M -s /sbin/nologin -g mysql mysql //下載二進制格式的mysql軟件包 [root@cwh ~]# wget https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz [root@cwh ~]# ls anaconda-ks.cfg apr-1.6.5 apr-1.6.5.tar.bz2 apr-util-1.6.1 apr-util-1.6.1.tar.bz2 httpd-2.4.37 httpd-2.4.37.tar.bz2 mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz //解壓軟件至/usr/local/ [root@cwh ~]# tar xf mysql-5.7.22-linux-glibc2.12-x86_64.tar.gz -C /usr/local/ [root@cwh ~]# cd /usr/local/ [root@cwh local]# ls apache apr apr-util bin etc games include lib lib64 libexec mysql-5.7.22-linux-glibc2.12-x86_64 sbin share src [root@cwh local]# ln -sv mysql-5.7.22-linux-glibc2.12-x86_64/ mysql "mysql" -> "mysql-5.7.22-linux-glibc2.12-x86_64/" //修改目錄/usr/local/mysql的屬主屬組 [root@cwh local]# chown -R mysql.mysql /usr/local/mysql* [root@cwh local]# ll 總用量 0 drwxr-xr-x. 13 root root 152 5月 13 16:21 apache drwxr-xr-x. 6 root root 58 5月 13 16:12 apr drwxr-xr-x. 5 root root 43 5月 13 16:14 apr-util drwxr-xr-x. 2 root root 6 12月 15 2017 bin drwxr-xr-x. 2 root root 6 12月 15 2017 etc drwxr-xr-x. 2 root root 6 12月 15 2017 games drwxr-xr-x. 2 root root 6 12月 15 2017 include drwxr-xr-x. 2 root root 6 12月 15 2017 lib drwxr-xr-x. 2 root root 6 12月 15 2017 lib64 drwxr-xr-x. 2 root root 6 12月 15 2017 libexec lrwxrwxrwx. 1 mysql mysql 36 5月 13 16:47 mysql -> mysql-5.7.22-linux-glibc2.12-x86_64/ drwxr-xr-x. 9 mysql mysql 129 5月 13 16:45 mysql-5.7.22-linux-glibc2.12-x86_64 drwxr-xr-x. 2 root root 6 12月 15 2017 sbin drwxr-xr-x. 5 root root 49 4月 16 00:27 share drwxr-xr-x. 2 root root 6 12月 15 2017 src //添加環境變量 [root@cwh local]# echo 'export PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh [root@cwh local]# . /etc/profile.d/mysql.sh //創建數據存放目錄 [root@cwh local]# mkdir /opt/data [root@cwh local]# chown -R mysql.mysql /opt/data/ //初始化數據庫 [root@cwh local]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/opt/data/ 2019-05-13T08:50:42.336456Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details). 2019-05-13T08:50:42.731987Z 0 [Warning] InnoDB: New log files created, LSN=45790 2019-05-13T08:50:42.771529Z 0 [Warning] InnoDB: Creating foreign key constraint system tables. 2019-05-13T08:50:42.827037Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 30d5ce4f-755c-11e9-a841-000c2938f528. 2019-05-13T08:50:42.828198Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened. 2019-05-13T08:50:42.829188Z 1 [Note] A temporary password is generated for root@localhost: JeJIXI&kn7p< //初始化隨機密碼第一次登錄須要用到 //配置mysql [root@cwh ~]# ln -sv /usr/local/mysql/include/ /usr/local/include/mysql "/usr/local/include/mysql" -> "/usr/local/mysql/include/" [root@cwh ~]# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf [root@cwh ~]# ldconfig -v [root@cwh ~]# ldconfig -p |grep mysql libmysqlclient.so.20 (libc6,x86-64) => /usr/local/mysql/lib/libmysqlclient.so.20 libmysqlclient.so.18 (libc6,x86-64) => /usr/lib64/mysql/libmysqlclient.so.18 libmysqlclient.so (libc6,x86-64) => /usr/lib64/mysql/libmysqlclient.so libmysqlclient.so (libc6,x86-64) => /usr/local/mysql/lib/libmysqlclient.so //生成配置文件 [root@cwh ~]# cat > /etc/my.cnf <<EOF > [mysqld] > basedir = /usr/local/mysql > datadir = /opt/data > socket = /tmp/mysql.sock > port = 3306 > pid-file = /opt/data/mysql.pid > user = mysql > skip-name-resolve > EOF //配置服務啓動腳本(使用sed命令或者修改/etc/init.d/mysqld中的basedir和datadir) [root@cwh ~]# cp -a /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld [root@cwh ~]# sed -ri 's#^(basedir=).*#\1/usr/local/mysql#g' /etc/init.d/mysqld [root@cwh ~]# sed -ri 's#^(datadir=).*#\1/opt/data#g' /etc/init.d/mysqld //啓動mysql [root@cwh ~]# service mysqld start Starting MySQL.Logging to '/opt/data/cwh.err'. . SUCCESS! [root@cwh ~]# ss -antl |grep 3306 LISTEN 0 80 :::3306 :::* //修改密碼 //使用臨時密碼登陸 [root@cwh ~]# mysql -uroot -p'JeJIXI&kn7p<' -e 'set password = password("wangqing123!")' mysql: [Warning] Using a password on the command line interface can be insecure. Please use --connect-expired-password option or invoke mysql in interactive mode. //此時修改失敗要你使用--connect-expired-password選項 [root@cwh ~]# mysql -uroot -p'JeJIXI&kn7p<' -e 'set password = password("wangqing123!")' --connect-expired-password mysql: [Warning] Using a password on the command line interface can be insecure. //此時修改密碼成功
//配置yum源 [root@cwh ~]# cd /etc/yum.repos.d/ [root@cwh yum.repos.d]# wget http://mirrors.163.com/.help/CentOS7-Base-163.repo [root@cwh ~]# sed -i 's/\$releasever/7/g' /etc/yum.repos.d/CentOS7-Base-163.repo [root@cwh ~]# sed -i 's/^enabled=.*/enabled=1/g' /etc/yum.repos.d/CentOS7-Base-163.repo [root@cwh ~]# yum -y install epel-release [root@cwh ~]# rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm //安裝依賴包 [root@localhost ~]# yum -y install libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libicu-devel libjpeg libjpeg-devel libpng libpng-devel openldap-devel libpcre-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel mhash mhash-devel php72w-mysqlnd //下載php [root@cwh ~]# wget http://cn.php.net/distributions/php-7.2.8.tar.xz //編譯安裝php [root@cwh ~]# tar xf php-7.2.8.tar.xz [root@cwh ~]# cd php-7.2.8 [root@cwh php-7.2.8]# ./configure --prefix=/usr/local/php7 \ --with-config-file-path=/etc \ --enable-fpm \ --enable-inline-optimization \ --disable-debug \ --disable-rpath \ --enable-shared \ --enable-soap \ --with-openssl \ --enable-bcmath \ --with-iconv \ --with-bz2 \ --enable-calendar \ --with-curl \ --enable-exif \ --enable-ftp \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-zlib-dir \ --with-freetype-dir \ --with-gettext \ --enable-json \ --enable-mbstring \ --enable-pdo \ --with-mysqli=mysqlnd \ --with-pdo-mysql=mysqlnd \ --with-readline \ --enable-shmop \ --enable-simplexml \ --enable-sockets \ --enable-zip \ --enable-mysqlnd-compression-support \ --with-pear \ --enable-pcntl \ --enable-posix [root@localhost php-7.2.8]# make && make install //安裝後配置 [root@cwh ~]# echo 'export PATH=/usr/local/php7/bin:$PATH' > /etc/profile.d/php7.sh [root@cwh ~]# source /etc/profile.d/php7.sh //配置php-fpm [root@cwh php-7.2.8]# cp php.ini-production /etc/php.ini [root@cwh php-7.2.8]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm [root@cwh php-7.2.8]# chmod +x /etc/rc.d/init.d/php-fpm [root@cwh php-7.2.8]# cp /usr/local/php7/etc/php-fpm.conf.default /usr/local/php7/etc/php-fpm.conf [root@cwh php-7.2.8]# cp /usr/local/php7/etc/php-fpm.d/www.conf.default /usr/local/php7/etc/php-fpm.d/www.conf //編輯php-fpm的配置文件(/usr/local/php7/etc/php-fpm.conf): //配置fpm的相關選項爲你所須要的值: [root@cwh ~]# vim /usr/local/php7/etc/php-fpm.conf //加入如下幾行 pm.max_children = 50 //最多同時提供50個進程提供50個併發服務 pm.start_servers = 5 //啓動時啓動5個進程 pm.min_spare_servers = 2 //最小空閒進程數 pm.max_spare_servers = 8 //最大空閒進程數 //啓動php-fpm [root@cwh ~]# service php-fpm start Starting php-fpm done [root@cwh ~]# ss -antl |grep 9000 LISTEN 0 128 127.0.0.1:9000
在apache httpd 2.4之後已經專門有一個模塊針對FastCGI的實現,此模塊爲mod_proxy_fcgi.so,它實際上是做爲mod_proxy.so模塊的擴展,所以,這兩個模塊都要加載,編輯httpd.conf文件,取消如下兩行內容的註釋:
//啓用httpd的相關模塊 1.再配置文件中取消mod_proxy_fcgi.so和mod_proxy.so模塊前的註釋 LoadModule proxy_module modules/mod_proxy.so //此行 #LoadModule proxy_connect_module modules/mod_proxy_connect.so #LoadModule proxy_ftp_module modules/mod_proxy_ftp.so #LoadModule proxy_http_module modules/mod_proxy_http.so LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so //此行 2.使用sed命令取消註釋多用於腳本 [root@cwh ~]# sed -i '/proxy_module/s/#//g' /etc/httpd24/httpd.conf [root@cwh ~]# sed -i '/proxy_fcgi_module/s/#//g' /etc/httpd24/httpd.conf
在須要使用fcgi的虛擬主機中添加相似以下兩行:
ProxyRequests Off //關閉正向代理
ProxyPassMatch ^/(.*.php)$ fcgi://127.0.0.1:9000/PATH/TO/DOCUMENT_ROOT/$1
例如:
ProxyPassMatch ^/(.*.php)$ fcgi://127.0.0.1:9000/var/www/html/idfsoft.com/$1
以上設置表示把以.php結尾的文件請求發送到php-fpm進程,php-fpm至少須要知道運行的目錄和URI,因此這裏直接在fcgi://127.0.0.1:9000後指明瞭這兩個參數,其它參數的傳遞已經被mod_proxy_fcgi.so進行了封裝,不須要手動指定。
注意:
//建立虛擬主機目錄並生成php測試頁面 [root@cwh ~]# mkdir /usr/local/apache/htdocs/cwh.com [root@cwh ~]# cat > /usr/local/apache/htdocs/cwh.com/index.php <<EOF <?php phpinfo(); ?> EOF [root@cwh ~]# chown -R apache.apache /usr/local/apache/htdocs/ [root@cwh ~]# ll /usr/local/apache/htdocs/ -d drwxr-xr-x 3 apache apache 44 Aug 16 14:50 /usr/local/apache/htdocs/
//在http配置文件的最後加入虛擬主機的配置內容 [root@localhost ~]# vim /etc/httpd24/httpd.conf <VirtualHost *:80> DocumentRoot "/usr/local/apache/htdocs/cwh.com" ServerName www.cwh.com ProxyRequests Off ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/usr/local/apache/htdocs/cwh.com/$1 <Directory "/usr/local/apache/htdocs/cwh.com"> Options none AllowOverride none Require all granted </Directory> </VirtualHost>
//在http配置文件中搜索AddType而且添加如下內容 [root@cwh ~]# vim /etc/httpd24/httpd.conf AddType application/x-compress .Z AddType application/x-gzip .gz .tgz AddType application/x-httpd-php .php //添加此行 AddType application/x-httpd-php-source .phps //添加此行
//在http配置文件中搜索DirectoryIndex而且修改如下內容 [root@cwh ~]# vim /etc/httpd24/httpd.conf <IfModule dir_module> DirectoryIndex index.html index.php </IfModule> 或者使用sed命令 [root@cwh ~]# sed -i '/ DirectoryIndex/s/index.html/index.php index.html/g' /etc/httpd24/httpd.conf
//重啓apache服務 [root@cwh ~]# apachectl stop [root@cwh ~]# apachectl start [root@cwh ~]# ss -antlp |grep http LISTEN 0 128 :::80 :::* users:(("httpd",pid=64084,fd=4),("httpd",pid=64083,fd=4),("httpd",pid=64082,fd=4),("httpd",pid=64081,fd=4),("httpd",pid=64080,fd=4),("httpd",pid=64079,fd=4))