LNMP架构
1.什么是LNMP架构?
LNMP架构就是:Linux+Nginx+Mysql+PHP
2.LNMP是如何工作的
nginx服务是不能处理动态请求的,只能其他软件
nginx服务是不能处理动态请求的,所以当用户发起动态请求时,nginx又是如何进行处理的?
当用户发起http请求时,请求会被nginx处理,如果是静态资源请求nginx则直接返回,如果是动态请求nginx则通过fastcgi协议转交给后端的PHP程序处理。
3.Nginx与PHP MySQL之间如何工作的
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;
}
}