针对PHP的动静分离
LAMP
环境Nginx
处理静态页面请求,在server {}
;段中加入[root@nginx php5]#vim /usr/local/httpd/conf/nginx.conf
location ~ .*\.(gifiglipeglbmp|swf)$ {
root html;
index index.html index.htm;
};
[root@nginx php5]#vim /usr/local/httpd/conf/nginx.conf
server {
.....
location ~ \.php$ {
proxy_ pass http://192.168.9.237:8080; //LAMP的IP地址
......
开启两台Linux虚拟机,一台配置Nginx,一台配置LANM架构,客户端访问nginx网页时Nginx服务处理静态访问信息,LAMP处理动态访问信息,
yum install httpd httpd-devel -y
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
...//省略部分内容...
已安装:
httpd.x86_64 0:2.4.6-90.el7.centos httpd-devel.x86_64 0:2.4.6-90.el7.centos
...//省略部分内容...
完毕!
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=http
success //配置防火墙允许http服务在公共区域通过
[root@localhost ~]# firewall-cmd --permanent --zone=public --add-service=https
success //配置防火墙允许https服务在公共区域通过
[root@localhost ~]# firewall-cmd --reload //重新加载防火墙
success
[root@localhost ~]# systemctl start httpd.service //启动http服务
[root@localhost ~]# yum install mariadb mariadb-server mariadb-libs mariadb-devel -y
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: ftp.sjtu.edu.cn
...//省略部分内容...
已安装:
mariadb.x86_64 1:5.5.64-1.el7 mariadb-devel.x86_64 1:5.5.64-1.el7
mariadb-server.x86_64 1:5.5.64-1.el7
完毕!
[root@localhost ~]# systemctl start mariadb //启动mariadb服务
[root@localhost ~]# netstat -ntap | grep 3306
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 2519/mysqld
[root@localhost ~]# 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 current
password for the root user. If you've just installed MariaDB, and
you 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): //询问是否给root用户设置密码,直接回车
OK, successfully used password, moving on...
Setting the root password ensures that nobody can log into the MariaDB
root user without the proper authorisation.
Set root password? [Y/n] y //是否设置密码,输入y确认
New password: //输入密码
Re-enter new password: //再次输入密码
Password updated successfully!
Reloading privilege tables..
... Success!
By default, a MariaDB installation has an anonymous user, allowing anyone
to log into MariaDB without having to have a user account created for
them. This is intended only for testing, and to make the installation
go a bit smoother. You should remove them before moving into a
production environment.
Remove anonymous users? [Y/n] n //询问是否删除匿名用户,输入n,不删除
... skipping.
Normally, root should only be allowed to connect from 'localhost'. This
ensures that someone cannot guess at the root password from the network.
Disallow root login remotely? [Y/n] n //询问是否拒绝root用户远程登录,输入n,不拒绝
... skipping.
By default, MariaDB comes with a database named 'test' that anyone can
access. This is also intended only for testing, and should be removed
before 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 far
will 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 MariaDB
installation should now be secure.
Thanks for using MariaDB! //完成设置
[root@localhost ~]# yum -y install php //安装php服务
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: ftp.sjtu.edu.cn
...//省略部分内容...
已安装:
php.x86_64 0:5.4.16-46.1.el7_7
...//省略部分内容...
完毕!
[root@localhost ~]# yum install php-mysql -y //安装php与mysql连接包
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: ftp.sjtu.edu.cn
* extras: ftp.sjtu.edu.cn
...//省略部分内容...
已安装:
php-mysql.x86_64 0:5.4.16-46.1.el7_7
作为依赖被安装:
php-pdo.x86_64 0:5.4.16-46.1.el7_7
完毕!
[root@localhost ~]# yum install -y php-gd php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-snmp php-soap curl curl-devel php-bcmath //安装php环境包
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: ftp.sjtu.edu.cn
...//省略部分内容...
已安装:
libcurl-devel.x86_64 0:7.29.0-54.el7 php-bcmath.x86_64 0:5.4.16-46.1.el7_7
php-gd.x86_64 0:5.4.16-46.1.el7_7 php-ldap.x86_64 0:5.4.16-46.1.el7_7
php-mbstring.x86_64 0:5.4.16-46.1.el7_7 php-odbc.x86_64 0:5.4.16-46.1.el7_7
php-pear.noarch 1:1.9.4-21.el7 php-snmp.x86_64 0:5.4.16-46.1.el7_7
php-soap.x86_64 0:5.4.16-46.1.el7_7 php-xml.x86_64 0:5.4.16-46.1.el7_7
php-xmlrpc.x86_64 0:5.4.16-46.1.el7_7
...//省略部分内容...
完毕!
[root@localhost ~]# cd /var/www/html //进入网页站点
[root@localhost html]# vim index.php //编辑php网页内容
<?php
phpinfo();
?>
:wq
[root@localhost html]# systemctl restart httpd.service //重启http服务
[root@localhost ~]# hostnamectl set-hostname nginx //为了区分先更改Linux主机名称
[root@localhost ~]# su
[root@nginx ~]# //更改成功
[root@nginx nginx-1.12.2]# yum install gcc gcc-c++ make pcre-devel zlib-devel -y //安装环境包
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: ftp.sjtu.edu.cn
...//省略部分内容...
已安装:
gcc.x86_64 0:4.8.5-39.el7 gcc-c++.x86_64 0:4.8.5-39.el7 pcre-devel.x86_64 0:8.32-17.el7
zlib-devel.x86_64 0:1.2.7-18.el7
...//省略部分内容...
完毕!
[root@nginx ~]# useradd -M -s /sbin/nologin nginx //创建程序用户
[root@nginx ~]# mount.cifs //192.168.100.10/lnmp /mnt/ //挂载宿主机源码包目录到mnt目录下
Password for root@//192.168.100.10/lnmp:
[root@nginx ~]# cd /mnt/ //进入mnt目录
[root@nginx mnt]# tar zvxf nginx-1.12.2.tar.gz -C /opt/ //解压源码包
...//省略部分内容...
nginx-1.12.2/auto/cc/msvc
nginx-1.12.2/auto/cc/name
nginx-1.12.2/auto/cc/owc
nginx-1.12.2/auto/cc/sunc
[root@nginx mnt]# cd /opt/nginx-1.12.2/ //进入解压的nginx文件目录
[root@nginx nginx-1.12.2]# ./configure \ //配置nginx
> --prefix=/usr/local/nginx \
> --user=nginx \
> --group=nginx \
> --with-http_stub_status_module
...//省略部分内容...
nginx http fastcgi temporary files: "fastcgi_temp"
nginx http uwsgi temporary files: "uwsgi_temp"
nginx http scgi temporary files: "scgi_temp
[root@nginx nginx-1.12.2]# make && make install //制作安装nginx
...//省略部分内容...
test -d '/usr/local/nginx/html' \
|| cp -R html '/usr/local/nginx'
test -d '/usr/local/nginx/logs' \
|| mkdir -p '/usr/local/nginx/logs'
make[1]: 离开目录“/opt/nginx-1.12.2”
[root@nginx nginx-1.12.2]# ln -s /usr/local/nginx/sbin/* /usr/local/sbin/ //创建软连接文件到系统命令目录
[root@nginx nginx-1.12.2]# cd /lib/systemd/system //进入system管理目录
[root@nginx system]# vim nginx.service //编辑nginx启动脚本文件
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/bin/kill -s HUP $MAINPID
ExecStop=/usr/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
:wq
[root@nginx system]# chmod 754 nginx.service //添加执行权限
[root@nginx system]# systemctl start nginx.service //启动服务
[root@nginx system]# systemctl stop firewalld.service //关闭防火墙
[root@nginx system]# setenforce 0 //关闭增强性安全功能
[root@nginx system]# vim /usr/local/nginx/conf/nginx.conf
...//省略部分内容...
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
location ~ \.php$ { //开启此模块,并将IP地址更改为LAMP的主机,也就是将动态请求交给LAMP的主机处理
proxy_pass http://192.168.144.137;
}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
...//省略部分内容...
:wq
[root@nginx system]# systemctl stop nginx.service //关闭服务
[root@nginx system]# systemctl start nginx.service //重新启动服务
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。