1.LNMP原理
LNMP 是一套技术组合,L=Linx、N=Nginx、M=MySQL、P=PHP
image.png
首先Nginx服务是不能处理动态请求,那么当用户发起动态请求时,Nginx是如何处理?
当用户发起http请求,请求会被Nginx处理,如果是静态资源请求Nginx则直接返回,如果是动态请求Nginx通过fastcgi协议交给后端的PHP程序处理
2.安装部署
- 创建www统一用户
groupadd www -g 666
useradd www -s /sbin/nologin -M -u 666 -g 666
id www
uid=666(www) gid=666(www) groups=666(www)
- 使用官方仓库源安装nginx或local本地仓库
#官方源
[root@web01 ~]# cat /etc/yum.repos.d/nginx.repo
[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
[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
[root@web01 ~]# yum install nginx -y
#本地仓库local源
cat >/etc/yum.repos.d/local.repo <<EOF
[local]
name=local
enable=1
gpgcheck=0
baseurl=http://10.0.0.61
#2.客户端测试安装
yum makecache # 更新下源
yum search nginx # 查找某个软件,是否走的YUM仓库
yum install nginx # 安装
- 启动Nginx并加入开机自启动
systemctl start nginx
systemctl enable nginx
- 使用第三方拓展源安装PHP7.1或(本地yum仓库)
yum remove php-mysql-5.4 php php-fpm php-common #清除就环境
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
yum -y install php71w php71w-fpm php71w-mbstring php71w-common php71w-gd php71w-mcrypt php71w-mysql php71w-xml php71w-cli php71w-devel php71w-pecl-memcached php71w-pecl-redis php71w-opcache
- 配置php-fpm用户与nginx用户保持一致
sed -i '/^user/c user = www' /etc/php-fpm.d/www.conf
sed -i '/^group/c group = www' /etc/php-fpm.d/www.conf
- 启动php-fpm并加入开机自启动
systemctl start php-fpm
systemctl enable php-fpm
3.调通Nginx和php的连接
- nginx子配置文件并重启服务
[root@db02 /etc/nginx/conf.d]# vim php.conf
server {
server_name www.a123.com; # 域名自定义
listen 80; # 暴露端口
root /code; # 代码目录
index index.php index.html; # 静态页面
location ~ \.php$ { # 匹配到以.php请求页面
root /code; # 代码目录
fastcgi_pass 127.0.0.1:9000; # 9000端口php-fpm进程
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; # 函数固定写法
include fastcgi_params;
}
}
[root@db02 /etc/nginx/conf.d]# systemctl restart nginx
- 调用php配置测试
[root@web01 ~]# mkdir /code
[root@web01 ~]# chown -R www:www /code/
[root@web01 ~]# cat /code/info.php
<?php
phpinfo();
?>
# 为安全考虑,测试完成后需删除此页面
-
浏览器查看Nginx和php是否连接成功(需配置本地hosts文件)
image.png
4.将nginx、PHP、MySQL全部调通
- 安装mysql
#安装依赖
yum install -y cmake openssl-devel gcc gcc-c++ glibc ncurses-devel autoconf libaio-devel
#上传按包并解压
tar xf mysql-5.6.46-linux-glibc2.12-x86_64.tar.gz
#创建存放mysql目录
mkdir /application
mv mysql-5.6.46-linux-glibc2.12-x86_64 /application/mysql-5.6.46
#复制配置文件并覆盖
cd /application/mysql-5.6.46/support-files/
cp my-default.cnf /etc/my.cnf y
cp mysql.server /etc/init.d/mysqld
#创建mysql用户和软连接。修改目录文件属主,属组
useradd mysql -s /sbin/nologin -M
cd /application/
ln -s mysql-5.6.46 mysql
chown -R mysql:mysql /application/mysql*
#初始化mysql
cd /application/mysql/scripts/
./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data/
#添加环境变量
vim /etc/profile.d/mysql.sh
export PATH="/application/mysql/bin:$PATH"
source /etc/profile
#修改mysql文件路径并启动
sed -i 's#/usr/local#/application#g' /etc/init.d/mysqld
service mysqld start
#mysql密码设置和初始化
密码设置方法1
mysqladmin password 123
密码设置的同时优化用户安全,清理test库(密码需设置,其他可默认回车)
mysql_secure_installation
#登录测试
mysql
- 创建测试PHP连通mysql的代码
[root@db02 /code]# cat /code/mysql.php
<?php
$servername = "127.0.0.1"; #这里如果写localhost:mysql会去找socket文件
$username = "root";
$password = "123";
// 创建连接
$conn = mysqli_connect($servername, $username, $password);
// // 检测连接
if (!$conn) {
die("Connection failed: " . mysqli_connect_error());
}
echo "php 连接 MySQL 数据库成功";
?>
image.png
5.搭建wordpress博客
#删除/code 目录下无用文件
[root@db02 /code]# rm -rf info.php mysql.php
#解压wordpress
tar xf wordpress-5.4.1-zh_CN.tar.gz
#修改权限
[root@db02 /code]# chown -R www:www /code/
#添加nginx配置文件并重启
[root@db02 /etc/nginx/conf.d]# vim bk.conf
server {
server_name www.bk.com;
listen 80;
root /code/wordpress; #博客代码目录
index index.php index.html;
location ~ \.php$ {
root /code/wordpress; #博客代码目录
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
systemctl restart nginx
#在windows配置hosts
- 创建博客数据库
[root@db02 /etc/nginx/conf.d]# mysql -uroot -p123
mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)
-
WEB页面登录
image.png
image.png
image.png
image.png
image.png
image.png
image.png
6.将数据库拆分出来
#1.将mysql数据库单独部署一台机
#2.创建一个远程登录的用户,和wordpress库
mysql> grant all on wordpress.* to dev@'10.0.0.%' identified by '123';
mysql> create database wordpress;
#3.使用创建用户登录测试
mysql -udev -p123 -h 10.0.0.55
#4.更改wordpress代码配置文件
[root@web01 /code/wordpress]# vim wp-config-sample.php
/** MySQL数据库用户名 */
define( 'DB_USER', 'dev' );
/** MySQL数据库密码 */
define( 'DB_PASSWORD', '123' );
/** MySQL主机 */
define( 'DB_HOST', '10.0.0.55' );