微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

LNMP5

目录

一、实战

systemctl centos7
ipaddress 192.168.80.2
wordpress-verison wordpress-5.3.2-zh_CN
PHP-version 7.1
Nginx-version yum安装-官方最新
//统一用户www,提前创建
groupadd -g 666 www;
useradd -u 666 -g 666 -M -s /sbin/nologin www;

1、安装

安装Nginx

//用官方的yum源
[Nginx-stable]
name=Nginx stable repo
baseurl=http://Nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://Nginx.org/keys/Nginx_signing.key
module_hotfixes=true

[Nginx-mainline]
name=Nginx mainline repo
baseurl=http://Nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://Nginx.org/keys/Nginx_signing.key
module_hotfixes=true

//安装
yum -y install Nginx

//更改主配置文件的启动用户
[root@Nginx conf.d]# vim /etc/Nginx/Nginx.conf 
user  www;

//编写站点文件
[root@Nginx conf.d]# vim default.conf 
server {
    listen       80;
    server_name  localhost;

    location / {
        root   /code;
        index  index.PHP;
    }
 location ~ \.PHP$ {
                root /code;
                fastcgi_index index.PHP;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_pass 127.0.0.1:9000;
                include fastcgi_params;
                }
}

//创建站点目录
mkdir /code


//上传wordpress-5.3.2-zh_CN,unzip解压到/code目录
[root@Nginx code]# mv wordpress/* ./

//更改权限
[root@Nginx code]# chown -R www:www  /code

//启动
systemctl start Nginx
systemctl enable Nginx

//检查
ss -tnlp | grep 80
ps aux | grep Nginx

数据库

//安装启动,设置密码
yum -y install mariadb-server mariadb
systemctl start mariadb
MysqL_secure_installation  #初始化并设置密码

//创建wordpress数据库
create database wordpress;

//创建wordpress用户wordpress数据库的授权
grant ALL on wordpress.* to wordpress@'localhost' identified by 'cba-123'; 

PHP

腾讯云提供的方法(亲测好用):

rpm -Uvh https://mirrors.cloud.tencent.com/epel/epel-release-latest-7.noarch.rpm 
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

yum -y install PHP70w PHP70w-opcache PHP70w-mbstring PHP70w-gd PHP70w-xml PHP70w-pear PHP70w-fpm PHP70w-MysqL PHP70w-pdo

//编写配置谁的,保证Nginx进程和PHP进程的用户一致
vim /etc/PHP-fpm.d/www.conf
user = www group=www

//启动进程
systemctl start PHP-fpm

//ps -aux 检查
ss -tnlp | grep 9000

老男孩教育提供方法(使用之后,wordpress不正常,样式丢失)

//卸载旧的PHP
yum remove PHP-MysqL PHP PHP-fpm PHP-common

//使用专用的PHP源
rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

//开始安装PHP
yum install -y 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

//编写配置谁的,保证Nginx进程和PHP进程的用户一致
vim /etc/PHP-fpm.d/www.conf
user = www  Nginx=www group=www

//启动进程
systemctl start PHP-fpm

//ps -aux 检查
ss -tnlp | grep 9000

wordpress

在浏览器上通过ip地址即可访问

管理URL:http://192.168.80.2/wp-admin/

2、三者建立联系

NginxPHP建立联系

[root@web01 conf.d]# cat default.conf 
server {
    listen       80;
    server_name  www.zhanghe.com;
    location / {               
        root   /code;
        index  index.html index.htm;
    }
    location ~ \.PHP$ {     #匹配PHP结尾的文件,通过cgi接口交给PHP
                root /code;
                fastcgi_index index.PHP;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;  #重点,携带完整的URL
                fastcgi_pass 127.0.0.1:9000;   #交给PHP
                include fastcgi_params;   #变量所在的文件,与上面fastcgi相配合
                }
}
systemctl restart Nginx
mkdir /code
cd /code
    vim index.PHP
        <?PHP
        PHPinfo();
        ?>

192.168.80.2/index.PHP访问时会打印一个紫色的表格

 PHP与mariadb建立关系

[root@Nginx code]# pwd
/code
[root@Nginx code]# cat index.PHP 
<?PHP
$servername = "localhost";
$username = "root";
$password = "cba-123";

$conn = MysqLi_connect($servername,$username,$password);
if ($conn) {
    echo "MysqL successful by root !\n";
    }else{
    die("connection Failed:" .MysqLi_connect_error());
}
?>

访问: http://192.168.80.2/index.PHP ,结果如果成功了就会提示:“ MysqL successful by root ! ”

二、理论

静态和动态

  • 静态资源:客户端从服务器获得的资源的表现形式与原文件相同。

  • 动态资源:通常是程序文件,需要在服务器执行之后,将执行的结果返回给客户端。

怎样理解这个静态呢?HTTPD程序接入到客户端的请求之后就是把客户端要请求的内容返回给客户端,其它的事情都没有做,只是做了I/0,内容没有发生改变,这就是静态资源。

web应用与PHP

httpd收到用户的请求之后,通过httpd的过滤功能(通常是后缀扩展名)可以区分出客户端请求的是静态资源还是动态资源,如果客户端请求的是静态资源的话(比如是html结尾的文件),httpd自己就可以发起系统调用完成响应;如果httpd识别出客户端请求的资源是一个PHP或者.sh结尾的文件呢?httpd本身是无能无力的,它总不能把这个PHP结尾的源码文件发送给客户端吧,但是httpd程序有自己又不能执行PHP文件,所以httpd需要与PHP解释器进行联动让PHP解释器把客户请求的程序执行一次,然后把结果返回给httpd进程,然后httpd进程再封装返回给客户端。那么httpdPHP解释器是两个程序,那么怎样联动呢?

httpdPHP解释器是两个不同的程序,就像两个说不同语言的人,相互谁也不理解谁,它们两个要想联动的话,就必须有统一的“交流语言”,这种情况在计算机的领域是非常常见的,都是使用协议来解决的,httpdPHP之间都运行cgi协议,所谓的cgi协议就是“通用网关接口”,httpd可以通过加载一个模块来支持此协议,而PHP也是基于此协议来开发的,所以它们之间是可以相互交流的。

httpdPHP在交流时的过程是这样的:

  1. httpd把客户端发过来动态资源请求通过cgi协议封装成请求包发送给PHP解释器

  2. PHP解释器收到之后会通过系统调用,然后IO,运行并处理引用户的动态资源,并通过数据流把结果发送给httpd程序,在这里需要注意,httpd加载静态资源的时候虽然加载的也是一个文件,但是实际就是一段数据流而已,当httpd收到来自PHP的响应报文时,收到的实际上也中是一段数据流,文件只是我们凭空想像出来的。

  3. httpd程序然后进行封装之后响应给客户端

总结

httpd像是客户端向PHP(服务器)发送请求,PHP做为服务器进行回应,httpd活生生像一个客户端!

换个角度再看,httpd就像是一个代理,对于动态资源的请求仅做一个转发作用,httpd活生生像一个代理!

PHPMysqL

PHP数据库系统进行联动

PHP数据库也是八竿子打不着的两个程序,它们怎样才一起联动呢?在这里并没有使用协议来解决这个问题,而是使用库调用解决这个问题的。假设以PHPMysqL进行联动来说明吧!

PHP程序本身的确无法与MysqL进行联动,PHP还需要加载一个驱动模板,这个驱动模块可能叫做PHP-MysqL,如果数据库是甲骨文数据库,那么PHP调用 PHP-甲骨文模块进行调用才与与甲骨文进行联动,因为PHP只有通过这个模块向相应的数据库系统发送的数据相应的数据库才能看懂,所以在安装PHP的时候,不要忘记安装这样一个驱动模块。

[root@www init.d]# yum list all | grep PHP-MysqL
PHP-MysqL.x86_64   #这个就是PHPMysqL交互的驱动模块

它们之间的关系也类似于客户端与服务器的关系,PHPMysqL请求,而MysqLPHP进行回应。

  1. 当客户端通过http协议向apache发来请求

    如果是静态资源,直接发起系统调用

    如果是动态资源,通过PHP模块/cgi/fastcgi任意一种方式发请求包交给PHP

  2. PHP收到之后apache的请求之后:

    如果所请求的资源都存储在硬盘上,那么PHP直接发起系统调用,将文件调用到内存并执行,执行完成之后把结果通过数据流交给apache,然后apache再回复客户端。

    如果所请求的资源有程序硬盘上,还有一部分数据在数据库当中,如下。

  3. PHP发的请求数据到达MysqL

    MysqL会通过各级索引找到数据,通过响应包回复PHPPHP通过在磁盘当中调用一部分程序,加上从mqsql回复的这部分数据,结合起来之后就可以运行,运行完成之后把结果交给apache

Nginx通过fastcgi接口与PHP交互,将用户的动态请求交给PHP处理。

PHP-fpm进程就用来接收Nginx发送过来的动态请求,fpm进程不会处理,真正处理的进程是wrapper进程,有些PHP请求wrapper可以直接进行处理,处理后再通过PHP-fpm返回给Nginx,但是还有一些需要调用数据库的,PHP-ini就负责与数据库沟通。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐