day38——LNMP架构

LNMP架构

1.什么是LNMP架构?

LNMP架构就是:Linux+Nginx+Mysql+PHP


2.LNMP是如何工作的

nginx服务是不能处理动态请求的,只能其他软件

nginx服务是不能处理动态请求的,所以当用户发起动态请求时,nginx又是如何进行处理的?

当用户发起http请求时,请求会被nginx处理,如果是静态资源请求nginx则直接返回,如果是动态请求nginx则通过fastcgi协议转交给后端的PHP程序处理。

nginx与php的工作原理.png

3.Nginx与PHP MySQL之间如何工作的

nginx与php与mysql如何工作.png

4.安装

4.1配置官方PHP源

[root@web01 ~]# cat /etc/yum.repos.d/php.repo 
[webtatic-php]
name = php Repository
baseurl = http://us-east.repo.webtatic.com/yum/el7/x86_64/
gpgcheck = 0

4.2安装nginx php mariadb

#安装nginx
yum install nginx -y
#移除旧版本的PHP
yum remove php-mysql-5.4 php php-fpm php-common
#安装新版7.1PHP
yum -y install php71w php71w-cli php71w-common php71w-devel php71w-embedded php71w-gd php71w-mcrypt php71w-mbstring php71w-pdo php71w-xml php71w-fpm php71w-mysqlnd php71w-opcache php71w-pecl-memcached php71w-pecl-redis php71w-pecl-mongodb
#安装数据库mariadb
yum install mariadb mariadb-server -y

4.3启动

systemctl start nginx
systemctl enable nginx
systemctl start php-fpm
systemctl enable php-fpm
systemctl start mariadb
systemctl enable mariadb

5.Nginx与PHP集成的原理

5.1编写能解析PHP的Nginx配置文件

[root@web01 conf.d]# cat php.oldxu.com.conf 
server {
    listen 80;
    server_name php.oldxu.com;
    root /code;

    location / {
        index index.php;
    } 

    location ~ \.php$ {
        #php-fpm服务的指定端口和ip
        fastcgi_pass 127.0.0.1:9000;    #连接php,通过9000端口
        #模块,固定的变量,访问资源所在的目录root后面,访问时指向的路径
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        #其余的模块都在/etc/nginx/fastcgi_params下,直接包含引用
        include fastcgi_params;   
    }
}

5.2编写PHP代码,测试访问效果

[root@web01 conf.d]# cat /code/info.php

5.3本地劫持


6.PHP与MySQL集成的原理

6.1启动数据库

[root@web01 ~]# yum install mariadb     #安装
[root@web01 ~]# systemctl start mariadb   #启动
[root@web01 ~]# systemctl enable mariadb    #开机自启

6.2创建数据库密码

#创建数据库密码,默认数据库用户名是root
[root@web01 ~]# mysqladmin password oldxu.com

6.3测试登录mysql

[root@web01 ~]# mysql -uroot -poldxu.com
MariaDB [(none)]>

6.4编写php连接数据库的代码

[root@web01 ~]# /code/mysqli.php

6.5直接使用php命令测试

或者使用刚才编写的域名浏览器测试,但必须要本地劫持了才行

[root@web01 ~]# php /code/mysqli.php

7.部署真实的PHP软件wordpress...

7.1编写Nginx集成PHP的配置文件

1.编写Nginx集成PHP的配置文件  (定义域名以及站点的目录位置)
[root@web01 conf.d]# cat blog.oldxu.com.conf 
server {
    listen 80;
    server_name blog.oldxu.com;
    root /code/wordpress;

    location / {
        index index.php;
    }

    location ~ \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

7.2根据Nginx配置,初始化环境,然后上传代码

2.根据Nginx配置,初始化环境,然后上传代码
 2.1准备站点目录
[root@web01 conf.d]# mkdir /code

 2.2下载wordpress代码
[root@web01 conf.d]# cd /code
[root@web01 code]# tar xf wordpress-5.2.3-zh_CN.tar.gz

7.3配置host本地劫持

C:\Windows\System32\drivers\etc\hosts ---> blog.oldxu.com

真实的域名不需要劫持

通过域名访问

7.4创建数据库

在浏览器,通过劫持的域名blog.oldxu.com访问,到安装界面,选择数据库

3.创建数据库名
[root@web01 code]# mysql -uroot -poldxu.com
    
MariaDB [(none)]> create database wordpress;
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
| wordpress          |
+--------------------+
5 rows in set (0.01 sec)

7.5统一nginx php权限

不统一权限,会出现安装失败

4.统一Nginx  PHP的权限  为  www
[root@web01 code]# groupadd www -g 666
[root@web01 code]# useradd -u666 -g666 www
    
[root@web01 code]# sed -i '/^user/c user www;' /etc/nginx/nginx.conf
[root@web01 code]# chown -R www.www /code
[root@web01 code]# systemctl restart nginx
    
[root@web01 code]# sed -i '/^user/c user = www' /etc/php-fpm.d/www.conf 
[root@web01 code]#  sed -i '/^group/c group = www' /etc/php-fpm.d/www.conf
[root@web01 code]# systemctl restart php-fpm

8.安装wecenter知乎

1.编写Nginx的配置文件       虚拟主机
[root@web01 conf.d]# cat zh.oldxu.com.conf 
server {
    listen  80;
    server_name zh.oldxu.com;
    root /code/zh;

    client_max_body_size 100m;      #设置上传的大小

    location / {
        index index.php;
    }

    location ~ \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}

2.上传代码,变更代码的属主和属组
[root@web01 conf.d]# cd /code
[root@web01 conf.d]# rz WeCenter_3-3-2.zip
[root@web01 conf.d]# mkdir zh
[root@web01 conf.d]# unzip WeCenter_3-3-2.zip  -d /code/zh/
[root@web01 code]# chown -R www.www /code


3.登录数据库.创建库名称
[root@web01 code]# mysql -uroot -poldxu.com

MariaDB [(none)]> create database zh;
MariaDB [(none)]> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
| wordpress          |
| zh                 |
+--------------------+
6 rows in set (0.00 sec)


3.重启Nginx服务
[root@web01 code]# systemctl restart nginx

4.配置host劫持

9.常见的nginx+php配置

server {
    listen 80;
    server_name www.xxxx.com;
    root /code/edusoho/web;

    # 日志路径
    access_log /var/log/nginx/example.com.access.log;
    error_log /var/log/nginx/example.com.error.log;

    location / {
        index app.php;
        try_files $uri @rewriteapp;
    }

    location @rewriteapp {
        rewrite ^(.*)$ /app.php/$1 last;
    }

    location ~ ^/udisk {
        internal;
        root /code/edusoho/app/data/;
    }

    location ~ ^/(app|app_dev)\.php(/|$) {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_split_path_info ^(.+\.php)(/.*)$;
        include fastcgi_params;
        fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
        fastcgi_param  HTTPS              off;
        fastcgi_param HTTP_X-Sendfile-Type X-Accel-Redirect;
        fastcgi_param HTTP_X-Accel-Mapping /udisk=/code/edusoho/app/data/udisk;
        fastcgi_buffer_size 128k;
        fastcgi_buffers 8 128k;
    }

    # 配置设置图片格式文件
    location ~* \.(jpg|jpeg|gif|png|ico|swf)$ {
        # 过期时间为3年
        expires 3y;

        # 关闭日志记录
        access_log off;

        # 关闭gzip压缩,减少CPU消耗,因为图片的压缩率不高。
        gzip off;
    }

    # 配置css/js文件
    location ~* \.(css|js)$ {
        access_log off;
        expires 3y;
    }

    # 禁止用户上传目录下所有.php文件的访问,提高安全性
    location ~ ^/files/.*\.(php|php5)$ {
        deny all;
    }

    # 以下配置允许运行.php的程序,方便于其他第三方系统的集成。
    location ~ \.php$ {
        # [改] 请根据实际php-fpm运行的方式修改
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_split_path_info ^(.+\.php)(/.*)$;
        include fastcgi_params;
        fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
        fastcgi_param  HTTPS              off;
    }
}

你可能感兴趣的:(day38——LNMP架构)