LNMP就是Linux+Nginx+MySQL+PHP,Linux做爲服務器的操做系統,MySQL即爲數據庫,Nginx爲一款高性能Web服務器,自己是不能處理PHP的,當接收到請求時,判斷若是是PHP請求就會將請求交給PHP解釋器處理,而後將結果返回給Client。Nginx通常把請求轉發給fast-cgi管理進程處理,fast-cgi管理進程再選擇cgi子進程處理請求,而後把結果返給Nginx。
Apache+PHP 和 Nginx+PHP的區別
Apache通常是把PHP當作本身的一個模塊來啓動;和LAMP不一樣的是,提供web服務的是Nginx,而且php是做爲一個獨立服務存在的,這個服務叫作php-fpm,Nginx直接處理靜態請求,動態請求會轉發給php-fpm,而Ngnix則是把http請求變量轉發給PHP進程,即PHP獨立進程,與Ngnix通訊,這種方式叫作Fast-CGI運行方式。因此Apache所編譯的PHP不能用於Nginx。
Nginx+PHP的基本結構圖以下:
javascript
一、安裝前準備
##建立用戶php
[root@localhost ~]#useradd -s /sbin/nologin mysql [root@localhost ~]# id mysql uid=1000(mysql) gid=1000(mysql) 組=1000(mysql)
##建立數據目錄。css
[root@localhost ~]mkdir -p /data/mysql [root@localhost ~]chown -R mysql.mysql /data/mysql [root@localhost ~]ll -d /data/mysql/ drwxr-xr-x 2 mysql mysql 6 6月 25 11:29 /data/mysql/
##安裝mysql所需依賴包html
[root@localhost ~]yum install -y gcc gcc-c++ make cmake ncurses-devel bison-devel autoconf libtool libXpm-devel libvpx-devel gmp-devel
注:若是缺乏這些依賴包,編譯過程會保錯,源碼安裝大部分報錯爲缺乏依賴包的引發的
二、安裝mysql
方式1:源碼編譯安裝MySQLjava
#進入軟件源碼存放目錄 [root@localhost ~]cd /usr/local/src/ #下載源碼包 [root@localhost src]wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.36.tar.gz #解壓源碼包 [root@localhost src]tar xvf mysql-5.6.36.tar.gz #進入解壓後的源碼目錄 [root@localhost src]cd mysql-5.6.36 #設置安裝參數,cmake至關於configure ##下面的反斜槓是脫義字符,加上它咱們能夠把一行命令寫成多行 [root@localhost ~]cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ \ #指定mysql安裝目錄 -DMYSQL_DATADIR=/data/mysql \ #指定數據存放的目錄 -DSYSCONFDIR=/etc/ \ #指定配置文件所在目錄 -DWITH_MYISAM_STORAGE_ENGINE=1 \ #安裝啓用myisam引擎支持 -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安裝啓用innodb引擎支持 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ #指定本地sock文件 -DMYSQL_TCP_PORT=3306 \ #指定TCP端口爲3306 -DENABLED_LOCAL_INFILE=1 \ #啓用本地數據導入支持 -DWITH_PARTITION_STORAGE_ENGINE=1 \ #安裝數據庫分區 -DEXTRA_CHARSETS=all \ #啓用額外的字符集類型(默認爲all) -DDEFAULT_CHARSET=utf8 \ #指定默認的字符集爲utf8 -DDEFAULT_COLLATION=utf8_general_ci #設定默認排序規則(utf8_general_ci快速/utf8_unicode_ci準確) 此處省略cmake過程 [root@localhost mysql-5.6.36]echo $? ##檢查是否有錯誤。 0 [root@localhost mysql-5.6.36]make && make install #編譯 && 安裝 ... 省略編譯安裝的過程 [root@localhost mysql-5.6.36]# echo $? ##再次檢查安裝是否有錯誤。若是是0就表示安裝沒問題。 0
方式2:二進制包安裝MySQL
源代碼方式和二進制包是軟件包的兩種形式。二進制包裏面包括了已經通過編譯,能夠立刻運行的程 序。你只須要下載和解包(安裝)它們之後,就立刻可使用。源代碼包裏面包括了程序原始的程序代碼,須要在你的計算機上進行編譯之後才能夠產生能夠運行程 序,因此從源代碼安裝的時間會比較長node
#進入軟件源碼存放目錄 [root@localhost ~]cd /usr/local/src/ #下載二進制包 [root@localhost src]wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.36-linux-glibc2.5-x86_64.tar.gz #解壓二進制包 [root@localhost src]tar xvf mysql-5.6.36-linux-glibc2.5-x86_64.tar.gz #將解壓好的目錄移動到/usr/local/目錄下重命名爲mysql [root@localhost src]mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql #進入/usr/local/mysql目錄 [root@localhost src]cd /usr/local/mysql ###到此安裝成功
三、初始化配置mysql
#初始化數據庫 [root@localhost ~]cd /usr/local/mysql/ [root@localhost mysql]./scripts/mysql_install_db --user=mysql --datadir=/data/mysql/ --basedir=/usr/local/mysql #備份初始配置文件 [root@localhost mysql]cp /etc/my.cnf /etc/my.cnf.bak #清空配置文件 [root@localhost mysql]echo > /etc/my.cnf #編輯配置文件寫入下面的內容後保存退出 [root@localhost mysql]vim /etc/my.cnf ################################### [mysqld] port = 3306 basedir=/usr/local/mysql datadir=/data/mysql/ socket=/tmp/mysql.sock user=mysql default-time-zone=system default-storage-engine=InnoDB log-error=/var/log/mysqld.log sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES ################################### ##將mysql啓動腳本放入/etc/init.d/目錄中重命名爲mysqld [root@localhost ~]cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld ##編輯啓動腳本 [root@localhost mysql]# vi /etc/init.d/mysqld 把下面兩個修改一下,否則啓動會報錯 basedir=/user/local/mysql #修改爲mysql的安裝目錄 datadir=/data/mysql #修改爲mysql的數據目錄 ##將mysql啓動腳本加入chkconfig管理 [root@localhost ~]# chkconfig --add mysqld ##設置mysql開機自啓動 [root@localhost ~]# chkconfig mysqld on
和LAMP安裝PHP方法有差異,須要開啓php-fpm服務
一、下載、解壓源碼包linux
[root@localhost ~]# cd /usr/local/src/ [root@localhost src]# wget http://mirrors.sohu.com/php/php-5.6.30.tar.gz [root@localhost src]# tar zxf php-5.6.30.tar.gz
二、編譯安裝PHPnginx
#先建立php-fpm用戶c++
[root@localhost src]# useradd -s /sbin/nologin php-fpm
#安裝依賴包
[root@localhost src]# yum -y install gcc libcurl-devel libxml2-devel openssl-devel bzip2-devel libjpeg-devel libpng-devel freetype-devel libmcrypt-devel
#建立配置文件目錄
[root@localhost src]# mkdir -p /usr/local/php-fpm/etc
#configure設置安裝參數
[root@localhost src]# cd php-5.6.30 [root@localhost php-5.6.30]# ./configure --prefix=/usr/local/php-fpm \ --with-config-file-path=/usr/local/php-fpm/etc \ --enable-fpm \ --with-fpm-user=php-fpm \ --with-fpm-group=php-fpm \ --with-mysql=/usr/local/mysql \ --with-mysqli=/usr/local/mysql/bin/mysql_config \ --with-pdo-mysql=/usr/local/mysql \ --with-mysql-sock=/tmp/mysql.sock \ --enable-mysqlnd \ --with-libxml-dir \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-freetype-dir \ --with-iconv-dir \ --with-zlib-dir \ --with-mcrypt \ --enable-soap \ --enable-gd-native-ttf \ --enable-ftp \ --enable-mbstring \ --enable-exif \ --with-pear \ --with-curl \ --with-openssl
#編譯、安裝
[root@localhost php-5.6.30]# make && make install
#檢查是否出錯
[root@localhost php-5.6.30]# echo $? 0
#參數說明:
--prefix=/usr/local/php-fpm #設定安裝目錄 --with-config-file-path=/usr/local/php-fpm/etc #誰定php-fpm配置文件所在目錄 --enable-fpm #開啓php-fpm模式 --with-fpm-user=php-fpm #設定php-fpm服務的用戶 --with-fpm-group=php-fpm #設定php-fpm服務的用戶組 --with-mysql=/usr/local/mysql #設定mysql庫,這種方式基本已經廢棄 --with-mysqli=/usr/local/mysql/bin/mysql_config #最新的mysqli鏈接庫 --with-pdo-mysql=/usr/local/mysql #mysqli鏈接庫 --with-mysql-sock=/tmp/mysql.sock #指定mysql.sock文件路徑 #其餘參數都和LAMP相同
#複製初始配置文件到configure指定的配置文件存放目錄下更名爲php.ini
[root@localhost php-5.6.30]# cp php.ini-production /usr/local/php-fpm/etc/php.ini
#配置/usr/local/php-fpm/etc/php-fpm.conf配置文件
[root@localhost php-5.6.30]# vi /usr/local/php-fpm/etc/php-fpm.conf #寫入下面的內容,保存 [global] pid = /usr/local/php-fpm/var/run/php-fpm.pid error_log = /usr/local/php-fpm/var/log/php-fpm.log [www] listen = /tmp/php-fcgi.sock listen.mode = 666 user = php-fpm group = php-fpm pm = dynamic pm.max_children = 50 pm.start_servers = 20 pm.min_spare_servers = 5 pm.max_spare_servers = 35 pm.max_requests = 500 rlimit_files = 65535
#複製啓動腳本到/etc/init.d/目錄下重命名爲php-fpm
[root@localhost php-5.6.30]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
#修改/etc/init.d/php-fpm文件的權限
[root@localhost php-5.6.30]# chmod 755 /etc/init.d/php-fpm
#加入chkconfig管理
[root@localhost php-5.6.30]# chkconfig --add php-fpm
#設置開機啓動
[root@localhost php-5.6.30]# chkconfig php-fpm on
#啓動php-fpm服務
[root@localhost php-5.6.30]# service php-fpm start
#查看php-fpm服務進程是否正常開啓。
[root@localhost php-5.6.30]# ps aux |grep php-fpm
Nginx官網:nginx.org
Nginx應用場景:web服務、反向代理、負載均衡
Nginx著名分支,淘寶基於Nginx開發的Tengine,使用上和Nginx一致,服務名,配置文件名都同樣,
和Nginx的最大區別在於Tenging增長了一些定製化模塊,在安全限速方面表現突出,另外它支持對js,css合併
Nginx核心+lua相關的組件和模塊組成了一個支持lua的高性能web容器openresty 參考連接
#下載、解壓源碼包
[root@localhost ~]# cd /usr/local/src [root@localhost src]# wget http://mirrors.sohu.com/nginx/nginx-1.12.1.tar.gz [root@localhost src]# tar zxf nginx-1.12.1.tar.gz
#配置參數、編譯、安裝
[root@localhost src]# cd nginx-1.12.1 [root@localhost nginx-1.12.1]# ./configure --prefix=/usr/local/nginx
#編譯、安裝
[root@localhost nginx-1.12.1]# make && make install
#檢查是否出錯
[root@localhost nginx-1.12.1]# echo $? 0
#編輯nginx啓動腳本
[root@localhost nginx-1.12.1]# vi /etc/init.d/nginx #寫入如下內容 #!/bin/bash # chkconfig: - 30 21 # description: http service. # Source Function Library . /etc/init.d/functions # Nginx Settings NGINX_SBIN="/usr/local/nginx/sbin/nginx" NGINX_CONF="/usr/local/nginx/conf/nginx.conf" NGINX_PID="/usr/local/nginx/logs/nginx.pid" RETVAL=0 prog="Nginx" start() { echo -n $"Starting $prog: " mkdir -p /dev/shm/nginx_temp daemon $NGINX_SBIN -c $NGINX_CONF RETVAL=$? echo return $RETVAL } stop() { echo -n $"Stopping $prog: " killproc -p $NGINX_PID $NGINX_SBIN -TERM rm -rf /dev/shm/nginx_temp RETVAL=$? echo return $RETVAL } reload() { echo -n $"Reloading $prog: " killproc -p $NGINX_PID $NGINX_SBIN -HUP RETVAL=$? echo return $RETVAL } restart() { stop start } configtest() { $NGINX_SBIN -c $NGINX_CONF -t return 0 } case "$1" in start) start ;; stop) stop ;; reload) reload ;; restart) restart ;; configtest) configtest ;; *) echo $"Usage: $0 {start|stop|reload|restart|configtest}" RETVAL=1 esac exit $RETVAL
#修改腳本權限並加入開機啓動
[root@localhost nginx-1.12.1]# chmod 755 /etc/init.d/nginx [root@localhost nginx-1.12.1]# chkconfig --add nginx [root@localhost nginx-1.12.1]# chkconfig nginx on [root@localhost nginx-1.12.1]# cd /usr/local/nginx/conf/; mv nginx.conf nginx.conf.bak
#修改nginx配置文件
[root@localhost conf]# vi nginx.conf #寫入下面的內容 user nobody nobody; worker_processes 2; error_log /usr/local/nginx/logs/nginx_error.log crit; pid /usr/local/nginx/logs/nginx.pid; worker_rlimit_nofile 51200; events { use epoll; worker_connections 6000; } http { include mime.types; default_type application/octet-stream; server_names_hash_bucket_size 3526; server_names_hash_max_size 4096; log_format combined_realip '$remote_addr $http_x_forwarded_for [$time_local]' ' $host "$request_uri" $status' ' "$http_referer" "$http_user_agent"'; sendfile on; tcp_nopush on; keepalive_timeout 30; client_header_timeout 3m; client_body_timeout 3m; send_timeout 3m; connection_pool_size 256; client_header_buffer_size 1k; large_client_header_buffers 8 4k; request_pool_size 4k; output_buffers 4 32k; postpone_output 1460; client_max_body_size 10m; client_body_buffer_size 256k; client_body_temp_path /usr/local/nginx/client_body_temp; proxy_temp_path /usr/local/nginx/proxy_temp; fastcgi_temp_path /usr/local/nginx/fastcgi_temp; fastcgi_intercept_errors on; tcp_nodelay on; gzip on; gzip_min_length 1k; gzip_buffers 4 8k; gzip_comp_level 5; gzip_http_version 1.1; gzip_types text/plain application/x-javascript text/css text/htm application/xml; server { listen 80; server_name localhost; index index.html index.htm index.php; root /usr/local/nginx/html; location ~ \.php$ { include fastcgi_params; fastcgi_pass unix:/tmp/php-fcgi.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name; } } }
nginx.conf配置文件詳解:【參考連接】
#檢查配置文件是否有錯誤
[root@localhost conf]# /usr/local/nginx/sbin/nginx -t
#啓動nginx服務
[root@localhost conf]# /etc/init.d/nginx start
#檢查80端口是否開始監聽
[root@localhost conf]# netstat -lntp |grep 80
#防火牆容許80端口訪問
[root@localhost conf]# firewall-cmd --add-port=80/tcp --permanent [root@localhost conf]# firewall-cmd --reload
擴展
Nginx爲何比Httpd高效:原理篇 http://www.toxingwang.com/linux-unix/linux-basic/1712.html
mod_php 和 mod_fastcgi以及php-fpm的比較 http://dwz.cn/1lwMSd
概念瞭解:CGI,FastCGI,PHP-CGI與PHP-FPM http://www.nowamagic.net/librarys/veda/detail/1319/ https://www.awaimai.com/371.html