PQS/TPS每秒请求数/ 每秒事务数 // 流量衡量参数
可以根据预估QPS 和 服务器的支持的最高QPS 对照计算 就可以得出 需要上架的服务器的最小数量
PV 页面浏览数 UV 独立用户访问量 // 对于网站的总体访问量
response time 响应时间 // 每个请求的响应时间
lnmp 分离部署 分化压力
nginx - 一个节点 192.168.110.133
php 一个节点 192.168.110.138
db 一个节点 192.168.110.22
实验topo

实验过程
nginx节点:
[root@nginx ~]# dnf -y install nginx
[root@nginx ~]# systemctl enable nginx.service
Created symlink /etc/systemd/system/multi-user.target.wants/nginx.service → /usr/lib/systemd/system/nginx.service.
[root@nginx ~]# systemctl status firewalld.service
● firewalld.service - firewalld - dynamic firewall daemon
Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; preset: enabled)
Active: active (running) since Tue 2024-09-10 09:12:37 CST; 2h 34min ago
Docs: man:firewalld(1)
Main PID: 924 (firewalld)
Tasks: 2 (limit: 24434)
Memory: 42.1M
CPU: 1.275s
CGroup: /system.slice/firewalld.service
└─924 /usr/bin/python3 -s /usr/sbin/firewalld --nofork --nopid
Sep 10 09:12:36 localhost systemd[1]: Starting firewalld - dynamic firewall daemon...
Sep 10 09:12:37 localhost systemd[1]: Started firewalld - dynamic firewall daemon.
[root@nginx ~]# systemctl stop firewalld.service
[root@nginx ~]# setenforce 0
[root@nginx ~]# vim /etc/exports
/usr/share/nginx/html *(rw)
[root@nginx ~]# cat /usr/share/nginx/html/index.php
<?php
phpinfo();
?>
[root@nginx ~]# yum -y install nfs-utils
[root@nginx ~]# systemctl start nfs-server
php:
php:
[root@php ~]# dnf -y install php php-fpm
[root@php ~]# systemctl stop firewalld.service
[root@php ~]# setenforce 0
[root@php ~]# systemctl start php-fpm
[root@php ~]# dnf -y install nfs-utils
root@php ~]# showmount -e 192.168.110.133
Export list for 192.168.110.133:
/usr/share/nginx/html *
[root@php ~]# mkdir -p /usr/local/nginx/html
[root@php ~]# chown apache -R /usr/share/nginx
[root@php ~]# mount 192.168.110.133:/usr/share/nginx/html /usr/share/nginx/html/
[root@php ~]# vim /etc/php-fpm.d/www.conf

// 修改php-fpm 监听本地与nginx同一网段的IPv4地址和9000端口
// 如果只写9000 代表监听所有地址的9000端口

// 允许访问的地址列表中添加nginx的ip地址
root@php \~\]# systemctl start php-fpm.service ### 返回nginx节点,进行动静分离的配置:  [root@nginx ~]# nginx -t nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful [root@nginx ~]# systemctl reload nginx.service 验证nginx转发php脚本给php-fpm 节点解析 [root@nginx ~]# curl -I 127.0.0.1/index.php HTTP/1.1 200 OK Server: nginx/1.20.1 Date: Tue, 10 Sep 2024 05:49:32 GMT Content-Type: text/html; charset=UTF-8 Connection: keep-alive X-Powered-By: PHP/8.0.30 如果访问出现问题,结合日志进行排错。 nginx 访问日志: /var/log/nginx/access.log 错误日志:/var/log/nginx/error.log php-fpm 日志: /var/log/php-fpm/error.log ### 配置php连接数据库 [root@db-mariadb ~]# dnf -y install mariadb mariadb-server [root@db-mariadb ~]# systemctl stop firewalld.service [root@db-mariadb ~]# setenforce 0 [root@db-mariadb ~]# systemctl start mariadb.service [root@db-mariadb ~]# mysql -u root -p Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 3 Server version: 10.5.22-MariaDB MariaDB Server Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MariaDB [(none)]> set password=password('redhat'); Query OK, 0 rows affected (0.001 sec) MariaDB [(none)]> exit Bye [root@db-mariadb ~]# ss -anput | grep mysql [root@db-mariadb ~]# ss -anput | grep mariadb tcp LISTEN 0 80 *:3306 *:* users:(("mariadbd",pid=35118,fd=19)) [root@db-mariadb ~]# mysql -u root -p Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 5 Server version: 10.5.22-MariaDB MariaDB Server Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MariaDB [(none)]> select user,host from mysql.user; +-------------+-----------+ | User | Host | +-------------+-----------+ | mariadb.sys | localhost | | mysql | localhost | | root | localhost | +-------------+-----------+ 3 rows in set (0.002 sec) MariaDB [(none)]> grant all on *.* to [email protected] identified by 'redhat'; Query OK, 0 rows affected (0.001 sec) MariaDB [(none)]> select user,host from mysql.user; +-------------+-----------------+ | User | Host | +-------------+-----------------+ | root | 192.168.110.138 | | mariadb.sys | localhost | | mysql | localhost | | root | localhost | +-------------+-----------------+ 4 rows in set (0.001 sec) MariaDB [(none)]> ### 在php上安装php-mysqlnd 模块,并验证可以连接数据库 [root@php ~]# dnf -y install mariadb [root@php ~]# mysql -h 192.168.110.22 -u root -predhat Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 6 Server version: 10.5.22-MariaDB MariaDB Server Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MariaDB [(none)]> exit Bye [root@php ~]# dnf -y install php-mysqlnd ### 切换到nginx 节点上,添加php连接数据库的脚本程序文件 [root@nginx ~]# cat /usr/share/nginx/html/db.php ### 在php节点查看文件是否同步,已经能否运行该脚本程序 [root@php ~]# ls /usr/share/nginx/html/db.php /usr/share/nginx/html/db.php [root@php ~]# php /usr/share/nginx/html/db.php 成功连接数据库 通过浏览器验证访问  [root@nginx ~]# curl 192.168.110.133/db.php 成功连接数据库 如果是lnamp 一般采用为apache 服务器前设置代理服务实现动静分离,apache 主要处理动态请求。 在对nginx 、 php 还有数据库 进行水平扩展时,应该怎么做? 