• 搭建LNMP实现分离


    目录

    nginx理论

    nginx日志格式:log_format

    nginx日志格式的变量

    nginx的location

    安装LNMP

    1. 安装nginx

    2. 安装mysql(mariadb)

    3. 安装PHP

    应用安装

    搭建wordpress

    搭建知乎WeCenter

    LNMP实现动静分离

    LNMP数据库的迁移 

    LNMP的PHP迁移


    🍤:大虾好吃吗的博客_大虾好吃吗

          实验目标:使用一台linux服务器先搭建LNMP平台,安装两个论坛后实现LNMP分离。

    实验拓扑图如下:

      

    nginx理论

    nginx日志格式:log_format

    示例:

    vim /etc/nginx/nginx.conf

    http {

    log_format  main  '$remote_addr - $remote_user [$time_iso8601] "$request" ' #定义日志输出格式main

                          '$status $body_bytes_sent "$http_referer" '

                          '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main; #调用日志格式main

    }

    nginx日志格式的变量

    $remote_addr #记录客户端的ip地址

    $remote_user #记录客户端的用户名

    $time_local #通用的时间格式

    $time_iso8601 #iso8601时间格式

    $request #请求的方法和请求的HTTP协议

    $status #请求状态码

    $body_bytes_sent #服务器回应的字节数,不包含头部大小

    $bytes_sent #服务器回应的总字节数

    $msec #日志写入时间,单位为秒,精度为毫秒

    $http_referer #记录链接访问源地址

    $http_user_agent #记录客户端浏览器信息

    $http_x_forwarded_for #代理服务器ip

    $request_length #请求包的长度(请求头+请求正文)

    $request_time #请求花费的时间,单位为秒,精度为毫秒

    (经验: 1秒=1000毫秒(ms), 1毫秒=1/1000秒(s);1秒=1000000 微秒)

    nginx的location

    语法规则: location [=|~|~*|^~] /uri/ { … }

    下列以优先级从高到低排序

    = 开头表示精确匹配

    ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。

    ~ 开头表示区分大小写的正则匹配                    

    ~* 开头表示不区分大小写的正则匹配             

    !~和!~*分别为区分大小写不匹配及不区分大小写不匹配的正则

    / 通用匹配,任何请求都会匹配到。

    示例:测试匹配符的优先级

    cd /etc/nginx/conf.d/

    vim test.conf

    添加:

    server {

            listen 80;

            server_name test.benet.com;

            location / {

                    default_type text/html;

                    return 200 "location /";

            }

            location =/ {

                    default_type text/html;

                    return 200 "location =/";

            }

            location ~ / {

                    default_type text/html;

                    return 200 "location ~ /";

            }

            location ~* / {

                    default_type text/html;

                    return 200 "location ~* /";

            }

    }

            保存退出

            客户端修改hosts文件,测试访问

    真实企业场景配置:*

    #通用匹配,任何请求都会匹配到。

    location / {

    }

    #严格区分大小写,匹配.php结尾

    location ~ \.php$ {

    fastcgi_pass http://127.0.0.1:9000;

    }

    #严格区分大小写,匹配.jsp结尾

    location ~ \.jsp$ {

    proxy_pass http://127.0.0.1:8080;

    }

    #不区分大小写匹配

    location ~* "\.(sql|bak|tgz|tar.gz|.git)$ {

    default_type text/html;

    return 403 "启用访问控制";

    }

    (注意:以上主要用于网页的动、静分离)

    安装LNMP

    1. 安装nginx

    所需安装包如下:

    安装并启动:

    1. [root@nginx ~]# rpm -ivh /media/nginx-rpm/*.rpm --nodeps --force
    2. [root@nginx ~]# systemctl start nginx
    3. [root@nginx ~]# systemctl enable nginx
    4. Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.

    2. 安装mysql(mariadb)

    所需安装包如下:

    安装mysql并启动

    1. [root@nginx ~]# rpm -ivh /media/mysql5.6-rpm/*.rpm --nodeps --force
    2. [root@nginx ~]# systemctl start mysqld
    3. [root@nginx ~]# systemctl enable mysqld
    4. 创建mysql密码
    5. [root@nginx ~]# mysqladmin -uroot password
    6. New password: //输入新密码
    7. Confirm new password: //再次输入新密码

    3. 安装PHP

    所需安装包如下:

      

    安装php并启动

    1. [root@nginx ~]# rpm -ivh /media/php-rpm/*.rpm --nodeps --force
    2. [root@nginx ~]# systemctl start php-fpm
    3. [root@nginx ~]# systemctl enable php-fpm

    应用安装

            本次php可以搭建两个应用wordpress和wecenter,两个app搭建一个论坛即可。如搭建两个app需要测试机本地解析域名,通过域名访问虚拟主机

    搭建wordpress

    注意:下面操作需要在同一台服务器操作,注意看服务器名称。

    1. 下载并解压wordpree包到/下并解压授权。

    1. [root@nginx ~]# cp -rp /media/wordpress-4.9.4-zh_CN.zip /
    2. [root@nginx ~]# cd /
    3. [root@nginx /]# unzip wordpress-4.9.4-zh_CN.zip
    4. [root@nginx /]# chmod -R 777 /wordpress

    2. 创建虚拟主机配置文件

    1. [root@nginx /]# vim /etc/nginx/conf.d/blog.conf
    2. server {
    3.         listen 80;
    4.         server_name www.blog.com;
    5.         root /wordpress;
    6.         index index.php index.html;
    7.         location ~ \.php$ {
    8.                         root /wordpress;
    9.                         fastcgi_pass 127.0.0.1:9000; //php服务器地址,如分离需要指定PHP服务器。
    10.                         fastcgi_index index.php;
    11.                         fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;  //与上一行是同一行,注意有空格
    12.                 include fastcgi_params;
    13.                 }
    14.         }
    15. [root@nginx /]# nginx -t
    16. nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
    17. nginx: configuration file /etc/nginx/nginx.conf test is successful
    18. [root@nginx /]# systemctl restart nginx //修改配置文件后需要重启或重载服务。

    3. 创建blog数据库和管理用户

    1. [root@nginx ~]# mysql -uroot -p123
    2. //省略部分内容
    3. mysql> create database blog;
    4. Query OK, 1 row affected (0.00 sec)
    5. mysql> grant all on blog.* to lisi@localhost identified by '123456';
    6. Query OK, 0 rows affected (0.00 sec)
    7. mysql> exit
    8. Bye

    4. 通过客户端服务器验证

            注意下面使用测试机1.10访问。

            因为只搭建了第一个app,所以直接访问IP即可,http://192.168.1.4,后台网址为http://192.168.1.4/wp-admin。根据下图点击(现在就开始!)。

      

            修改以下三项内容后点击提交。

            点击现在安装。

            创建站点标题,管理用户名及密码,如密码过于简单需要勾选确认使用弱密码,输入邮箱后点击安装即可。

     

            完成后使用用户密码登录即可。

            登录后可以看到论坛板块,根据需求修改添加即可。

    搭建知乎WeCenter

    1. 下载并解压wecenter包到/zh下并解压授权。

    1. [root@nginx ~]# mkdir /zh
    2. [root@nginx ~]# cp -rp /media/WeCenter_3-3-4.zip /zh
    3. [root@nginx ~]# cd /zh
    4. [root@nginx zh]# unzip WeCenter_3-3-4.zip
    5. [root@nginx zh]# chmod -R 777 /zh

    2. 创建虚拟主机配置文件

    1. [root@nginx zh]# vim /etc/nginx/conf.d/zh.conf
    2. server {
    3.         listen 80;
    4.         server_name www.zh.com;
    5.         root /zh;
    6.         index index.php index.html;
    7.         location ~ \.php$ {
    8.                 root /zh;
    9.                 fastcgi_pass 127.0.0.1:9000; //php服务器地址,如分离需要指定PHP服务器。
    10.                 fastcgi_index index.php;
    11.                 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    12.                 include fastcgi_params;
    13.                 }
    14.         }
    15. [root@nginx zh]# systemctl restart nginx

    3. 创建blog数据库和管理用户

    1. [root@nginx ~]# mysql -uroot -p123
    2. //省略部分内容
    3. mysql> create database zh;
    4. Query OK, 1 row affected (0.00 sec)
    5. mysql> grant all on zh.* to wangwu@localhost identified by '123456';
    6. Query OK, 0 rows affected (0.00 sec)
    7. mysql> exit
    8. Bye

    4. 通过客户端服务器验证

    注意:下面使用测试机1.10访问。

            前面已经安装了wordpress,使用IP访问的话优先访问wordpree论坛,所以需要修改测试机的本地hosts文件或配置DNS域名解析。如两者只安装一个可以忽略域名方式访问,使用IP访问即可。访问http://zh.benet.com登录后台为http://zh.benet.com/?/admin。

    1. [root@client ~]# echo "192.168.1.4 www.blog.com" >> /etc/hosts
    2. [root@client ~]# echo "192.168.1.4 www.zh.com" >> /etc/hosts

            浏览器访问http://www.zh.com,进入安装页面,拉到最下面确认没问题,点击下一步。

     

      

            修改下面四项内容,端口默认3306,如使用其他端口需添加上去,完成后点击现在安装。

            根据要求创建管理员用户密码,输入邮箱后点击完成。

            完成后点击访问网站首页即可。

            输入用户密码后登录论坛首页即可。

    LNMP实现动静分离

            根据以上操作,lnmp搭建论坛就完成了,下面将进行拆分lnmp。

    LNMP数据库的迁移 

            1. 为了实现mysql独立运行,现需要把nginx服务器中的mysql数据库迁移到1.5mysql服务器中。打开1.5mysql服务器,安装mysql,配置密码。

    1. [root@mysql ~]# rpm -ivh /media/mysql5.6-rpm/*.rpm --nodeps --force
    2. [root@mysql ~]# systemctl start mysqld
    3. [root@mysql ~]# systemctl enable mysqld
    4. [root@mysql ~]# mysqladmin -uroot password
    5. New password:
    6. Confirm new password:

            2. 把nginx服务器(192.168.1.4)中的mysql数据库文件导出,并复制到新的mysql服务器(192.168.1.5)中。 

    1. [root@nginx ~]# mysqldump -uroot -p123 --all-databases > my.sql
    2. Warning: Using a password on the command line interface can be insecure.
    3. [root@nginx ~]# scp my.sql root@192.168.1.5:/root
    4. The authenticity of host '192.168.1.5 (192.168.1.5)' can't be established.
    5. ECDSA key fingerprint is SHA256:i7pBmvf3GlxXGmjiEWzSfTD1J8gwQ32anS7qK/jbMbM.
    6. ECDSA key fingerprint is MD5:80:da:11:52:72:6d:4e:08:3f:b7:64:25:8c:8f:49:14.
    7. Are you sure you want to continue connecting (yes/no)? yes
    8. Warning: Permanently added '192.168.1.5' (ECDSA) to the list of known hosts.
    9. root@192.168.1.5's password: //输入mysql服务器的root密码
    10. my.sql                                                         100% 1757KB  38.3MB/s   00:00

            3. 在新的mysql服务器上导入数据库文件。

    1. [root@mysql ~]# mysql -uroot -p123 < /root/my.sql 
    2. Warning: Using a password on the command line interface can be insecure.
    3. [root@mysql ~]# systemctl restart mysqld

            4. 在新的mysql服务器上创建相同的管理用户和密码。

    1. [root@mysql ~]# mysql -uroot -p123 //登录mysql
    2. //省略部分内容
    3. mysql> grant all on blog.* to lisi@'%' identified by '123456'; //创建用户lisi密码123456
    4. Query OK, 0 rows affected (0.00 sec)
    5. mysql> grant all on zh.* to wangwu@'%' identified by '123456'; //创建用户wangwu密码123456
    6. Query OK, 0 rows affected (0.00 sec)
    7. mysql> exit
    8. Bye

            5. 在原服务器(nginx服务器1.4)中修改blog和zh的配置文件,重新指定数据库服务器ip。

    (1)修改blog配置文件

    1. [root@nginx ~]# grep -R 123456 /wordpress //查找blog的配置文件,查看后发现wp-config.php文件
    2. [root@nginx ~]# vim /wordpress/wp-config.php //下面只需要修改服务器IP地址
    3. /** WordPress数据库的名称 */
    4. define('DB_NAME', 'blog');
    5. /** MySQL数据库用户名 */
    6. define('DB_USER', 'lisi');
    7. /** MySQL数据库密码 */
    8. define('DB_PASSWORD', '123456');
    9. /** MySQL主机 */
    10. define('DB_HOST', '192.168.1.5'); //新的mysql服务器的主机地址。

    (2)修改zh文件     

    1. [root@nginx ~]# grep -R 123456 /zh //查找zh的配置文件,查看后发现/zh/system/config/database.php的配置文件
    2. [root@nginx ~]# vim /zh/system/config/database.php
    3.   'host' => '192.168.1.5',         //该配置文件中依旧只需要修改为新的mysql主机地址。

             以上步骤就完成了mysql的拆分,下面将进行php的拆分。

    LNMP的PHP迁移

            1. 打开新的linux服务器,安装PHP。

    [root@php ~]# rpm -ivh /media/php-rpm/*.rpm --nodeps --force

            2. 修改nginx服务器(192.168.1.4)中的配置文件,重新指向新的php服务器,blog和zh配置文件都需要修改。

    1. [root@nginx ~]# vim /etc/nginx/conf.d/blog.conf
    2.  fastcgi_pass 192.168.1.6:9000; //修改该行配置中的IP为PHP服务器的地址。
    3. [root@nginx ~]# vim /etc/nginx/conf.d/zh.conf
    4. fastcgi_pass 192.168.1.6:9000; //同上
    5. [root@nginx ~]# systemctl restart nginx

            3. 修改PHP服务器(192.168.1.6)的配置文件。

    1. [root@php ~]# vim /etc/php-fpm.d/www.conf
    2. listen = 192.168.1.6:9000 //PHP服务器IP
    3. listen.allowed_clients = 192.168.1.4 //web服务器IP,表示允许web主机访问php服务器
    4. [root@php ~]# systemctl restart php-fpm

            4. 复制wordpress和zh安装目录到php根下。

    1. [root@php ~]# scp -rp root@192.168.1.4:/wordpress /
    2. root@192.168.1.4's password: //1.4root密码
    3. [root@php ~]# scp -rp root@192.168.1.4:/zh /
    4. root@192.168.1.4's password: //1.4root密码

            5. 客户端(192.168.1.10)验证

            访问http://www.blog.com登录用户验证成功。

            访问http://www.zh.com登录用户验证成功。

  • 相关阅读:
    K8S 实用工具之三 - 图形化 UI Lens
    记我的 Windows Dev Kit 2023 使用体验
    LibTorch实战一:MNIST的python代码
    OkHttp post json数据,Java
    springcloud:3.1介绍雪崩和Resilience4j
    Handler原理
    docker 复习
    分类预测 | MATLAB实现SSA-CNN-BiLSTM麻雀算法优化卷积双向长短期记忆神经网络数据分类预测
    【Linux基础】Linux基本指令(二)
    生产事故-走近科学之消失的JWT
  • 原文地址:https://blog.csdn.net/qq_61116007/article/details/127831511