linux复盘:构架搭建lnmp(安装)

lnmp构架介绍

PHP是以fastcgi的方式结合Nginx的,可以理解为Nginx代理了PHP的fastcgi和LAMP不同的是,LNMP中提供web服务的是Nginx

在LNMP架构中PHP是作为一个独立的服务存在的,这个服务叫做php-fpm

Nginx直接处理静态请求(支持的并发更高,速度比Apache快),动态请求转发给php-fpm处理

mysql安装

cd /usr/local/src

wget http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

tar zxvf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

mv mysql-5.6.35-linux-glibc2.5-x86_64 /usr/local/mysql

cd /usr/local/mysql

useradd -s /sbin/nologin mysql

mkdir -p /data/mysql #创建数据库目录,这个是数据库哟

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安装

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 开机启动

nginx安装

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

创建nginx启动脚本

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

更改nginx配置文件

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,避免日志文件占用太多磁盘空间。

 

转载于:https://my.oschina.net/u/3655649/blog/1611561

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值