1.LNMP原理
LNMP 是一套技術(shù)組合,L=Linx、N=Nginx、M=MySQL、P=PHP
image.png
首先Nginx服務(wù)是不能處理動(dòng)態(tài)請(qǐng)求,那么當(dāng)用戶發(fā)起動(dòng)態(tài)請(qǐng)求時(shí),Nginx是如何處理?
當(dāng)用戶發(fā)起http請(qǐng)求,請(qǐng)求會(huì)被Nginx處理,如果是靜態(tài)資源請(qǐng)求Nginx則直接返回,如果是動(dòng)態(tài)請(qǐng)求Nginx通過fastcgi協(xié)議交給后端的PHP程序處理
2.安裝部署
- 創(chuàng)建www統(tǒng)一用戶
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 # 查找某個(gè)軟件,是否走的YUM倉庫
yum install nginx # 安裝
- 啟動(dòng)Nginx并加入開機(jī)自啟動(dòng)
systemctl start nginx
systemctl enable nginx
- 使用第三方拓展源安裝PHP7.1或(本地yum倉庫)
yum remove php-mysql-5.4 php php-fpm php-common #清除就環(huán)境
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
- 啟動(dòng)php-fpm并加入開機(jī)自啟動(dòng)
systemctl start php-fpm
systemctl enable php-fpm
3.調(diào)通Nginx和php的連接
- nginx子配置文件并重啟服務(wù)
[root@db02 /etc/nginx/conf.d]# vim php.conf
server {
server_name www.a123.com; # 域名自定義
listen 80; # 暴露端口
root /code; # 代碼目錄
index index.php index.html; # 靜態(tài)頁面
location ~ \.php$ { # 匹配到以.php請(qǐng)求頁面
root /code; # 代碼目錄
fastcgi_pass 127.0.0.1:9000; # 9000端口php-fpm進(jìn)程
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; # 函數(shù)固定寫法
include fastcgi_params;
}
}
[root@db02 /etc/nginx/conf.d]# systemctl restart nginx
- 調(diào)用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全部調(diào)通
- 安裝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
#創(chuàng)建存放mysql目錄
mkdir /application
mv mysql-5.6.46-linux-glibc2.12-x86_64 /application/mysql-5.6.46
#復(fù)制配置文件并覆蓋
cd /application/mysql-5.6.46/support-files/
cp my-default.cnf /etc/my.cnf y
cp mysql.server /etc/init.d/mysqld
#創(chuàng)建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/
#添加環(huán)境變量
vim /etc/profile.d/mysql.sh
export PATH="/application/mysql/bin:$PATH"
source /etc/profile
#修改mysql文件路徑并啟動(dòng)
sed -i 's#/usr/local#/application#g' /etc/init.d/mysqld
service mysqld start
#mysql密碼設(shè)置和初始化
密碼設(shè)置方法1
mysqladmin password 123
密碼設(shè)置的同時(shí)優(yōu)化用戶安全,清理test庫(密碼需設(shè)置,其他可默認(rèn)回車)
mysql_secure_installation
#登錄測試
mysql
- 創(chuàng)建測試PHP連通mysql的代碼
[root@db02 /code]# cat /code/mysql.php
<?php
$servername = "127.0.0.1"; #這里如果寫localhost:mysql會(huì)去找socket文件
$username = "root";
$password = "123";
// 創(chuàng)建連接
$conn = mysqli_connect($servername, $username, $password);
// // 檢測連接
if (!$conn) {
die("Connection failed: " . mysqli_connect_error());
}
echo "php 連接 MySQL 數(shù)據(jù)庫成功";
?>

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
#修改權(quán)限
[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
- 創(chuàng)建博客數(shù)據(jù)庫
[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.將數(shù)據(jù)庫拆分出來
#1.將mysql數(shù)據(jù)庫單獨(dú)部署一臺(tái)機(jī)
#2.創(chuàng)建一個(gè)遠(yuǎn)程登錄的用戶,和wordpress庫
mysql> grant all on wordpress.* to dev@'10.0.0.%' identified by '123';
mysql> create database wordpress;
#3.使用創(chuàng)建用戶登錄測試
mysql -udev -p123 -h 10.0.0.55
#4.更改wordpress代碼配置文件
[root@web01 /code/wordpress]# vim wp-config-sample.php
/** MySQL數(shù)據(jù)庫用戶名 */
define( 'DB_USER', 'dev' );
/** MySQL數(shù)據(jù)庫密碼 */
define( 'DB_PASSWORD', '123' );
/** MySQL主機(jī) */
define( 'DB_HOST', '10.0.0.55' );








