• LNMP服务


    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


    前言

    LNMP 指的是一个基于 CentOS/Debian 编写的 Nginx、 Linux、 MySQL、 PHP, 可以在独立主机上轻松的安装 LNMP 生产环境。


    一、案例概述

    LNMP 指的是一个基于 CentOS/Debian 编写的 Nginx、Linux、MySQL、PHP,可以在独立主机上轻松的安装 LNMP 生产环境。本案例主要介绍 LNMP 框架安装方法以及部署 Discuz!社区论坛应用。

    二、、Nginx

    Nginx 作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,
    体现更高的效率。Nginx 作为负载均衡服务器:Nginx 既可以在内部直接支持 Rails 和 PHP,
    也可以支持作为 HTTP 代理服务器对外进行服务。Nginx 采用 C 语言进行编写,不论是系统
    资源开销还是 CPU 使用效率都比 Perlbal 要好的多。Nginx 作为邮件代理服务器:Nginx 同
    时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服
    务器),Last/fm 描述了成功并且美妙的使用经验。Nginx 安装非常的简单,配置文件非常
    简洁(还能够支持 perl 语法)。Nginx 支持平滑加载新的配置,还能够在不间断服务的情
    况下进行软件版本的升级。

    三、MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前被 Oracle 公
    司收购。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL 是较好
    的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件。
    MySQL 是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数
    据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用
    于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,
    由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开
    发都选择 MySQL 作为网站数据库。

    四、PHP-FPM

    PHP-FPM(FastCGI Process Manager:FastCGI 进程管理器)是一个 PHPFastCGI 管理器,由于 Nginx 服务器不能处理动态页面,需要由 Nginx 把动态请求交给 php-fpm 处理。
    FastCGI:FastCGI是一个可伸缩地、高速地在HTTP服务器和动态脚本语言间通信的接口(FastCGI接口在Linux下是socket(可以是文件socket,也可以是ip socket)),主要优点是把动态语言和HTTP服务器分离开来。多数流行的HTTP服务器都支持FastCGI,包括Apache、Nginx和lightpd。
    FastCGI:作用:把动态语言和HTTP分离开来,动静分离

    五、LNMP架构的部署

    1、部署思路

    安装 Nginx 服务
    安装 MySQL 服务
    安装配置 PHP 解析环境
    部署 Discuz!社区论坛 Web 应用

    2、安装 Nginx 服务

    (一)、关闭防火墙、核心防护

    (二)、安装环境依赖包

    yum -y install gcc gcc-c++ pcre-devel zlib-devel make
    
    • 1

    在这里插入图片描述

    (三)、创建运行用户、组

    useradd -M -s /sbin/nologin nginx
    不建立宿主文件夹,也禁止登录到 Shell 环境
    
    为其创建专门的用户账号,以便更准确
    地控制其访问权限,增加灵活性、降低安全风险
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    (四)、编译安装Nginx

    上传nginx-1.15.9.tar.gz至/opt目录

    cd /opt
    tar xzvf nginx-1.15.9.tar.gz
    cd nginx-1.15.9/
    
    • 1
    • 2
    • 3

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述

    配置configure(解释性语言需要执行,编译性语言就不需要)
    ./configure \ 执行脚本
    --prefix=/usr/local/nginx \  将安装目录设为/usr/local/nginx;
    --user=nginx \
    --group=nginx \运行用户和组均设为nginx;
    --with-http_stub_status_module启用http_stub_status_module 模块以支持状态统计,便于查看服务器的连接信息
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述

    编译安装并显示进度条
    make && make install
    
    • 1
    • 2

    在这里插入图片描述

    (五)、路径优化

    ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
    创建链接文件,以便管理员
    直接执行“nginx”命令就可以调用 Nginx 的主程序让系统可以识别
    ls -l /usr/local/sbin/nginx
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    (六)、检查配置文件

    nginx -t
    检测的是语法和配置文件能否生效
    若要检查位于其他位置的配置文件,可使用“-c”选项来指定路径
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    (七)、启动、停止Nginx

    nginx:开启nginx 服务
    
    
    • 1
    • 2
        主程序 Nginx 支持标准的进程信号,通过 kill 或 killall 命令发送 HUP 信号表示重载配置,
    QUIT 信号表示退出进程,KILL 信号表示杀死进程。例如,若使用 killall 命令,重载配置、
    停止服务的操作分别如下所示(通过“-s”选项指定信号种类)
    #killall -s HUP nginx      ###选项 -s HUP 等同于 -1  重新加载 systemctl reload nginx 
    #killall -s QUIT nginx     ###选项 -s QUIT 等同于 -3  停止服务 systemctl stop nginx 
    当 Nginx 进程运行时,PID 号默认存放在 logs/目录下的 nginx.pid 文件中,因此若改用
    kill 命令,也可以根据 nginx.pid 文件中的 PID 号来进行控制。
    #/usr/local/nginx/logs/nginx.pid
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    1、检查 Nginx 程序的监听状态
    netstat -anpt | grep nginx 
    
    • 1

    在这里插入图片描述

    2、在浏览器中访问此 Web 服务(默认页面将显示“Welcom to nginx!”)

    在这里插入图片描述
    在这里插入图片描述

    (八)、添加 Nginx 系统服务

    vim /lib/systemd/system/nginx.service
    配置参数
    [Unit]
    Description=nginx
    After=network.target
    [Service]
    Type=forking
    PIDFile=/usr/local/nginx/logs/nginx.pid
    ExecStart=/usr/local/nginx/sbin/nginx
    ExecReload=/usr/bin/kill -s HUP $MAINPID
    ExecStop=/usr/bin/kill -s QUIT $MAINPID
    PrivateTmp=true
    [Install]
    WantedBy=multi-user.target
    ##配置参数解释##
    [Unit]
    Description=nginx                    					  ####描述
    After=network.target                 					  ####描述服务类别
    [Service]
    Type=forking                                              ###后台运行形式
    PIDFile=/usr/local/nginx/logs/nginx.pid                   ###PID文件位置
    ExecStart=/usr/local/nginx/sbin/nginx                     ###启动服务
    ExecReload=/usr/bin/kill -s HUP $MAINPID             ###根据PID重载配置
    ExecStop=/usr/bin/kill -s QUIT $MAINPID                ###根据PID终止进程
    PrivateTmp=true
    [Install]
    WantedBy=multi-user.target
    
    
    chmod 754 /lib/systemd/system/nginx.service
    
    systemctl enable nginx.service
    Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    :wq

    (九)、检查通过systemctl命令能否正常 启动、停止、重启、重载 Nginx 服务

    netstat -anutp |grep nginx
    killall -3 nginx
    systemctl start nginx
    netstat -anutp |grep nginx
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述
    在这里插入图片描述

    如果systemctl status nginx
    nginx不能开启,显示的是loaded 
    则需要killall -3 nginx
    或者killall -s QUIT nginx
    先关闭服务后再次systemctl start nginx即可。
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    在这里插入图片描述

    补充——systemctl enable nginx --now (开机自启服务并现在开启)
    开机自启服务并现在开启
    #systemctl enable nginx --now
    
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    3、安装MySQL服务

    (1)、安装Mysql环境依赖包

    yum -y install \
    ncurses \
    ncurses-devel \
    bison \
    cmake
    
    • 1
    • 2
    • 3
    • 4
    • 5
    yum -y install \
    ncurses \			#字符终端工具包  UTF-8
    ncurses-devel \		
    bison \				#函数库
    cmake
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    (2)、创建运行用户

    #useradd -s /sbin/nologin  mysql
    
    
    • 1
    • 2

    在这里插入图片描述

    (3)、编译安装

    上传mysql-boost-5.7.20.tar.gz到opt目录下

    cd /opt
    tar xzvf mysql-boost-5.7.20.tar.gz
    
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    在这里插入图片描述

    cd /opt/mysql-5.7.20/
    cmake \
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #指定安装路径(目录)
    -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \	#指定通信文件,连接数据库,通讯协议的载体
    -DSYSCONFDIR=/etc \	#配置文件目录指向/etc
    -DSYSTEMD_PID_DIR=/usr/local/mysql \	#指定pid目录文件
    -DDEFAULT_CHARSET=utf8 \	#字符集设定
    -DDEFAULT_COLLATION=utf8_general_ci \	#字符集设定
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \	#以下三行均为存储引擎ENGINE
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
    -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
    -DMYSQL_DATADIR=/usr/local/mysql/data \	#指定数据存放位置
    -DWITH_BOOST=boost \	#底层C++运营库 独立的表空间结构
    -DWITH_SYSTEMD=1	#守护进程id 守护进程 
    ——》跑在后台的一个支持服务正常运行的一个特殊进程
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    cmake \
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
    -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
    -DSYSCONFDIR=/etc \
    -DSYSTEMD_PID_DIR=/usr/local/mysql \
    -DDEFAULT_CHARSET=utf8 \
    -DDEFAULT_COLLATION=utf8_general_ci \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_ARCHIVE_STORAGE_ENGINE=1 \
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
    -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
    -DMYSQL_DATADIR=/usr/local/mysql/data \
    -DWITH_BOOST=boost \
    -DWITH_SYSTEMD=1 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    在这里插入图片描述

    make && make install #安装会比较长时间

    #make && make install #安装会比较长时间
    
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    (4)、数据库目录进行权限调整

    #chown -R mysql:mysql /usr/local/mysql/ 
    
    • 1

    在这里插入图片描述
    在这里插入图片描述

    (5)、调整配置文件

    vi /etc/my.cnf
    #删除原有内容,添加以下内容
    [client]					#client 用户程序
    port = 3306				
    default-character-set=utf8
    socket = /usr/local/mysql/mysql.sock
    
    [mysql]						#mysql 软件内容 
    port = 3306					#端口
    default-character-set=utf8
    socket = /usr/local/mysql/mysql.sock
    
    [mysqld]					#以后对mysql配置时 更多的会针对于mysqld进行配置
    user = mysql				#程序用户
    basedir = /usr/local/mysql	#工作目录
    datadir = /usr/local/mysql/data		#数据文件目录
    port = 3306					#端口
    character_set_server=utf8	#服务的字符集
    pid-file = /usr/local/mysql/mysqld.pid	#PID文件目录
    socket = /usr/local/mysql/mysql.sock	#通讯文件
    server-id = 1				#服务id,在之后的mysql集群中用于标识mysql服务器
    
    sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
    #模块,默认加载
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    在这里插入图片描述
    在这里插入图片描述

    (6)、设置环境变量

    echo 'PATH=$PATH:/usr/local/mysql/bin' >> /etc/profile
    echo 'export PATH' >> /etc/profile
    source /etc/profile
    
    • 1
    • 2
    • 3

    (7)、初始化数据库

    cd /usr/local/mysql/
    
    bin/mysqld \
    --initialize-insecure \
    --user=mysql \
    --basedir=/usr/local/mysql \
    --datadir=/usr/local/mysql/data
    
    cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述

    (8)、数据库开启自启、 关闭、状态

    systemctl enable mysqld
    systemctl start mysqld
    systemctl status mysqld
    netstat -anpt | grep 3306
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述
    在这里插入图片描述

    (9)、设置Mysql密码,登陆数据库

    #mysql -u root -p password
    #mysql -u root -p
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述

    4、安装配置 PHP 解析环境

    (1)、安装环境依赖包

    yum -y install \
    > libjpeg \						#jpg图片依赖
    > libjpeg-devel \
    > libpng libpng-devel \			#png图片依赖
    > freetype freetype-devel \		#字体
    > libxml2 \						#支持xml
    > libxml2-devel \
    > zlib zlib-devel \				#压缩格式
    > curl curl-devel \				#识别url
    > openssl openssl-devel
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    yum -y install \
    libjpeg \
    libjpeg-devel \
    libpng libpng-devel \
    freetype freetype-devel \
    libxml2 \
    libxml2-devel \
    zlib zlib-devel \
    curl curl-devel \
    openssl openssl-devel
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述
    在这里插入图片描述

    (2)、编译安装

    cd /opt
    tar xjvf php-7.1.10.tar.bz2
    cd php-7.1.10
    
    ./configure \
    --prefix=/usr/local/php \			#PHP文件路径
    --with-mysql-sock=/usr/local/mysql/mysql.sock \	#sock通讯文件(需要与mysql指定的路径一致)
    --with-mysqli \					#with(支持各项功能)
    --with-zlib \
    --with-curl \
    --with-gd \
    --with-jpeg-dir \
    --with-png-dir \
    --with-freetype-dir \
    --with-openssl \
    --enable-fpm \					#开启fpm模块	
    --enable-mbstring \				#开启多字段模块
    --enable-xml \					#开启扩展性标记语言模块
    --enable-session \				#会话
    --enable-ftp \					#文本传输协议
    --enable-pdo \					#函数库
    --enable-tokenizer \			#令牌解释器
    --enable-zip					#ZIP压缩格式
    
    make && make install
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    在这里插入图片描述
    在这里插入图片描述

    ./configure \
    --prefix=/usr/local/php \
    --with-mysql-sock=/usr/local/mysql/mysql.sock \
    --with-mysqli \
    --with-zlib \
    --with-curl \
    --with-gd \
    --with-jpeg-dir \
    --with-png-dir \
    --with-freetype-dir \
    --with-openssl \
    --enable-fpm \
    --enable-mbstring \
    --enable-xml \
    --enable-session \
    --enable-ftp \
    --enable-pdo \
    --enable-tokenizer \
    --enable-zip
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    在这里插入图片描述

    (3)、修改php的配置文件

    php.ini 核心配置文件
    php-fpm.conf 进程服务配置文件
    www.conf 扩展配置文件
    
    • 1
    • 2
    • 3
    cp php.ini-development /usr/local/php/lib/php.ini
    vi /usr/local/php/lib/php.ini
    
    修改1170行 mysqli.default_socket = /usr/local/mysql/mysql.sock
    修改939行 date.timezone = Asia/Shanghai
    
    /usr/local/php/bin/php -m #验证安装的模块
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述

    在这里插入图片描述
    在这里插入图片描述

    (4)、配置及优化FPM模块

    复制主配置文件及php-fpm 配置文件

    cd /usr/local/php/etc/
    cp  php-fpm.conf.default php-fpm.conf
    cd /usr/local/php/etc/php-fpm.d/
    cp www.conf.default www.conf
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    cd /usr/local/php/etc/
    vi php-fpm.conf
    #开启pid 支持(可运行)
    pid = run/php-fpm.pid
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    (5)、启动php -c 代表 conf

    /usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
    netstat -anpt | grep 9000
    
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    (6)、识别命令

    #ln -s /usr/local/php/bin/* /usr/local/bin/
    
    
    • 1
    • 2

    在这里插入图片描述

    (7)、查看php的进程

    #ps aux | grep -c "php-fpm"  
    
    • 1

    在这里插入图片描述

    (8)、让nginx支持PHP功能

    vi /usr/local/nginx/conf/nginx.conf
    修改45行 加上 index.php
    取消注释这一段,65-71行
    location ~ \.php$ {
                root           html;
                fastcgi_pass   127.0.0.1:9000;
                fastcgi_index  index.php;
                fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name; ####注意目录名称
                include        fastcgi_params;
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    在这里插入图片描述

    vi /usr/local/nginx/html/index.php
    <?php
    phpinfo();
    ?>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    在这里插入图片描述

    systemctl restart nginx
    
    
    • 1
    • 2

    在这里插入图片描述

    在网页测试“http://192.168.116.10/index.php”
    在这里插入图片描述

    (9)、测试数据库工作是否正常

    mysql -u root -p #输入abc123密码
    
    CREATE DATABASE bbs;
    GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
    GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
    flush privileges;
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    vi /usr/local/nginx/html/index.php
    #原来的测试页内容更改如下
    <?php
    $link=mysqli_connect('192.168.195.128','bbsuser','admin123');
    if($link) echo "

    Success!!

    "
    ; else echo "Fail!!"; ?> systemctl restart nginx
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    在网页测试“http://192.116.32.10/index.php”

    在这里插入图片描述

    5、LNMP应用部署

    部署 Discuz!社区论坛 Web 应用

    安装论坛
    cd /opt
    unzip Discuz_X3.4_SC_UTF8.zip  -d /tmp
    cd /tmp/dir_SC_UTF8/
    cp -r upload/ /usr/local/nginx/html/bbs/
    cd /usr/local/nginx/html/bbs/
    chown -R root:nginx ./config/
    chown -R root:nginx ./data/
    chown -R root:nginx ./uc_client/
    chown -R root:nginx ./uc_server/
    
    chmod -R 777 ./config/
    chmod -R 777 ./data/
    chmod -R 777 ./uc_client/
    chmod -R 777 ./uc_server/
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    在这里插入图片描述

    在这里插入图片描述

    http://192.168.116.10/bbs/install/index.php
    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    vim /usr/local/nginx/html/index.php可以看到库名、数据库用户名、数据库密码
    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    到此完成。

    5.1、NMP部署完成进行验证

    管理后台的页面
    http://192.168.116.10/bbs/admin.php?     #这是后台管理页面
    输入账号 密码
    
    • 1
    • 2

    总结

  • 相关阅读:
    Redis--list列表
    高效率的10进制转2进制(C版)
    小程序转App最便捷的方法,附实操
    实习记录(一):MySQL时间偏差问题的发现与解决
    c++ using用法之一
    Allegro输出带等长规则的Excel操作指导
    Jenkins入门级安装部署
    [组件笔记]7.UnityEngine.MonoBehaviour
    npm install / webdriver-manager update报错 unable to get local issuer certificate
    微宏科技基于 KubeSphere 的微服务架构实践
  • 原文地址:https://blog.csdn.net/zhou641694375/article/details/126490601