千家信息网

实现apache与nginx之间的动静分离

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,实现apache与nginx之间的动静分离解析Nginx的静态处理能力很强,但是动态处理能力不足,因此,在企业中常用动静分离技术。针对PHP的动静分离,静态页面交给Nginx处理,动态页面交给PHP-
千家信息网最后更新 2025年01月23日实现apache与nginx之间的动静分离

实现apache与nginx之间的动静分离解析

Nginx的静态处理能力很强,但是动态处理能力不足,因此,在企业中常用动静分离技术。

针对PHP的动静分离,静态页面交给Nginx处理,动态页面交给PHP-FPM模块或Apache处理。

在Nginx的配置中,是通过location配置段配合正则匹配实现静态与动态页面的不同处理方式

其简单示意图如下:

本次实验将使用两台虚拟机,分别模拟LNMP端与NGINX端

首先是LAMP的架设

LAMP端

安装http服务

[root@localhost ~]# hostnamectl set-hostname LAMP       //更改主机名[root@localhost ~]# su[root@lamp ~]# yum install httpd httpd-devel -y[root@lamp ~]# systemctl start httpd.service[root@lamp ~]# firewall-cmd --zone=public --add-service=http --permanent    //防火墙设定允许通过success[root@lamp ~]# firewall-cmd --zone=public --add-service=https --permanent success[root@lamp ~]# firewall-cmd --reload success

安装mariadb数据库

概述:

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。

[root@lamp ~]# yum install mariadb mariadb-server mariadb-libs mariadb-devel -y[root@lamp ~]# systemctl start mariadb.service [root@lamp ~]# mysql_secure_installation                     //对数据库进行设置NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MariaDB      SERVERS IN PRODUCTION USE!  PLEASE READ EACH STEP CAREFULLY!In order to log into MariaDB to secure it, we'll need the currentpassword for the root user.  If you've just installed MariaDB, andyou haven't set the root password yet, the password will be blank,so you should just press enter here.Enter current password for root (enter for none):        //回车进行下一步OK, successfully used password, moving on...Setting the root password ensures that nobody can log into the MariaDBroot user without the proper authorisation.Set root password? [Y/n] y                             //建立新的root管理密码,选择yNew password:                                          //输入两遍同样密码即可Re-enter new password: Password updated successfully!Reloading privilege tables.. ... Success!By default, a MariaDB installation has an anonymous user, allowing anyoneto log into MariaDB without having to have a user account created forthem.  This is intended only for testing, and to make the installationgo a bit smoother.  You should remove them before moving into aproduction environment.Remove anonymous users? [Y/n] n                         //删除匿名用户?(选择n) ... skipping.Normally, root should only be allowed to connect from 'localhost'.  Thisensures that someone cannot guess at the root password from the network.Disallow root login remotely? [Y/n] n                 //是否允许远程根登录,选择n ... skipping.By default, MariaDB comes with a database named 'test' that anyone canaccess.  This is also intended only for testing, and should be removedbefore moving into a production environment.Remove test database and access to it? [Y/n] n        //选择n即可 ... skipping.Reloading the privilege tables will ensure that all changes made so farwill take effect immediately.Reload privilege tables now? [Y/n] y                 //是否进行刷新?(选择y) ... Success!Cleaning up...All done!  If you've completed all of the above steps, your MariaDBinstallation should now be secure.Thanks for using MariaDB!

安装PHP工具

[root@lamp ~]# yum -y install php              //安装PHP工具[root@lamp ~]# yum install php-mysql -y        //建立php与数据库的关系[root@lamp ~]# yum -y install \php-gd \php-ldap \php-odbc \php-pear \php-xml \php-xmlrpc \php-mbstring \php-snmp \php-soap \curl curl-devel \php-bcmath

创建http站点

[root@lamp ~]# cd /var/www/html/          //前往http站点目录[root@lamp html]# ll       //此时为空总用量 0[root@lamp html]# vim index.php           //新建首页添加[root@lamp html]# systemctl restart httpd.service

此时,使用测试机进行访问是可以查看到php的动态网页的,证明LAMP架构成功,下面就是nginx方面的设置。

Nginx端

开启另一台虚拟机作为nginx端

手工编译安装nginx

[root@localhost ~]# hostnamectl set-hostname nginx      //更改主机名[root@localhost ~]# su[root@nginx mnt]# tar zxvf nginx-1.12.0.tar.gz -C /opt[root@nginx mnt]# cd /opt/nginx-1.12.0/[root@nginx nginx-1.12.0]# useradd -M -s /sbin/nologin nginx     //创建程序性用户[root@nginx nginx-1.12.0]# yum -y install \gcc gcc-c++ \pcre pcre-devel \zlib-devel \expat-devel[root@nginx nginx-1.12.0]# ./configure \> --prefix=/usr/local/nginx \> --user=nginx \> --group=nginx \> --with-http_stub_status_module[root@nginx nginx-1.12.0]# make && make install     //编译安装

编写启动脚本

[root@nginx nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/    //创建软链接方便识别[root@nginx nginx-1.12.0]# vim /etc/init.d/nginx添加#!/bin/bashwenjian="/usr/local/nginx/sbin/nginx"pid="/usr/local/nginx/logs/nginx.pid"case $1 instart)    $wenjian ;;stop)    kill -s QUIT $(cat $pid) ;;restart)    $0 stop    $0 start;;reload)    kill -s HUP $(cat $pid) ;;*)    echo "Please,try again"    exit 1 ;;esacexit 0[root@nginx nginx-1.12.0]# chmod +x /etc/init.d/nginx[root@nginx init.d]# service nginx start [root@nginx init.d]# netstat -atnp | grep 80tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      8638/nginx: master[root@nginx init.d]# systemctl stop firewalld.service [root@nginx init.d]# setenforce 0

验证nginx服务

此时,我们通过测试机进行访问,即可得到如下界面:

但是,若访问php格式的动态网页则会出现404访问错误的问题

想要解决这个问题,就引入了下面的实验,在nginx配置文件中进行动静分离的设置

nginx端

[root@nginx init.d]# cd /usr/local/nginx/conf[root@nginx conf]# vim nginx.conf     //修改配置文件59到61行,取消注释,并按照下面进行修改  location ~ \.php$ {        proxy_pass   http://192.168.142.128;    #apache服务器所在地址  }wq保存退出[root@nginx nginx]# service nginx stop       //重启服务[root@nginx nginx]# service nginx start

至此,动静分离就全部完成了。

实验验证

动态网页

静态网页

动态 动静 处理 选择 数据 数据库 网页 静态 服务 配置 页面 实验 主机 密码 工具 文件 用户 站点 能力 问题 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全竞赛宣传大纲 我的世界服务器合成表不显示 mt4设置服务器 rust怎么样看服务器人数 easymall商城数据库设计 暗黑2亚洲服务器什么时候更新 插入读卡器显示服务器运行失败 黄冈网络安全审计 租服务器怎么架设游戏 如何把流量服务器打开 装配式网络技术哪家好 中国城乡社会治理调查数据库 网络安全包抬哪些项目 网络安全法2.0内容 大学生网络安全的主要内容 数据库代码风险 运行时地理数据库是怎么创建的 网课软件开发商公司 儿童个人信息网络安全保护 品茗安全临时用电超出数据库 惠普服务器电源如何加装电压显示 本地文件怎么复制到远程服务器 嘉兴智能软件开发培训 awe数据库 金融软件开发公司 廣東 中国城乡社会治理调查数据库 施耐德低压数据库 江苏品质刀片服务器生产厂家 阿里云服务器申请步骤 录屏视频提示服务器运行失败
0