FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速

本文主要是介绍FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

目录

前言

一. 源码包下载

1. FFmpeg源码下载

2. MSYS2安装

  2.1 执行下面命令配置环境

  2.2 安装完成后将MSYS2安装路径下的mingw64/bin配置到windows环境变量中

  2.3 安装其他工具( 默认全部安装 ):

3. 安装CMake工具

  3.1 将CMake加入环境变量

4. 下载x264,x265

  4.1 x264源码下载:

  4.2 x265源码下载(直接git):

二. 开始编译

1. 编译x264

2. 编译x265

3. 编译FFmpeg

三. 功能验证

1. x264验证

2. x265验证

3. FFmpeg验证

四. FFmpeg支持 Intel,Nvidia,AMD 硬件加速

1. 支持Intel QSV硬件加速

2. 支持 Nvidia nvenc,cuda,cuvid 硬件加速

3. AMD amf 硬件加速支持

4. 完整的 build-ffmpeg.sh 脚本文件代码

五. 硬件加速功能测试

1. Intel QSV 硬件加速编解码测试

2. Nvidia 硬件加速测试

3. AMD 硬件加速测试

六. 可能存在的问题

1. 可能缺少某些依赖库

2. 如何查看我们编译好的 FFmpeg 依赖哪些库?

3. Nvidia 部分依赖库 libnpp 支持

4. Error: operand type mismatch for `shr'

参考博客链接


前言

        最近完成了 FFmpeg 在 Windows 环境下的编译工作,在查询了大量的官方文档和牛人博客,并且踩了N多坑后,总结出了比较完善的编译方式。

一. 源码包下载

1. FFmpeg源码下载

下载地址: FFmpeg

2. MSYS2安装

下载地址:MSYS2

  2.1 执行下面命令配置环境

pacman -Syu

输入y选择全部更新,更新完成后再次执行

pacman -Syu

安装基础工具(默认全部安装):

pacman -S base-devel

安装编译工具(默认全部安装):

pacman -S mingw-w64-x86_64-toolchain

如果是要编译32位的FFmpeg,则需要在MSYS的MinGW32里运行如下命令:

pacman -S mingw-w64-i686-toolchain

  2.2 安装完成后将MSYS2安装路径下的mingw64/bin配置到windows环境变量中

  2.3 安装其他工具( 默认全部安装 ):

pacman -S yasm
pacman -S nasm
pacman -S make

3. 安装CMake工具

CMake下载地址:Download | CMake

  3.1 将CMake加入环境变量

安装完成之后我们在 msys2 中是找不到 cmake 命令的,这里我们把 windows path 添加到 msys2 中。在 windows 环境变量中新建一个名为 MSYS2_PATH_TYPE 的环境变量,值改为 inherit,然后重启msys2就可以在msys2中使用安装的cmake了。

4. 下载x264,x265

  4.1 x264源码下载

  下载地址:x264

  4.2 x265源码下载(直接git):

  下载地址:

git clone https://bitbucket.org/multicoreware/x265_git.git

二. 开始编译

1. 编译x264

(1)把下载的x264源码包解压到msys64的home目录下,即 c/msys64/home/xxx (这里的xxx是用户名)

(2)进入x264源码目录中新建脚本 build-x264.sh ,脚本内容如下:

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)echo ${basepath}
cd ${basepath}pwd
./configure --prefix=${basepath}/x264_install --enable-static --enable-shared \
--extra-ldflags=-Wl,--output-def=libx264.def
make -j8
make install

在msys2中执行脚本文件:

sh build-x264.sh

等待编译完成后,在x264_install下会生成动态库,头文件和静态库

bin 中存放的是动态库

include 中存放的是头文件

lib 中存放的是静态库,给后面 FFmpeg 链接使用

假如我们需要使用动态库的话,还缺少一个 .lib 文件

.lib 文件可以由 .dll 直接生成,也可以由 .def 生成,这里我们可以用 .def 文件生成,在x264源码目录下有生成 libx264.def 文件

把 libx264.def 拷贝到和 libx264-164.dll 同一级目录下

然后打开VS命令行工具:

进入 VC\Tools\MSVC\14.29.30133(这里根据实际情况来,按tab可自动填充)\bin\Hostx64\x64

执行命令:

lib.exe /out:输出.lib的路径加文件名 /machine:x64 /def:输入def文件的路径和文件名

如:

lib.exe /out:C:\msys64\home\Administrator\x264-master\x264_install\bin\libx264-164.lib /machine:x64 /def:C:\msys64\home\Administrator\x264-master\x264_install\bin\libx264.def

执行成功后,如下图所示:

执行完成后在 x264_install/bin 目录中就会生成 .lib 文件

2. 编译x265

 (1)在msys中进入 x265_git/build/msys 下,执行下面命令生成 makefile:

cd x265_git/build/msys

sh make-Makefiles.sh

在弹出的窗口中先修改安装路径,然后点击configure,再点 generate 生成 makefile,最后关闭窗口

(2)开始编译

make -j8

(3)安装

make install

编译和安装完成后,在 x265_git/x265_install/bin 目录中就可以看到生成的文件了

 

3. 编译FFmpeg

(1)把下载好的FFmpeg源码包解压到msys2中的 home/xxx 目录下

(2)进入FFmpeg源码包,新建脚本 build-ffmpeg.sh ,脚本内容如下:

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)echo ${basepath}
cd ${basepath}#添加x264 x265的pkg路径
x264_pkg_path=/home/Administrator/x264-master/x264_install/lib/pkgconfig
x265_pkg_path=/home/Administrator/x265_git/x265_install/lib/pkgconfig
export PKG_CONFIG_PATH=$x264_pkg_path:$x265_pkg_path:$PKG_CONFIG_PATH./configure --prefix=${basepath}/ffmpeg_5.1.3_install --disable-static --enable-shared \
--enable-libx264 --enable-libx265 --enable-gpl
make -j8
make install

(3)然后在msys2中进入 FFmpeg 源码包目录下执行脚本:

sh build-ffmpeg.sh

等待编译完成后,就可以在 ffmpeg_5.1.3_install 中看到生成了以下目录:

三. 功能验证

1. x264验证

进入 x264-master/x264_install/bin 目录下,执行下面命令,如果能够输出版本信息,说明正常

./x264.exe --version

2. x265验证

进入 x265_git/x265_install/bin 目录下,执行下面命令,如果能够得到版本信息,说明正常

./x265.exe --version

3. FFmpeg验证

(1)需要把x264和x265生成的动态库bin目录中的文件全部拷贝到 FFmpeg 生成目录的bin中。(和ffmpeg.exe同一级目录,因为编译好的 FFmpeg 依赖于它们的 dll 库)

(2)msys2中进入 ffmpeg_5.1.3_install/bin 目录下,执行以下命令,如果能够输出版本信息,则说明正常

./ffmpeg.exe -version

四. FFmpeg支持 Intel,Nvidia,AMD 硬件加速

1. 支持Intel QSV硬件加速

(1)首先从 github 上下载 mfx_dispatch,通过这个生成 libmfx

mfx_dispatch 下载网址: mfx_dispatch

(2)进入下载好的 mfx_dispatch源码包中,用Notepad++打开Makefile.am文件,将下面四个 *.a 改为 *.la

修改完后记得保存并关闭 Makefile.am 文件

(3)打开msys, 执行以下命令

cd mfx_dispatch

pacman -S automake

然后再 autoupdate

autoupdate

这样就可以下载autoreconf 了

autoreconf --install

然后再执行下面的命令安装一些包:

pacman -S perl
pacman -S libtool
pacman -S pkg-config

接下来重命名 /usr/bin/link.exe , 避免冲突

cd /usr/bin
mv link.exe link.bak

如果提示如下信息,则不用理会,继续执行后面的操作

which cl link yasm cpp

执行上面命令后如果没有找到cl,link,则代表是VS

然后重新进入 mfx_dispatch 目录

执行以下命令生成 libmfx ,--prefix 是指定 libmfx 生成在哪个目录,--host 是指定用什么编译器

autoreconf -i
./configure --prefix=/c/msys64/home/Administrator/libmfx --host=x86_64-w64-mingw32
make -j
make install

PS:如果要编译32位的FFmpeg,则应该修改 --host 的值

--host=i686-w64-mingw32

安装完毕后,你就能看到生成的 libmfx 目录了

(4)接下来我们进入 FFmpeg 目录,将 build-ffmpeg.sh 脚本文件修改为支持 libmfx

然后在msys中进入 FFmpeg 源码包下执行脚本文件 build-ffmpeg.sh

等待编译完成后,我们在msys中进入 ffmpeg_5.1.3_install/bin 目录,执行以下命令就可以看到FFmpeg已经支持 Intel QSV 硬件加速了

./ffmpeg.exe -hwaccels

2. 支持 Nvidia nvenc,cuda,cuvid 硬件加速

(1)集成Nvidia硬件加速需要先下载 nv-codec-headers 和 CUDA Toolkit

        nv-codec-headers 历史版本下载地址:https://github.com/FFmpeg/nv-codec-headers/releases

        CUDA Toolkit 历史版本下载地址:CUDA Toolkit Archive | NVIDIA Developer

        本文选择的 nv-codec-headers 版本是:9.1.23.3

        本文选择的 CUDA Toolkit 版本是:10.1-update2

(2)下载完CUDA Toolkit后进行安装,安装选项选择自定义

安装完毕后,在CMD窗口输入 nvcc -V 显示如下信息则表示安装成功

(3)安装完成后,在 c/msys64/usr/local/include 下新建一个目录 nv_sdk_10.1 用来存放头文件。

把 C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\include 下面所有的头文件复制到 nv_sdk_10.1 目录

如下:

把 ​​ C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\lib\x64​​  里面所有的 lib 库全部复制到  c/msys64/​​usr/local/lib/x64 下

如下:

(4)下载好 nv-codec-headers 后,我们在msys中进入 nv-codec-headers ,执行命令

make && make install

如图所示:

执行完上述命令后,我们在 c/msys64/usr/local/include 中可以看到生成的 ffnvcodec 文件夹

(5)接下来我们修改 build-ffmpeg.sh 脚本文件,添加支持 nvenc,cuda和cuvid 的配置

修改完成后,我们在msys中进入 FFmpeg 源码目录,执行脚本文件

 

等待编译完成后,我们进入 ffmpeg_5.1.3_install/bin 目录下,执行命令

./ffmpeg.exe -hwaccels

可以看到 FFmpeg 已经支持 Nvidia 的硬件加速了

3. AMD amf 硬件加速支持

(1)AMF声明文件下载:AMF

下载完成后,在 c/msys64/usr/local/include 目录下新建 AMF文件夹,将下载文件的 AMF/amf/public/include 下的两个文件夹复制到刚才新建的AMF文件夹中,如图所示:

(2)接下来修改 build-ffmpeg.sh 脚本文件,添加支持 amf

修改完成后,在msys中进入 FFmpeg 源码目录,执行脚本

(3)等待编译完成后,可以看到 FFmpeg 已经支持 AMD 的 amf 硬件加速了

4. 完整的 build-ffmpeg.sh 脚本文件代码

#!/bin/sh
basepath=$(cd `dirname $0`;pwd)
echo ${basepath}
cd ${basepath}#添加x264 x265的pkg路径
x264_pkg_path=/home/Administrator/x264-master/x264_install/lib/pkgconfig
x265_pkg_path=/home/Administrator/x265_git/x265_install/lib/pkgconfig
mfx_pkg_path=/home/Administrator/libmfx/lib/pkgconfig
ffnvcodec_pkg_path=/usr/local/lib/pkgconfig
export PKG_CONFIG_PATH=$x264_pkg_path:$x265_pkg_path:$mfx_pkg_path:$ffnvcodec_pkg_path:$PKG_CONFIG_PATH#Intel
#Nvidia
#AMD  
./configure --prefix=${basepath}/ffmpeg_5.1.3_install --disable-static --enable-shared \
--enable-libx264 --enable-libx265 --enable-gpl \
--enable-libmfx --enable-encoder=h264_qsv --enable-decoder=h264_qsv \
--enable-nonfree --enable-ffnvcodec --enable-libnpp --arch=x86_64 --enable-postproc --enable-nvenc --enable-cuda --enable-cuvid --enable-encoder=h264_nvenc --enable-decoder=h264_cuvid \
--enable-amf \
--extra-cflags=-I/c/msys64/home/Administrator/libmfx/include --extra-ldflags=-L/c/msys64/home/Administrator/libmfx/lib \
--extra-cflags=-I/usr/local/include/ffnvcodec \
--extra-cflags=-I/usr/local/include/nv_sdk_10.1 --extra-ldflags=-L/usr/local/lib/x64 \
--extra-cflags=-I/usr/local/include --extra-ldflags=-L/usr/local/lib
make -j8
make install

五. 硬件加速功能测试

1. Intel QSV 硬件加速编解码测试

(1)准备一个命名为 input.mp4 的视频放到 ffmpeg_5.1.3_install/bin 目录下,如图:

(2)在msys中进入 ffmpeg_5.1.3_install/bin 目录下运行以下命令,可以看到在同目录下生成了相应的名为 h264_qsv_output.mp4 的视频

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_qsv -c:a copy h264_qsv_output.mp4

若视频能正常打开,则说明Intel QSV硬件加速编解码成功

2. Nvidia 硬件加速测试

同理,运行以下命令,若生成的视频能正常打开,则说明编解码成功

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_nvenc -c:a copy h264_nvenc_output.mp4

3. AMD 硬件加速测试

同理,运行以下命令,若生成的视频能正常打开,则说明编解码成功

./ffmpeg.exe -i input.mp4 -b:v 2000k -c:v h264_amf -c:a copy h264_amf_output.mp4

PS:特别注意!!!以上命令需要在各自硬件支持或驱动支持的情况下才能正常生成视频!

六. 可能存在的问题

1. 可能缺少某些依赖库

我们编译好的 FFmpeg 可能依赖某些dll库,如果我们打包的时候没有把这些dll库放到 ffmpeg_5.1.3_install/bin 目录下,在其他环境下运行 ffmpeg.exe 时可能会报类似于下面的错误:

一种解决办法是可以在FFmpeg源码的 configure 文件中看哪些库可以在脚本文件中disable,不过有三个基本的库是在 configure 里没有禁掉选项的,这时我们就需要把这几个库复制到ffmpeg_5.1.3_install/bin 目录下。

这几个dll库都可以在 C:\msys64\mingw64\bin 里面找到。

2. 如何查看我们编译好的 FFmpeg 依赖哪些库?

编译好的FFmpeg有两个最重要的dll库, avcodec-59.dll 和 avutil-57.dll  而这两个库可以在 dumpbin 里面查看它们依赖哪些库。

我们可以在VS命令行工具里面运行以下 dumpbin 命令查看依赖库

先 cd C:\msys64\home\Administrator\ffmpeg-5.1.3\ffmpeg_5.1.3_install\bin

然后执行以下命令:

dumpbin -imports avcodec-59.dll

查看avcodec-59.dll 依赖于哪些库后, 再查看一下 avutil-57.dll 依赖哪些库。把除了系统库之外一些能找到的 dll 库放到 ffmpeg_5.1.3_install/bin 中即可。

3. Nvidia 部分依赖库 libnpp 支持

如果我们编译脚本时,加入了 --enable-libnpp 选项,则可能还需要 libnpp 这几个库

而上面的这几个库在 C:\Program Files\NVIDIA GPU Computing Toolkit\CUDA\v10.1\bin 下,我们把它们复制到 ffmpeg_5.1.3_install\bin 中就好了

总结就是,缺少哪些库,我们就把这些库放到 ffmpeg_5.1.3_install/bin 目录下,或者看看能不能直接在编译的时候就 disable

4. Error: operand type mismatch for `shr'

      在使用 13.2.0 或以上版本的gcc编译 FFmpeg 时可能会出现这个问题,这是汇编代码中存在类型不匹配的错误导致的,如下:

C:\msys64\tmp\ccUxvBjQ.s: Assembler messages:
C:\msys64\tmp\ccUxvBjQ.s:345: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:410: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:470: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:645: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:713: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:781: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:866: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:951: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1036: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1133: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1405: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1514: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1638: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:1797: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2137: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2242: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2368: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2553: Error: operand type mismatch for `shr'
C:\msys64\tmp\ccUxvBjQ.s:2703: Error: operand type mismatch for `shr'
make: *** [ffbuild/common.mak:60: libavformat/adtsenc.o] Error 1
make 编译过程中的出现上面错误

我这里之前使用13.1.0 版本的gcc时没有这个问题,更新到13.2.0后编译就报这个错误了,但是msys2的gcc版本又不能回退,所以我们现在编译FFmpeg时需要修改FFmpeg的源码:

首先,找到FFmpeg源码中的mathops.h文件,具体路径如下:

我这里是在  ffmpeg-5.0.3/libavcodec/x86/mathops.h

然后修改mathops.h中以下几个函数的定义(将 ci 改为 c):

#define MULL MULL
static av_always_inline av_const int MULL(int a, int b, unsigned shift)
{int rt, dummy;__asm__ ("imull %3               \n\t""shrdl %4, %%edx, %%eax \n\t":"=a"(rt), "=d"(dummy)//:"a"(a), "rm"(b), "ci"((uint8_t)shift):"a"(a), "rm"(b), "c"((uint8_t)shift));return rt;
}
#define NEG_SSR32 NEG_SSR32
static inline  int32_t NEG_SSR32( int32_t a, int8_t s){__asm__ ("sarl %1, %0\n\t": "+r" (a)//: "ci" ((uint8_t)(-s)): "c" ((uint8_t)(-s)));return a;
}
#define NEG_USR32 NEG_USR32
static inline uint32_t NEG_USR32(uint32_t a, int8_t s){__asm__ ("shrl %1, %0\n\t": "+r" (a)//: "ci" ((uint8_t)(-s)): "c" ((uint8_t)(-s)));return a;
}

修改完成后保存并关闭文件,然后重新编译FFmpeg应该就能解决上述问题了

参考博客链接

1. ffmpeg5.0+h264+h265 windows下编译ffmpeg-5.0.1支持x265编解码_老吕丶的博客-CSDN博客​​​​​

2. windows下编译FFMPEG开启硬件加速(INTEL,NVIDIA,AMD)selivert的博客-CSDN博客

3. FFmpeg引入NVIDIA硬件编解码扩展_mb628cd5266c9eb的技术博客_51CTO博客

4. 音视频开源基础学习 – 编译ffmpeg(音视频开发进阶) | 半码博客

5. ffmpeg编译 Error: operand type mismatch for `shr‘

这篇关于FFmpeg在 Windows 环境编译(64位)支持h264,h265,和Intel QSV,Nvidia Cuda,AMD amf 硬件加速的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/719036

相关文章

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压