versions.rst 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. ESP-IDF 版本简介
  2. ================
  3. :link_to_translation:`en:[English]`
  4. ESP-IDF 的 GitHub 仓库时常更新,特别是用于开发新特性的 master 分支。
  5. 如有量产需求,请使用稳定版本。
  6. 发布版本
  7. ---------
  8. 您可以通过以下链接访问各个版本的配套文档:
  9. * 最新稳定版 ESP-IDF:https://docs.espressif.com/projects/esp-idf/zh_CN/stable/
  10. * 最新版 ESP-IDF(即 master 分支):https://docs.espressif.com/projects/esp-idf/zh_CN/latest/
  11. ESP-IDF 在 GitHub 平台上的完整发布历史请见 `发布说明页面`_。您可以在该页面查看各个版本的发布说明、配套文档及相应获取方式。
  12. 此外,您还可以直接前往文档页面,查看部分 ESP-IDF 版本的配套文档,具体可通过点击页面左下角的小三角标志,在不同版本间切换。
  13. .. image:: /../_static/choose_version.png
  14. 我该选择哪个版本?
  15. ----------------------------------
  16. - 如有量产需求,请使用 `最新稳定版本`_ 。稳定版本已通过人工测试,后续更新仅修复 bug,主要特性不受影响(更多详情,请见 `版本管理`_ )。请访问 `发布说明页面`_ 界面查看每一个稳定发布版本。
  17. - 如需尝试/测试 ESP-IDF 的最新特性,请使用 `最新版本(在 master 分支上) <https://docs.espressif.com/projects/esp-idf/zh_CN/latest/>`_。最新版本包含 ESP-IDF 的所有最新特性,已通过自动化测试,但尚未全部完成人工测试(因此存在一定风险)。
  18. - 如需使用稳定版本中没有的新特性,但同时又不希望受到 master 分支更新的影响,您可以将一个最适合您的稳定版本 :ref:`更新至一个预发布版本` 或 :ref:`更新至一个发布分支`。
  19. 有关如何更新 ESP-IDF 本地副本的内容,请参考 :ref:`updating` 章节。
  20. 版本管理
  21. -----------------
  22. ESP-IDF 采用了 `语义版本管理方法 <http://semver.org/>`_,即您可以从字面含义理解每个版本的差异。其中
  23. - 主要版本(例 ``v3.0``)代表有重大更新,包括增加新特性、改变现有特性及移除已弃用的特性。
  24. 升级至一个新的主要版本(例 ``v2.1`` 升级至 ``v3.0``)意味着您可能需要更新您的工程代码,并重新测试您的工程,具体可参考 `发布说明页面`_ 的重大变更 (Breaking Change) 部分。
  25. - 次要版本(例 ``v3.1``)代表有新增特性和 bug 修复,但现有特性不受影响,公开 API 的使用也不受影响。
  26. 升级至一个新的次要版本(例 ``v3.0`` 升级至 ``v3.1``)意味着您可能不需要更新您的工程代码,但需重新测试您的工程,特别是 `发布说明页面`_ 中专门提到的部分。
  27. - Bugfix 版本(例 ``v3.0.1``)仅修复 bug,并不增加任何新特性。
  28. 升级至一个新的 Bugfix 版本(例 ``v3.0`` 升级至 ``v3.0.1``)意味着您不需要更新您的工程代码,仅需测试与本次发布修复 bug(列表见 `发布说明页面`_)直接相关的特性。
  29. 支持期限
  30. ---------------
  31. ESP-IDF 的每个主要版本和次要版本都有相应的支持期限。支持期限满后,版本停止更新维护,将不再支持。
  32. `支持期限政策`_ 对此有具体描述,并介绍了每个版本的支持期限是如何界定的。
  33. `发布说明页面`_ 界面上的每一个发布版本都提供了该版本的支持期限信息。
  34. 一般而言:
  35. - 如您刚开始一个新项目,建议使用最新稳定版本。
  36. - 如您有 GitHub 账号,请点击 `发布说明页面`_ 界面右上角的 "Watch" 按键,并选中 "Releases only" 选项。GitHub 将会在新版本发布的时候通知您。当您所使用的版本有 bugfix 版本发布时,请做好升级至该 bugfix 版本的规划。
  37. - 如可能,请定期(如每年一次)将项目的 IDF 版本升级至一个新的主要版本或次要版本。对于小版本更新,更新过程应该比较简单,但对于主要版本更新,可能需要细致查看发布说明并做对应的更新规划。
  38. - 请确保您所使用的版本停止更新维护前,已做好升级至新版本的规划。
  39. 查看当前版本
  40. ----------------------------
  41. 查看 ESP-IDF 本地副本的版本,请使用 idf.py 命令::
  42. idf.py --version
  43. 此外,由于 ESP-IDF 的版本也已编译至固件中,因此您也可以使用宏 ``IDF_VER`` 查看 ESP-IDF 的版本(以字符串的格式)。ESP-IDF 默认引导程序会在设备启动时打印 ESP-IDF 的版本。请注意,在 GitHub 仓库中的代码更新时,代码中的版本信息仅会在源代码重新编译或在清除编译时才会更新,因此打印出来的版本可能并不是最新的。
  44. 几个 ESP-IDF 版本的例子:
  45. =============================== ===================================================================================================
  46. 版本字符串 含义
  47. =============================== ===================================================================================================
  48. ``v3.2-dev-306-gbeb3611ca`` | master 分支上的预发布版本。
  49. | - ``v3.2-dev``:为 v3.2 进行的开发。
  50. | - ``306``:v3.2 开发启动后的 commit 数量。
  51. | - ``beb3611ca``:commit 标识符。
  52. ``v3.0.2`` 稳定版本,标签为 ``v3.0.2``。
  53. ``v3.1-beta1-75-g346d6b0ea`` | v3.1 的 beta 测试版本(可参考 :ref:`更新至一个发布分支`)。
  54. | - ``v3.1-beta1`` - 预发布标签。
  55. | - ``75``:添加预发布 beta 标签后的 commit 数量。
  56. | - ``346d6b0ea``:commit 标识符。
  57. ``v3.0.1-dirty`` | 稳定版本,标签为 ``v3.0.1``。
  58. | - ``dirty`` 代表 ESP-IDF 的本地副本有修改。
  59. =============================== ===================================================================================================
  60. Git 工作流
  61. ------------
  62. 乐鑫 ESP-IDF 团队的 (Git) 开发工作流程如下:
  63. - 新的改动总是在 master 分支(最新版本)上进行。master 分支上的 ESP-IDF 版本总带有 ``-dev`` 标签,表示“正在开发中”,例 ``v3.1-dev``。
  64. - 这些改动将首先在乐鑫的内部 Git 仓库进行代码审阅与测试,而后在自动化测试完成后推至 GitHub。
  65. - 新版本一旦完成特性开发(在 ``master`` 分支上进行)并达到进入 beta 测试的标准,则将该版本签出至一个新分支(例 ``release/v3.1``)。此外,该分支还打上预发布标签(例 ``v3.1-beta1``)。您可以在 GitHub 平台上查看 ESP-IDF 的完整 `分支列表`_ 和 `标签列表`_。Beta 预发布版本可能仍存在大量“已知问题”(Known Issue)。
  66. - 随着对 beta 版本的不断测试,bug 修复将同时增加至该发布分支和 ``master`` 分支。而且,``master`` 分支可能也已经开始为下个版本开发新特性了。
  67. - 当测试快结束时,该发布分支上将增加一个 rc 标签,代表候选发布 (Release Candidate) ,例 ``v3.1-rc1``。此时,该分支仍属于预发布版本。
  68. - 如果一直未发现或报告重大 bug,则该预发布版本将最终增加“主要版本”(例 ``v4.0``)或“次要版本”标记(例 ``v3.1``),成为正式发布版本,并体现在 `发布说明页面`_ 。
  69. - 后续,该版本中发现的 bug 都将在该发布分支上进行修复。人工测试完成后,该分支将增加一个 bugfix 版本标签(例 ``v3.1.1``),并体现在 `发布说明页面`_ 。
  70. .. _updating:
  71. 更新 ESP-IDF
  72. ----------------
  73. 请根据您的实际情况,对 ESP-IDF 进行更新。
  74. - 如有量产用途,建议参考 :ref:`更新至一个稳定发布版本`。
  75. - 如需测试/研发/尝试最新特性,建议参考 :ref:`更新至 master 分支` 。
  76. - 两者折衷建议参考 :ref:`更新至一个发布分支`。
  77. .. note:: 在参考本指南时,请首先获得 ESP-IDF 的本地副本,具体步骤请参考 :doc:`入门指南 </get-started/index>` 中的介绍。
  78. .. _`更新至一个稳定发布版本`:
  79. 更新至一个稳定发布版本
  80. ^^^^^^^^^^^^^^^^^^^^^^^^^^
  81. (推荐量产用户)如需更新至一个新的 ESP-IDF 发布版本,请参考以下步骤:
  82. - 请定期查看 `发布说明页面`_ ,了解最新发布情况。
  83. - 如有新发布的 bugfix 版本(例 ``v3.0.1`` 或 ``v3.0.2``)时,请将新的 bugfix 版本更新至您的 ESP-IDF 目录:
  84. .. code-block:: bash
  85. cd $IDF_PATH
  86. git fetch
  87. git checkout vX.Y.Z
  88. git submodule update --init --recursive
  89. - 如有主要版本或次要版本新发布时,请查看发布说明中的具体描述,并决定是否升级您的版本。具体命令与上方描述一致。
  90. .. note:: 如果您之前在安装 ESP-IDF 时使用了 zip 文件包,而非通过 Git 命令,则您将无法使用 Git 命令进行版本升级,此属正常情况。这种情况下,请重新下载最新 zip 文件包,并替换掉之前 ``IDF_PATH`` 下的全部内容。
  91. .. _`更新至一个预发布版本`:
  92. 更新至一个预发布版本
  93. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  94. 您也可以将您的本地副本签出(命令 ``git checkout``)至一个预发布版本或 rc 版本,具体方法请参考 :ref:`更新至一个稳定发布版本` 中的描述。
  95. 预发布版本通常不体现在 `发布说明页面`_。更多详情,请查看完整 `标签列表`_。使用预发布版本的注意事项,请参考 :ref:`更新至一个发布分支` 中的描述。
  96. .. _`更新至 master 分支`:
  97. 更新至 master 分支
  98. ^^^^^^^^^^^^^^^^^^^^^^^^^
  99. .. note:: ESP-IDF 中 master 分支上的代码会时时更新,因此使用 master 分支相当在“流血的边缘试探”,存在一定风险。
  100. 如需使用 ESP-IDF 的 master 分支,请参考以下步骤:
  101. - 本地签出至 master 分支::
  102. cd $IDF_PATH
  103. git checkout master
  104. git pull
  105. git submodule update --init --recursive
  106. - 此外,您还应在后续工作中不时使用 ``git pull`` 命令,将远端 master 上的更新同步到本地。注意,在更新 master 分支后,您可能需要更改项代码,也可能遇到新的 bug。
  107. - 如需从 master 分支切换至一个发布分支或稳定版本,请使用 ``git checkout`` 命令。
  108. .. important:: 强烈建议您定期使用 ``git pull`` 和 ``git submodule update --init --recursive`` 命令,确保本地副本的及时更新。旧的 master 分支相当于一个“快照”,可能存在未记录的问题,且无法获得支持。对于半稳定版本,请参考 :ref:`更新至一个发布分支`。
  109. .. _`更新至一个发布分支`:
  110. 更新至一个发布分支
  111. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  112. 从稳定性来说,使用“发布分支”相当于在使用 master 分支和稳定版本之间进行折衷,包含一些 master 分支上的新特性,但也同时保证可通过 beta 测试且基本完成了 bug 修复。
  113. 更多详情,请前往 GitHub 查看完整 `标签列表`_。
  114. 举例,您可以关注 ESP-IDF v3.1 分支,随时关注该分支上的 bugfix 版本发布( 例 ``v3.1.1`` 等)::
  115. cd $IDF_PATH
  116. git fetch
  117. git checkout release/v3.1
  118. git pull
  119. git submodule update --init --recursive
  120. 您每次在该分支上使用 ``git pull`` 时都相当于把最新的 bugfix 版本发布更新至您的本地副本中。
  121. .. note:: 发布分支并不会有专门的配套文档,建议您使用与本分支最接近的版本。
  122. .. _`发布说明页面`: http://github.com/espressif/esp-idf/releases
  123. .. _`分支列表`: https://github.com/espressif/esp-idf/branches
  124. .. _`标签列表`: https://github.com/espressif/esp-idf/tags
  125. .. _`最新稳定版本`: https://docs.espressif.com/projects/esp-idf/zh_CN/stable/
  126. .. _`支持期限政策`: https://github.com/espressif/esp-idf/blob/master/SUPPORT_POLICY_CN.md
  127. .. _`版本管理`: https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/versions.html