php7詳細(xì)安裝教程(linux + nginx +PHP + mysql)

php下載網(wǎng)站:http://cn2.php.net/downloads.php
選擇你需要的版本.

首先ssh連接遠(yuǎn)程服務(wù)器,

在/usr/local/下創(chuàng)建php文件:

cd /usr/local/

創(chuàng)建source文件夾,專門用作下載包路徑.

mkdir source

創(chuàng)建php安裝路徑

mkdir php

進(jìn)入下載文件夾:

cd source/

下載包:

wget http://cn2.php.net/distributions/php-7.2.6.tar.gz

解壓(當(dāng)前目錄):

tar -zxvf php-7.2.6.tar.gz

查看解壓文件夾,并進(jìn)入

ls

php-7.2.6 php-7.2.6.tar.gz

移動(dòng)php-7.2.6文件夾內(nèi)文件到php里:

mv php-7.2.6/* /usr/local/php/

進(jìn)入待安裝目錄php

cd /usr/local/php/

經(jīng)過上面步驟基本上完成了下載文件,創(chuàng)建安裝目錄等操作.接下來需要做的是:

1 : 配置PHP安裝需要的環(huán)境
2 : 初始化并安裝PHP

配置PHP安裝需要的環(huán)境:

逐個(gè) 執(zhí)行下面命令,不要遺漏,也不要嫌麻煩:

yum -y install libxml2
yum -y install libxml2-devel
yum -y install openssl
yum -y install openssl-devel
yum -y install curl
yum -y install curl-devel
yum -y install libjpeg
yum -y install libjpeg-devel
yum -y install libpng
yum -y install libpng-devel
yum -y install freetype
yum -y install freetype-devel
yum -y install pcre
yum -y install pcre-devel
yum -y install libxslt
yum -y install libxslt-devel
yum -y install bzip2
yum -y install bzip2-devel
yum install gcc

執(zhí)行配置(注意: 下面命令很長(zhǎng),是一行,復(fù)制時(shí)不要有換行):

./configure --prefix=/usr/local/php --with-curl --with-freetype-dir --with-gd --with-gettext --with-iconv-dir --with-kerberos --with-libdir=lib64 --with-libxml-dir --with-mysqli --with-openssl --with-pcre-regex --with-pdo-mysql --with-pdo-sqlite --with-pear --with-png-dir --with-jpeg-dir --with-xmlrpc --with-xsl --with-zlib --with-bz2 --with-mhash --enable-fpm --enable-bcmath --enable-libxml --enable-inline-optimization --enable-mbregex --enable-mbstring --enable-opcache --enable-pcntl --enable-shmop --enable-soap --enable-sockets --enable-sysvsem --enable-sysvshm --enable-xml --enable-zip

一段時(shí)間后執(zhí)行編譯:

make

編譯 時(shí)間比較長(zhǎng),耐心等待,
后執(zhí)行安裝:

make install

安裝成功以后,接下來配置php-fpm:

cp php.ini-development /usr/local/php/lib/php.ini
cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
cp sapi/fpm/php-fpm /usr/local/bin
cp php.ini-production /etc/php.ini
cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

設(shè)置權(quán)限:

chmod +x /etc/init.d/php-fpm

配置環(huán)境變量:

vim /etc/profile

在末尾追加:

PATH=$PATH:/usr/local/php/bin
export PATH

執(zhí)行命令使得改動(dòng)立即生效:

source /etc/profile

創(chuàng)建web用戶及組(名稱自己定,這里假設(shè)是www-data):

groupadd www-data
useradd -g www-data www-data

配置nginx,不然無法識(shí)別PHP文件:
(根據(jù)你自己安裝nginx的目錄)

vim /usr/local/nginx/conf/nginx.conf 

需要修改的幾個(gè)點(diǎn):

1 : root 路徑是否修改,如果有需要改下
2 : 啟動(dòng)文件 添加index.php的支持
3 : 開啟PHP配置, 如果需要https,在server里也要設(shè)置:
4 : 假設(shè)把網(wǎng)頁(yè)存放路徑設(shè)置為/home/www
5: 第一行用戶改下
6 : HTTPS server : 這塊根據(jù)需要https配置,否則https下打開PHP文件就是直接下載了
7 : fastcgi_param SCRIPT_FILENAME 后面修改為網(wǎng)頁(yè)根路徑

設(shè)置完成的nginx.conf 應(yīng)該像下面這樣:

                                                                                                          
user  www-data;                                                                                        
worker_processes  1;                                                                                      
                                                                                                          
#error_log  logs/error.log;                                                                               
#error_log  logs/error.log  notice;                                                                       
#error_log  logs/error.log  info;                                                                         
                                                                                                          
#pid        logs/nginx.pid;                                                                               
                                                                                                          
       
events {
    worker_connections  1024;                                                                             
}                                                                                                         
                                                                                                          
                                                                                                          
http {                                                                                                    
    include       mime.types;                                                                             
    default_type  application/octet-stream;                                                               
                                                                                                          
    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                            
    #                  '$status $body_bytes_sent "$http_referer" '                                        
    #                  '"$http_user_agent" "$http_x_forwarded_for"';                                      
                                                                                                          
    #access_log  logs/access.log  main;                                                                   
                                                                                                          
    sendfile        on;                                                                                   
    #tcp_nopush     on;  
   #keepalive_timeout  0;                                                                                 
    keepalive_timeout  65;                                                                                 
                                                                                                           
    #gzip  on;                                                                                             
                                                                                                           
    server {                                                                                               
        listen       80;                                                                                   
        server_name  localhost;                                                                            
                                                                                                           
        #charset koi8-r;                                                                                   
                                                                                                           
        #access_log  logs/host.access.log  main;                                                           
                                                                                                           
        location / {                                                                                      
            root   /home/www;                                                                              
            index  index.html index.php index.htm;                                                         
        }                                                                                                  
                                                                                                           
        #error_page  404              /404.html;                                                           
                                                                                                           
        # redirect server error pages to the static page /50x.html                                         
        #                                                                                                  
        error_page   500 502 503 504  /50x.html;                                                          
        location = /50x.html {                                                                            
            root   /home/www;                                                                             
        }                                                                                                 

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80                                       
    #                  
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;                                                               
        #}                                                                                                
                                                                                                          
        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000                              
        #                                                                                                  
        location ~ \.php$ {                                                                               
            root           /home/www;                                                                      
            fastcgi_pass   127.0.0.1:9000;                                                                 
            fastcgi_index  index.php;                                                                      
            #fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;                           
                                                                                                           
                fastcgi_param  SCRIPT_FILENAME  /home/www/$fastcgi_script_name;                            
                include        fastcgi_params;                                                             
        #   include        fastcgi.conf;                                                                   
        }                                                                                                  
                          
        # deny access to .htaccess files, if Apache's document root                                        
        # concurs with nginx's one                                                                         
        #                                                                                                  
        #location ~ /\.ht {                                                                               
        #    deny  all;                                                                                   
        #}                                                                                                 
    }          

# another virtual host using mix of IP-, name-, and port-based configuration                          
    #                                                                                                     
    #server {                                                                                             
    #    listen       8000;                                                                               
    #    listen       somename:8080;                                                                      
    #    server_name  somename  alias  another.alias;                                                     

    #    location / {                                                                                     
    #        root   html;                                                                                 
    #        index  index.html index.htm;                                                                 
    #    }                                                                                                
    #}                                                                                                    


    # HTTPS server                                                                                        
    #                                                                                                     
    server {                                                                                              
        listen       443 ssl;                                                                             
        server_name  localhost;                                                                           
        ssl on;                                                                                           
        ssl_certificate      cert/1527654392270.pem;                                                      
        ssl_certificate_key  cert/1527654392270.key;                                                      
        root  /home/www;                                                                                  
    #    ssl_session_cache    shared:SSL:1m;                                                              
        ssl_session_timeout  5m;                                                                          

        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;          
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;   
ssl_prefer_server_ciphers on;                                                                           
                                                                                                            
    #    ssl_ciphers  HIGH:!aNULL:!MD5;                                                                     
    #    ssl_prefer_server_ciphers  on;                                                                     
                                                                                                            
        location / {                                                                                        
            root  /home/www;                                                                              
           index  index.html index.php index.htm;                                                         
        }                                                                                                 
   
       
        location ~ .*\.(php|php7)?$ {                                                                              
            root           /home/www;                                                                     
            fastcgi_pass   127.0.0.1:9000;                                                                
            fastcgi_index  index.php;                                                                     
            #fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;                          
            #                                                                                             

                fastcgi_param  HTTPS   on;                                                                
                fastcgi_param  SCRIPT_FILENAME  /home/www/$fastcgi_script_name;                           
                include        fastcgi_params;                                                                              
                                                                                                          

          }                                                                                               
    }                                                                                                     


}                                                                                                         

配置完成以后:
啟動(dòng)php-fpm:

/etc/init.d/php-fpm start

如果已經(jīng)啟動(dòng),報(bào)錯(cuò)的話,需要?dú)⒌暨M(jìn)程再執(zhí)行:
unable to bind listening socket for address '127.0.0.1:9000': Address already in use (98)

查看進(jìn)程():

netstat -nldp |grep 9000

返回信息:
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 20016/php-fpm: mast

殺掉進(jìn)程():

kill 20016

再次啟動(dòng)(成功返回done):

/etc/init.d/php-fpm start

添加啟動(dòng)項(xiàng):

chkconfig --add php-fpm

開啟3,4,5:

chkconfig php-fpm --level 345 on

重新啟動(dòng)php-fpm:

service php-fpm restart

重新啟動(dòng)nginx (如果失敗往下走):

service nginx restart

重新啟動(dòng)nginx

如果沒有配置的上面命令執(zhí)行會(huì)失敗,使用下面安裝路徑啟動(dòng):
/usr/local/nginx/sbin/nginx -s reload

到此差不多完成,最后一步:添加測(cè)試文件
用ftp在網(wǎng)站根路徑下添加test.php
/home/www/test.php

文件信息:

<?php
phpinfo();
?>

然后再網(wǎng)站打開鏈接:
http://xxxxxxx/test.php
或者
https://xxxxxxx/test.php

圖片.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,646評(píng)論 6 533
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,595評(píng)論 3 418
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,560評(píng)論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,035評(píng)論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,814評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,224評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,301評(píng)論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,444評(píng)論 0 288
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,988評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,804評(píng)論 3 355
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,998評(píng)論 1 370
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,544評(píng)論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,237評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,665評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,927評(píng)論 1 287
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,706評(píng)論 3 393
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,993評(píng)論 2 374