PHP是以fastcgi的方式结合Nginx的,能够理解为Nginx代理了PHP的fastcgi和LAMP不一样的是,LNMP中提供web服务的是Nginxjavascript
在LNMP架构中PHP是做为一个独立的服务存在的,这个服务叫作php-fpmphp
Nginx直接处理静态请求(支持的并发更高,速度比Apache快),动态请求转发给php-fpm处理css
cd /usr/local/srchtml
wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gzjava
tar zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gznode
mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysqlmysql
cd /usr/local/mysqllinux
useradd -s /sbin/nologin mysqlnginx
mkdir -p /data/mysql #建立数据库目录,这个是数据库哟web
chown -R mysql:mysql /data/mysql
./scripts/mysql_install_db --user=mysql --datadir=/data/mysql #初始化指定用户和数据库目录
cp support-files/my-default.cnf /etc/my.cnf #拷贝配置文件并配置
vim /etc/my.cnf datadir=/data/mysql socket=/tmp/mysql.sock
cp support-files/mysql.server /etc/init.d/mysqld 将启动脚本添加到系统配置文件中
chmod 755 /etc/init.d/mysqld
vim /etc/init.d/mysqld basedir=/usr/local/mysql datadir=/data/mysql 设定开机启动MySQL: chkconfig --add mysqld chkconfig mysqld on 开机: service mysqld start /etc/init.d/mysqld start
PHP是以fastcgi的方式结合Nginx的,能够理解为Nginx代理了PHP的fastcgi和LAMP不一样的是,LNMP中提供web服务的是Nginx
php的安装有部分不一样须要注意:须要开启php-fpm服务
cd /usr/local/src/
wget http://cn2.php.net/distributions/php-5.6.30.tar.gz (下载源码包)
tar zxvf php-5.6.30.tar.gz
useradd -s /sbin/nologin php-fpm
(该帐号用来运行php-fpm服务,由于在LNMP环境中,PHP是以一种服务的形式独立存在的)
##进行编译准备前准备生产makefile cd 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 --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 --enable-fpm关键模块若是不加不会有php-fpm执行文件生成 mysql相关模块:若是mysql不在同一台机器上也要指定模块,或者直接安装mysql不启动 这里缺乏不少包须要依次安装后再make&&make install,基本上包含以下: yum install -y gcc yum install -y libxml2-devel yum install -y openssl-devel yum install -y libjpeg-turbo-devel yum list|grep libjpeg yum install -y libjpeg-turbo-devel yum list|grep png yum install -y libpng-devel yum install -y freetype-devel epel扩展源yum install -y epel-release yum install -y libmcrypt-deve make && make install 编译和安装 若是是小内存安装,加上--disable-fileinfo能够顺利安装
php-fpm相关命令:
/usr/local/php-fpm/bin/php -m 查看php开启的程序
/usr/local/php-fpm/sbin/php-fpm -t 测试是否正确
将配置文件添加到php-fpm文件目录cp php.ini-production /usr/local/php-fpm/etc/php.ini
vim /usr/local/php-fpm/etc/php-fpm.conf ###php-fpm主配置文件☆☆☆ [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 = 127.0.0.1::9000,本地监听,也能够监听其余IP:port #此处格式会影响配置Nginx和PHP结合时Nginx寻址PHP的路径 listen.mode = 666 #当监听的为socket文件时该部分才生效,用于指定.sock文件的权限 user = php-fpm group = php-fpm #定义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 = 1024 #以上部分为进程相关信息 ###配置完记得-t检测是否正确
配置启动脚本
cd /usr/local/src/php-5.6.30
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm 添加启动脚本到系统配置
chmod 755 /etc/init.d/php-fpm 更改文件权限
service php-fpm start
chkconfig --add php-fpm 添加到系统服务
chkconfig php-fpm on 开机启动
cd /usr/local/src
wget http://nginx.org/download/nginx-1.12.1.tar.gz
tar zxf nginx-1.12.1.tar.gz
cd nginx-1.12.1
./configure --prefix=/usr/local/nginx ##能够添加模块,按需求进行配置,https等后加
make && make install
vim /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
/usr/local/nginx/sbin/nginx -t #检查错误
chmod 755 /etc/init.d/nginx #更改文件权限
chkconfig --add nginx #加入系统服务再设置开机启动
chkconfig nginx on
cd /usr/local/nginx/conf/
mv nginx.conf nginx.conf.bak
vim /usr/local/nginx/conf/nginx.conf user nobody nobody; #定义启动nginx的用户 worker_processes 2; #定义子进程数目 error_log /usr/local/nginx/logs/nginx_error.log crit; pid /usr/local/nginx/logs/nginx.pid; worker_rlimit_nofile 51200; #指定Nginx最多可打开的文件数目 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; } } }
/usr/local/nginx/sbin/nginx -t #检查错误
/etc/init.d/nginx start #启动
测试php解析是否正常:
vim /usr/local/nginx/html/666.php <?php echo "这里随便写,35天仍是放弃了该如何是好呢"; curl localhost/666.php显示上面的语句表示成功
lnmp最多见为502问题环境搭建完成后,一访问网站直接提示“502 Bad Gateway”缘由大体两种:
其一配置错误
在Nginx配置中location的php配置中,若是把fastcgi_pass(这是用来通讯的)后面指定的路径配置错了,那么就会出现502错误,由于Nginx找不到php-fpm了,fastcgi _pass后面能够跟socket也能够跟IP+port,默认监听地址为:127.0.0.1:9000。
注意: 这里用两种形式均可以,可是两个配置文件(Nginx和php-fpm)中的形式必定要统一,否则绝对502;若是用套接字形式的话,socket文件的路径必定要对,否则也仍是502
其二资源耗尽
lnmp架构处理PHP时,是Nginx直接调取后端的php-fpm服务,若是Nginx的请求量偏高,而咱们又没给php-fpm配置足够的子进程数,那么总有php-fpm资源耗尽的时候,一旦耗尽Nginx找不到php-fpm,此时也会致使502错误出现。解决办法就是调整php-fpm.conf中的pm.max_children数值,使其增长。但也不能无限制增长,由于服务器的资源有限。4G内存机器若是只跑php-fpm和Nginx,不跑MySQL服务,pm.max _children能够设置为150,尽可能不要超过该数值,8G内存设置为300,以此类推。
其上未解决呢
在配置文件/usr/local/nginx/conf/nginx.conf中将crit改成debug,使其记录最多的日志内容,这样方便咱们排查错误,可是配置更改完成后要记得将级别改回crit,避免日志文件占用太多磁盘空间。