LNMP架构 (Ⅰ)

1.LNMP架构介绍

上一课学习了LAMP架构,现在流行LNMP架构;他们的区别就是提供web服务为apache和nginx,目前nginx发展迅速,取代apache指日可待。

  • LAMP=linux+apache+mysql+php
  • LNMP=linux+nginx+mysql+php

当我们讲LAMP的时候PHP是作为一个模块在Apache中,但是在LNMP中,PHP是一个服务,当用户请求的时候nginx会把它交给php 然后对mysql进行交互!像这种静态的,例如图片或者html,nginx会直接处理,从而加快访问速度! 谈到速度,其实如果一个普通的站点你是看不到什么效果的,但是如果要是访问一个纯静态站点,nginx就能体现出它的优势!nginx的另外一个优势得益于它的高并发支持!

和LAMP不同的是,提供web服务的是Nginx 并且php是作为一个独立服务存在的,这个服务叫做php-fpm Nginx直接处理静态请求,动态请求会转发给php-fpm

2.MySQL安装

1).我们首先进入/usr/local/src/目录下面去去下载mysql的安装包

wget http://mirrors.163.com/mysql/Downloads/MySQL-5.6/mysql-5.6.39-linux-glibc2.12-x86_64.tar.gz

2).下载好之后进行解压缩并移动到/usr/local/mysql 并命名为mysql

9eefedef8585cb5f8bf6059dad6972150df.jpg

3).创建一个mysql用户和data目录

c448620073a235750167f49c3d5c2acefde.jpg

4).初始化

 ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql

0a26455506be2ee31b346bd690ad6e6b2b5.jpg90b252fda9c5b915ed061197edeb4b98546.jpg

初始化完成的时候要进行检测一下初始化有没有成功

5).配置文件

1012874043108aaed909d299eefe0778882.jpg6a468e7b2d5ad72cc8810c57b3334304dea.jpg

6).编辑启动脚本

cp support-files/mysql.server /etc/init.d/mysqld     //把mysql.server复制到mysqld这个新目录

3211be2ea18f9b349e5d3da253417688a0d.jpg

7).启动脚本

4c55e976f81aa86fded5e1b53dbec30a8d2.jpg

8).增加到系统服务列表中让其开机自动启动

b116f2cc09e9023012cebb85194f7b32721.jpg

9).mysql服务启动和关闭

启动:service mysqld start
     /etc/init.d/mysqld start
/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf --user=mysql --datadir=/data/mysql/
             --defaults-file=/etc/my.cnf 定义默认的配置文件
             --user=mysql 定义用户
             --datadir=/data/mysql/ 定义数据目录
关闭:service mysqld stop
     /etc/init.d/stop

在开启服务的时候看看防火墙有没有关闭防火墙可能会影响服务的开启

316ce4a78a0ccb1d360428d4c571527d1e8.jpg

2.PHP安装

LNMP安装PHP和LAMP不是完全一样,先对PHP的压缩包进行解压

dd272cd4b48be8f1065a7d86063d94d321a.jpg

1).编译和安装

./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
  • --prefix=指定安装位置
  • --with-config-file-path=指定配置文件目录
  • --enable-fpm=启动fpm服务
  • --with-fpm-user=指定用户
  • --with-fpm-group=指定用户组
  • --with-mysql=指定mysql的路径

9be02031d676fb69959c097b58f354eccbc.jpg

make
make install

完成每一步最好都要验证一下是否成功 echo $?

 

2).PHP相关信息

1087f251bd0f8ba3b8ad8660548d81a52a4.jpg

安装下来之后我们发现其实比之前安装PHP要多了两个目录 sbin 和 var

  • sbin:实际上就是启动php-fpm服务的目录
  • var:实际上就是存放PHP日志的,当然这个我们可以指定的
    • log: php日志目录;
    • run:进程PID目录

1).php-fpm 选项参数用法:-i -m -t

/usr/local/php-fpm/sbin/php-fpm -i  //查看PHP信息
/usr/local/php-fpm/sbin/php-fpm -m  //查看PHP模块
/usr/local/php-fpm/sbin/php-fpm -t  //测试PHP配置语法

786ebe15151dfa30cdeb07d3ef663f1131d.jpgbe912c6f802e83a597b7cb7a94a384e379b.jpg

2).PHP配置

51840cbc11fe0a370d707029f2d8085404b.jpg7f68c565c410b8ab8d8924b93930db302ee.jpg

新建一个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 = 1024
  • [global]=定义全局参数
  • [www]=自定义模块
  • listen = 监听的地址
  • 或者可以使用这样的方式↓
  • listen = 127.0.0.1:9000 (port默认为9000,也可以更改)
  • listen.mode = 666 用来定义listen = /tmp/php-fcgi.sock的权限,只有这个sock打开的情况下才生效

ed24c53f5d3bedeb96372d7b9d9239f3318.jpg

把启动脚本放到/etc/init.d/下面去

cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

给/etc/init.d/php-fpm755权限

4e39e97e5fcac8645a770468dcac36a62e1.jpg

增加开机自动启动使用chkconfig 并启动php

0742ddcdb2665acff430170ed211f2b02e9.jpg

3.Nginx介绍和安装

1).下载配置安装Nginx,并解压

 wget http://nginx.org/download/nginx-1.4.7.tar.gz

6b39fad474c1d8b180ba21ba0b22d75aa85.jpg

2).进行初始化编译安装

 ./configure --prefix=/usr/local/nginx
  make
  make install

9c91579db4815cb6a4ba05a5f43a67d9d00.jpg

3).nginx相关目录信息

f08801045e3ef6e4a8c2d85478fa9e8b54a.jpg

confnginx配置文件
html主页样例文件
logs站点日志
sbin核心进程文件

 4).nginx配置

在init.d目录下,新建nginx脚本文件

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

增加权限让开机自动启动

0ff3e36882107443dad6ce6178abd8cb3db.jpg

进入nginx/conf/目录下,把默认的配置文件作为备份并创建一个新的文件

1f56681926dbce797de53ddb06c90c83da1.jpg

新增的文件内容如下

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;
        }    
    }
}
  • user nobody nobody; 运行服务的用户是谁
  • worker_processes 2;定义子进程的数量
  • worker_rlimit_nofile
  • 51200;最多可以打开多少个文件
  • worker_connections 6000;允许最大的连接数
  • server; 下面对应的就是虚拟主机配置
  • server_name localhost;定义网站的域名
  • root /usr/local/nginx/html;定义网站的根目录
  • location ~ .php$;配置解析PHP
  • fastcgi_pass unix:/tmp/php-fcgi.sock;监听端口或者监听socket,通过此命令去执行
  • fastcgi_pass 127.0.0.1:9000;(或者携程这种方式,服务器IP地址+端口)

编辑好配置文件检查一下有没有错

12556b8ab21d8ee82550b0d086cce943eec.jpg

启动nginx服务

5da4868686588807435599cccd3624cbf2a.jpg

使用curl localhost进行测试

48d18b803b82ed0a543994e9b1dc8a49542.jpg

测试解析PHP功能

382e2a375218900e35b3318c7b62db81cd4.jpg

转载于:https://my.oschina.net/u/4000361/blog/2983311

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值