LNMP

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' );

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
禁止轉(zhuǎn)載,如需轉(zhuǎn)載請(qǐng)通過簡信或評(píng)論聯(lián)系作者。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容