ESP32/8266开发环境超详细安装步骤
cac55 2025-05-21 12:14 17 浏览 0 评论
本文详细阐述了本站视频“[ESP32/8266]超详细的开发环境搭建说明”中所介绍的步骤和执行的命令,也包含了安装过程中可能出现的错误和解决方法!值得你细品。
视频中介绍了ESP8266开发环境建议使用Linux环境,因为真的比其windows平台开发工具快很多,很多,很多!!!
所以我们需要有一点点Linux基础,当然你非要用Windows平台,那么请忽略本文~
对了。视频中没有介绍ESP32的开发环境搭建,但是我在本文中有介绍。因为都是在Linux下搭建,所以建议你学着搭建一下Linux虚拟机,然后就可以选择安装ESP32或者ESP8266开发环境了。
Linux开发环境搭建
在windows电脑上安装一个Ubuntu Server(Linux)虚拟机(VirtualBox + Ubuntu Server)
- VirtualBox 6.1.20 官方下载地址:https://www.virtualbox.org/wiki/Downloads
- Ubuntu Server 20.04.2 LTS 官方下载地址:https://cn.ubuntu.com/download
安装Ubuntu服务器版本的主要目的是把它当成ESP开发服务器使用,方便多人使用,而且体积也小很多。
我们可通过SSH客户端工具Putty或者SecureCRT连接,使用命令行进行程序安装,编译等工作。免得在Ubuntu里操作,省心些,毕竟我们还不习惯在Ubuntu系统里做事情嘛。
Ubuntu虚拟机安装没啥说的,从官方途径下载文件后,按照视频介绍安装即可。
安装虚拟机增强包
Ubuntu虚拟机安装完后,一般都需要安装虚拟机增强包。它可以帮助虚拟机与主机建立文件共享,方便文件传输!好用的功能!必须装上!
如果出现了上面的错误,不用管。按照下面的方法继续安装
1.挂载cdrom(增强包镜像光盘)
所需命令如下:
sudo mount /dev/cdrom /mnt/
mount: /mnt: WARNING: device write-protected, mounted read-only.
2.执行脚本安装
进入已挂载的光盘,执行安装脚本
cd /mnt
ls
AUTORUN.INF TRANS.TBL VBoxWindowsAdditions-x86.exe
autorun.sh VBoxLinuxAdditions.run
cert VBoxSolarisAdditions.pkg
/* VBoxLinuxAdditions.run 是适合于我们的系统的安装脚本文件执行*/
sudo ./VBoxLinuxAdditions.run
reboot
内容如下
安装成功后,重启系统,就可以去配置共享文件夹了
并通过如下命令挂载所配置的共享目录
sudo mkdir /mnt/myesp
sudo mount -t vboxsf myesp /mnt/myesp
下载安装免费SSH客户端工具-PuTTY
在Ubuntu虚拟机安装完成后,就可以使用该工具访问Ubuntu系统进行接下来的操作了。方便快捷!
- PuTTY官方地址:https://www.chiark.greenend.org.uk/~sgtatham/putty/
SecureCRT这个工具更好用些,但是收费!
Linux服务器安装成功后,接下来就可以安装ESP8266开发环境了,想安装ESP32开发环境的同学直接下拉到后面去看吧!
1. 安装开发工具包
使用下面的命令,一次性安装所有的工具包
sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0 libncurses5-dev lrzsz
由于版本一直在更新,建议参考一下官方安装指导
- https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/get-started/linux-setup.html
但是 “ libncurses5-dev lrzsz ”这两个工具最好都一起安装
2. 下载ESP8266编译工具
进入官方页面查看最新工具
- https://github.com/espressif/ESP8266_RTOS_SDK.git
从官方页面提供的资料来看,ESP8266 最新版本的编译工具链目前是v8.4.0版本(截至视频发布时间。可能已经更新了,你可以从官方途径下载最新的版本)
下载编译工具
//下载
wget https://dl.espressif.com/dl/xtensa-lx106-elf-gcc8_4_0-esp-2020r3-linux-amd64.tar.gz
//解压其到当前文件夹
tar -zvxf xtensa-lx106-elf-gcc8_4_0-esp-2020r3-linux-amd64.tar.gz
//修改其权限为777
sudo chmod 777 -R xtensa-lx106-elf
3. 下载ESP8266 SDK
git clone --recursive https://github.com/espressif/ESP8266_RTOS_SDK.git
4. 设置环境变量
环境配置很简单,就是设置2个变量即可!先拿到刚才下载的编译工具链路径和SDK路径!以我的环境为例,如下:
export PATH=$PATH:/home/esp/tools/xtensa-lx106-elf/bin
export IDF_PATH=/home/esp/ESP8266_RTOS_SDK
设置步骤:
- 打开文件后按下 i 表示添加内容: vim ~/.bashrc
- 在文件空处添加上述的2个变量即可
- 按下esc 键,再 :wq 表示写入保存,并执行命令使配置生效: source ~/.bashrc
- 测试工具链环境是否设置成功: xtensa-lx106-elf-gcc -v
- 测试IDF_PATH路径是否设置成功: echo $IDF_PATH
5. 编译例程代码
拷贝SDK中的例程“hello_world”到自定义目录中,以我的为例,如下
cp ESP8266_RTOS_SDK/examples/get-started/hello_world/ ./ -a
进入该hello_world目录,执行命令:
make menuconfig
进行配置。配置可默认,大概看一下,然后退出保存即可。
可能遇到的错误和解决办法
1. 提示错误:/usr/bin/env: ‘python’: No such file or directory
解决办法:可将系统安装的python3做一个软链接
sudo ln -s /usr/bin/python3 /usr/bin/python
2. 提示版本错误
解决办法:按照提示执行
/usr/bin/python -m pip install --user -r /home/esp/ESP8266_RTOS_SDK/requirements.txt
如果没有什么错误,那么就可以执行编译操作了。
首次编译需要编译所有的代码(包括SDK源码)
make all
之后可仅仅编译自己的APP代码
make app
可通过添加CPU多核 -j8 参数快速编译代码!例如
make all -j8
编译成功后,如下图
内容如下:
To flash all build output, run 'make flash' or:
python /home/esp/ESP8266_RTOS_SDK/components/esptool_py/esptool/esptool.py --chip esp8266 --port /dev/ttyUSB0 --baud 115200 --before default_reset --after hard_reset write_flash -z --flash_mode dio --flash_freq 40m --flash_size 2MB 0x0 /home/esp/hello_world/build/bootloader/bootloader.bin 0x10000 /home/esp/hello_world/build/hello-world.bin 0x8000 /home/esp/hello_world/build/partitions_singleapp.bin
esp@esp:~/hello_world$
其中如下三个文件即为我们需要烧录的程序
Flash地址 BIN文件
0x0 bootloader.bin -- 启动文件
0x10000 hello-world.bin -- 自己的APP程序
0x8000 partitions_singleapp.bin -- 配置文件
6. 烧录工具配置
下面使我烧录模块 ESP-12S的参考配置,主要注意一下FLASH SIZE
这里开始介绍安装ESP32开发环境搭建
说明:以下搭建步骤,我也是参考官方网站的说明,随着时间的推移官方可能有变动,所有建议大家也去官方网站看看。本文搭建是以ESP-IDF SDK版本4.2为基础。
环境搭建
https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/get-started/linux-setup.html#
SDK下载
https://www.espressif.com/zh-hans/support/download/sdks-demos
好了,接下来大家就参考一下下面的步骤吧
注意:本文中Linux基本路径为"/home/esp",可能跟你的不一样,所以你需要修改成你的路径。
1. 下载ESP-IDF SDK v4.2
#安装解压工具unzip
sudo apt install unzip
#下载esp-idf
wget https://dl.espressif.com/github_assets/espressif/esp-idf/releases/download/v4.2/esp-idf-v4.2.zip
#解压zip文件
unzip esp-idf-v4.2.zip
下载方式有两种,一种是通过github下载,但是国内访问太慢了,所以直接从官方下载zip包,非常很快。
2. 安装工具
#进入esp-idf目录
cd esp-idf-v4.2
#设置优先选择官方 Espressif 下载服务器
export IDF_GITHUB_ASSETS="dl.espressif.com/github_assets"
#开始安装工具
./install.sh
3. 设置环境变量
#打开系统文件.profile
vi ~/.profile
#在 .profile 文件中末尾添加环境设置脚本
#注意 复制包含命令前面的“.”
. /home/esp/esp-idf-v4.2/export.sh
#使能当前设置
source ~/.profile
4. 编译测试工程
环境设置完成后,我们可以复制esp-idf中的Demo例程“hello_world”进行编译测试
#复制例程到指定目录,本例只是复制到根目录而已
cp esp-idf-v4.2/examples/get-started/hello_world/ . -a
#进入例程目录
cd hello_world
#设置“目标”芯片
idf.py set-target esp32
#工程配置
idf.py menuconfig
#开始编译
idf.py build
复制例程
设置目标芯片
配置工程
menuconfig工程配置配置时,参数默认即可。
menuconfig 工具的常见操作见下。
上下箭头:移动
回车:进入子菜单
ESC 键:返回上级菜单或退出
英文问号:调出帮助菜单(退出帮助菜单,请按回车键)。
空格``或 ``Y 键:选择 [*] 配置选项;N 键:禁用 [*] 配置选项
英文问号 (查询配置选项):调出有关该选项的帮助菜单
/ 键:寻找配置工程
配置工程后,就可以编译工程了
esp@esp:~/hello_world$ idf.py build
Executing action: all (aliases: build)
Running ninja in directory /home/esp/hello_world/build
Executing "ninja all"...
[4/931] Generating ../../partition_table/partition-table.bin
Partition table binary generated. Contents:
*******************************************************************************
# ESP-IDF Partition Table
# Name, Type, SubType, Offset, Size, Flags
nvs,data,nvs,0x9000,24K,
phy_init,data,phy,0xf000,4K,
factory,app,factory,0x10000,1M,
*******************************************************************************
[140/931] Performing configure step for 'bootloader'
-- Building ESP-IDF components for target esp32
-- Adding linker script /home/esp/esp-idf-v4.2/components/esp32/ld/esp32.peripherals.ld
-- Adding linker script /home/esp/esp-idf-v4.2/components/esp_rom/esp32/ld/esp32.rom.ld
-- Adding linker script /home/esp/esp-idf-v4.2/components/esp_rom/esp32/ld/esp32.rom.newlib-funcs.ld
-- Adding linker script /home/esp/esp-idf-v4.2/components/esp_rom/esp32/ld/esp32.rom.libgcc.ld
-- Adding linker script /home/esp/esp-idf-v4.2/components/bootloader/subproject/main/ld/esp32/bootloader.ld
-- Adding linker script /home/esp/esp-idf-v4.2/components/bootloader/subproject/main/ld/esp32/bootloader.rom.ld
-- Components: bootloader bootloader_support efuse esp32 esp_common esp_rom esptool_py log main micro-ecc partition_table soc spi_flash xtensa
-- Component paths: /home/esp/esp-idf-v4.2/components/bootloader /home/esp/esp-idf-v4.2/components/bootloader_support /home/esp/esp-idf-v4.2/components/efuse /home/esp/esp-idf-v4.2/components/esp32 /home/esp/esp-idf-v4.2/components/esp_common /home/esp/esp-idf-v4.2/components/esp_rom /home/esp/esp-idf-v4.2/components/esptool_py /home/esp/esp-idf-v4.2/components/log /home/esp/esp-idf-v4.2/components/bootloader/subproject/main /home/esp/esp-idf-v4.2/components/bootloader/subproject/components/micro-ecc /home/esp/esp-idf-v4.2/components/partition_table /home/esp/esp-idf-v4.2/components/soc /home/esp/esp-idf-v4.2/components/spi_flash /home/esp/esp-idf-v4.2/components/xtensa
-- Configuring done
-- Generating done
-- Build files have been written to: /home/esp/hello_world/build/bootloader
[142/931] Performing build step for 'bootloader'
[1/2] Linking C executable bootloader.elf
[2/2] Generating binary image from built executable
esptool.py v3.0
Generated /home/esp/hello_world/build/bootloader/bootloader.bin
[931/931] Generating binary image from built executable
esptool.py v3.0
Generated /home/esp/hello_world/build/hello-world.bin
Project build complete. To flash, run this command:
/home/esp/.espressif/python_env/idf4.2_py3.8_env/bin/python ../esp-idf-v4.2/components/esptool_py/esptool/esptool.py -p (PORT) -b 460800 --before default_reset --after hard_reset --chip esp32 write_flash --flash_mode dio --flash_size detect --flash_freq 40m 0x1000 build/bootloader/bootloader.bin 0x8000 build/partition_table/partition-table.bin 0x10000 build/hello-world.bin
首次编译,过程有点慢~稍等一会哈。如果一切正常,编译完成后将生成三个.bin 文件,跟ESP8266类似,可参考本文中ESP8266部分。
好了,终于写完了~~~我要去喝杯咖啡了。哈哈哈。对了。别忘了点个赞啥的哈!
- 上一篇:软件破解工具大礼包光盘目录?
- 下一篇:自动启动的多媒体光盘程序-C#学习进阶
相关推荐
- Mac电脑强制删除任何软件方法-含自启动应用
-
对于打工者来说,进入企业上班使用的电脑大概率是会被监控起来,比如各种流行的数据防泄漏DLP,奇安信天擎,甚至360安全卫士,这些安全软件你想卸载是非常困难的,甚至卸载后它自己又安装回来了,并且还在你不...
- Linux基础知识 | 文件与目录大全讲解
-
1.linux文件权限与目录配置1.文件属性Linux一般将文件可存取的身份分为三个类别,分别是owner/group/others,且三种身份各read/write/execute等权限文...
- 文件保护不妥协:2025 年 10 款顶级加密工具推荐
-
数据安全无小事,2025年这10款加密工具凭借独特功能脱颖而出,从个人到企业场景全覆盖,第一款为Ping32,其余为国外英文软件。1.Ping32企业级加密核心工具,支持200+文件格...
- 省心省力 一个软件搞定系统维护_省心安装在哪里能找到
-
◆系统类似于我们居住的房间,需要经常打理才能保持清洁、高效。虽然它本身也自带一些清理和优化的工具,但借助于好用的第三方工具来执行这方面的任务,会更让人省心省力。下面笔者就为大家介绍一款集多项功能于一身...
- JAVA程序员常用的几个工具类_java程序员一般用什么软件写程序
-
好的工具做起事来常常事半功倍,下面介绍几个开发中常用到的工具类,收藏一下,也许后面真的会用到。字符串处理:org.apache.commons.lang.StringUtilsisBlank(Char...
- 手工解决Windows10的若干难题_windows10系统卡顿怎么解决
-
【电脑报在线】很多朋友已经开始使用Win10,估计还只是测试版本的原因,使用过程中难免会出现一些问题,这里介绍解决一些解决难题的技巧。技巧1:让ProjectSpartan“重归正途”从10074...
- System32文件夹千万不能删除,看完这篇你就知道为什么了
-
C:\Windows\System32目录是Windows操作系统的关键部分,重要的系统文件存储在该目录中。网上的一些恶作剧者可能会告诉你删除它,但你不应该尝试去操作,如果你尝试的话,我们会告诉你会发...
- Windows.old 文件夹:系统备份的解析与安全删除指南
-
Windows.old是Windows系统升级(如Win10升Win11)或重装时,系统自动在C盘创建的备份文件夹,其核心作用是保留旧系统的文件、程序与配置,为“回退旧系统”提供保...
- 遇到疑难杂症?Windows 10回收站问题巧解决
-
回收站是Windows10的一个重要组件。然而,我们在使用过程中,可能会遇到一些问题。例如,不论回收站里有没有文件,都显示同一个图标,让人无法判别回收站的空和满的真实情况;没有了像Windows7...
- 卸载软件怎么彻底删掉?简单几个步骤彻底卸载,电脑小白看过来
-
日常工作学习生活中,我们需要在安装一些软件程序,但随着软件的更新迭代速度,很多时候我们需要重新下载安装新的程序,这时就需要将旧的一些软件程序进行卸载。但是卸载软件虽然很简单,但是很多小伙伴们表示卸载不...
- 用不上就删!如何完全卸载OneDrive?
-
作为Windows10自带的云盘,OneDrive为资料的自动备份和同步提供了方便。然而,从隐私或其他方面考虑,有些人不愿意使用OneDrive。但Windows10本身不提供直接卸载OneDri...
- 【Linux知识】Linux下快速删除大量文件/文件夹方法
-
在Linux下,如果需要快速删除大量文件或文件夹,可以使用如下方法:使用rm命令删除文件:可以使用rm命令删除文件,例如:rm-rf/path/to/directory/*这个命令会递...
- 清理系统不用第三方工具_清理系统垃圾用什么软件
-
清理优化系统一定要借助于优化工具吗?其实,手动优化系统也没有那么神秘,掌握了方法和技巧,系统清理也是一件简单和随心的事。一方面要为每一个可能产生累赘的文件找到清理的方法,另一方面要寻找能够提高工作效率...
- 系统小技巧:软件卸载不了?这里办法多
-
在正常情况下,我们都是通过软件程序组中的卸载图标,或利用控制面板中的“程序和功能”模块来卸载软件的。但有时,我们也会发现利用卸载图标无法卸载软件或者卸载图标干脆丢失找不到了,甚至控制面板中卸载软件的功...
- 麒麟系统无法删除文件夹_麒麟系统删除文件权限不够
-
删除文件夹方法例:sudorm-rf文件夹名称。删除文件方法例:sudorm-r文件名包括扩展名。如果没有权限,给文件夹加一下权限再删。加最高权限chmod775文件名加可执行权限...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 如何绘制折线图 (52)
- javaabstract (48)
- 新浪微博头像 (53)
- grub4dos (66)
- s扫描器 (51)
- httpfile dll (48)
- ps实例教程 (55)
- taskmgr (51)
- s spline (61)
- vnc远程控制 (47)
- 数据丢失 (47)
- wbem (57)
- flac文件 (72)
- 网页制作基础教程 (53)
- 镜像文件刻录 (61)
- ug5 0软件免费下载 (78)
- debian下载 (53)
- ubuntu10 04 (60)
- web qq登录 (59)
- 笔记本变成无线路由 (52)
- flash player 11 4 (50)
- 右键菜单清理 (78)
- cuteftp 注册码 (57)
- ospf协议 (53)
- ms17 010 下载 (60)