Windows下最简单的ESP8266_ROTS_ESP-IDF环境搭建与腾讯云SDK编译
bigegpt 2025-06-03 20:23 8 浏览
前言
其实也没啥可说的,只是我感觉ESP-IDF对新手来说很不友好,很容易踩坑,尤其是对业余DIY爱好者搭建环境非常困难,即使有官方文档,或者网上的其他文档,但是还是很容易踩坑,多研究,记住两点就行了, 一个是编译的工具链,二个是SDK编译所需的一些软件或者库,搞清楚了,还是蛮简单的.本人如此精心的细心地写了这篇文章,若你还是无法完成,那我也帮不了你了.
在windows上安装ubuntu
本文主要针对在linux环境编译,所以首先需要在你的winsows上,安装linux,在windows上安装linux方式有很多,选择你觉得合适的方式即可,你可以采用msys2,或者虚拟机,本文直接采用win10的系统功能,这样更加方便
1.打开控制面板,进入程序和功能(你也可以直接使用 Win键 + R键 输入 appwiz.cpl 确定)
2.点击左侧,启动或关闭Windows功能
3.勾选列表中的 "适用于 Linux 的 Windows 子系统" 点击确定,重启系统
4.打开Windows应用商店(Microsoft Store),搜索 Ubuntu 下载安装,这个下载与安装结束很快,耐心等待即可
5.通过开始菜单,点击 Ubuntu ,打开进入 Ubuntu (你也可以在Windows应用商店,你刚刚点击下载那里点击启动)
6.首次启动Ubuntu后会输入你的用户名及密码(输入密码时界面上不显示内容),密码需要输入两次,第二次为确认密码
PS:创建完账号后,linux会自动创建相应的用户目录(/home/你的用户名),我这里为hmuyin,后面会用到这个目录
至此Ubuntu安装完毕,可以在控制台看到Ubuntu的版本以及其他信息"Welcome to Ubuntu 20.04.2 LTS (GNU/Linux 4.4.0-19041-Microsoft x86_64)"
7.为了我们后续方便,我们需要对安装好的Ubuntu进行一些设置
首先是更新软件源,这样在国内或者不使用代理的情况下,下载软件更快更方便,本文使用清华大学开源软件源,注意:请根据你的Ubuntu版本选择对应的源.
打开 清华大学开源软件镜像站
https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/在右侧 "选择你的ubuntu版本"复制内容
PS:你可以使用 lsb_release -a 查看Ubuntu版本
然后命令输入
sudo vim /etc/apt/sources.list
打开后全选,按下键盘 : ggVG (注意大写,按键盘顺序 G键-->G键-->大小写键(切到大写)-->V键-->G键),全选后清楚,按下键盘 : dG (注意大写,按键盘顺序 d键-->大小写键(切到大写)-->G键),清除完毕后按下i键进入编辑,点击窗口右键->编辑->粘贴,将复制的内容粘贴进去,最后按下 ESC 键,输入 :wq 保存并退出即可.
最后再输入两条命令更新软件源
sudo apt update
sudo apt upgrade -y
对 Ubuntu 进行汉化 (若你无需汉化,则跳过本步骤)
由于本人英文水平较差,比较喜欢用中文,所以能汉化的东西或者说有中文的东西我一般都是尽量使用中文
1.直接复制以下命令然后在控制台进行粘贴
sudo apt install language-pack-zh-han* -y
sudo locale-gen zh_CN.GB18030 && sudo locale-gen zh_CN.GB2312 && sudo locale-gen zh_CN.UTF8
sudo apt install fontconfig -y
sudo apt install ttf-mscorefonts-installer -y
sudo apt install -y --force-yes --no-install-recommends fonts-wqy-microhei
sudo apt install -y --force-yes --no-install-recommends ttf-wqy-zenhei
等待字体文件下载完毕后,复制以下命令,进入菜单选择zh_CN UTF.8 UTF.8,按空格选中,回车继续,下一个菜单也选这个,完成后重启,变中文了
sudo dpkg-reconfigure locales
搭建ESP-IDF环境
在Linux上安装所需软件,以及配置工具链,这里我将大部分的SDK所需软件都进行统一安装,这样就可以编译大部分的一些SDK,比如腾讯云ESP8266SDK,阿里云ESP-IDF,以及第三方或者其他个人开发的开发的一些SDK,等.(这篇文章为何要写,并且为什么写的这个详细,就是因为如果按照原来的方法搭建或者按照官方的方法,在编译其他SDK的时候就容易报错)
1.先下载工具链,以及官方SDK,(本文使用腾讯云SDK,所以同时将腾讯云SDK也下载)
#先建立一个目录
mkdir esp
cd esp
#官方SDK3.1版本
git clone --single-branch -b release/v3.1 https://github.com/espressif/ESP8266_RTOS_SDK.git
#腾讯云SDK
git clone https://github.com/tencentyun/qcloud-iot-esp-wifi.git
#下载腾讯云工具链并解压
wget https://dl.espressif.com/dl/xtensa-lx106-elf-linux64-1.22.0-92-g8facf4c-5.2.0.tar.gz -O - | tar zxf -
ls
ls 后看到有这三个文件夹,就表示完成了
ESP8266_RTOS_SDK qcloud-iot-esp-wifi xtensa-lx106-elf
2.安装所需编译需要库及软件(如果你的ubunt在20.0及以上) 方法一与方法二任选其一,区别在于方法一安装的为 python3,方法二则安装的python2,由于软件源不再提供pip,取代的是php3,所以这里提供两种方法,根据自己实际需求选择
方法一: python3
sudo apt-get install git wget libncurses-dev flex bison gperf python3 python3-pip python3-setuptools python3-serial python3-cryptography python3-future python3-pyparsing python3-pyelftools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0
#然后重建映射,方便在python2上的兼容使用
sudo ln -s /usr/bin/python3 /usr/bin/python
方法二: python2
因为要输入密码,所以我们分两次进行安装
sudo apt-get install git wget flex bison gperf python python-setuptools cmake ninja-build ccache libffi-dev libssl-dev libncurses5-dev curl
curl https://bootstrap.pypa.io/pip/2.7/get-pip.py --output get-pip.py
sudo python2 get-pip.py
pip2 --version
pip install pyserial #安装python串口模块
pip install xlrd #安装excel读写模块
将工具链添加到PATH环境变量,以及将IDF编时IDF_PATH的变量添加到系统环境变量
环境变量可以随时切换其他的工具链以及SDK,本文只要编译的是esp8266
sudo vim /etc/profile.d/esp.sh
然后按下 i 键进入编辑
export PATH="$PATH:/home/你的用户目录/esp/xtensa-lx106-elf/bin" #工具链
export IDF_PATH="/home/你的用户目录/esp/ESP8266_RTOS_SDK" #ESP8266 SDK 目录
编辑好后,按下 ESC 键,输入 :wq 保存,然后重启即可生效
注意:这里如果你有多个SDK可以随时切换,或者有多个工具链也可以随时修改来进行切换,如你要编译ESP32则下载ESP32的工具链与SDK,然后在这里修改工具链的目录与SDK目录,即可随时切换
重启后可以通过 echo $IDF_PATH 查看是否正常
vim的操作,可以参考文本第一步的第6小节
PS : 你的用户目录,通常来说也就是安装Ubuntu时你创建的用户名,完整目录一般为 /home/你的用户名
具体可以请参考本文第1步的第6小结
编译腾讯云SDK
编译方式与官方教程一样
切换至腾讯云SDK目录 输入编译配置,保存好后退出,然后进行编译
make menuconfig
make all
看到 To flash all build output, run 'make flash' or 表示编译完成,你可以进行make flash进行下载,如果中途编译有错误的话,是无法看到该提示的,需根据错误进行问题排查.
腾讯云SDK需要配置三元信息以及其他信息,这里本文只是讲解如何正确编译,暂时不做开发类介绍,以后我会专门写一篇关于开发腾讯SDK文章
编译官方SDK
好了,我们再来测试一下编译官方的扩展示例
切换至官方扩展示例目录 输入编译配置,保存好后退出,然后进行编译
make menuconfig
make all
烧写/下载 测试
文本将使用官方SDK的扩展示例 hello word 进行测试
注意:如果你的端口为 COM3 在Ubuntu里面对应则为 /dev/ttyS3
你的COM端口为几,那么/dev/ttyS 就S几
看到 Hard resetting via RTS pin... 后表示下载完成,可以使用 make monitor 打开串口测试
Ubuntu 与 windows 文件共享
现在我们就可以进行创建项目进行程序编写了,但是如何方便地进行访问Linux中的文件呢,这里有两种方式
1.直接打开linux的目录
C:\Users\你的用户名\AppData\Local\Packages\
CanonicalGroupLimited.UbuntuonWindows_79rhkp1fndgsc\LocalState\rootfs
在这个目录下 就是整个linux的目录,你的用户目录在 home 目录下,新建项目与.c 文件操作都可以直接在这个目录下进行,也可以使用 vscode 打开该目录进入到SDK目录下编写.
也可以创建快捷键方式,即可直接进入该目录
2.挂载本机磁盘
直接使用 mount 查看,可以看到磁盘的内容,直接使用 cd /mnt/c 即进入了c盘,在使用ls可查看文件列表
总结
目前发现串口调试也就是 make monitor 还是有一定的问题,目前正在想法解决,如果解决后会修改本文,如需串口调试可以使用其他第三方串口调试工具进行串口调试,这个问题据说是win10 Bug 引起的问题,我们在 idf_monitor.py 从文件中也可以得知
具体问题可以参考
https://github.com/espressif/esp-idf/issues/1136
原创内容,未经许可,禁止随便转载,by:hmuyin
相关推荐
- 【Docker 新手入门指南】第十章:Dockerfile
-
Dockerfile是Docker镜像构建的核心配置文件,通过预定义的指令集实现镜像的自动化构建。以下从核心概念、指令详解、最佳实践三方面展开说明,帮助你系统掌握Dockerfile的使用逻...
- Windows下最简单的ESP8266_ROTS_ESP-IDF环境搭建与腾讯云SDK编译
-
前言其实也没啥可说的,只是我感觉ESP-IDF对新手来说很不友好,很容易踩坑,尤其是对业余DIY爱好者搭建环境非常困难,即使有官方文档,或者网上的其他文档,但是还是很容易踩坑,多研究,记住两点就行了,...
- python虚拟环境迁移(python虚拟环境conda)
-
主机A的虚拟环境向主机B迁移。前提条件:主机A和主机B已经安装了virtualenv1.主机A操作如下虚拟环境目录:venv进入虚拟环境:sourcevenv/bin/active(1)记录虚拟环...
- Python爬虫进阶教程(二):线程、协程
-
简介线程线程也叫轻量级进程,它是一个基本的CPU执行单元,也是程序执行过程中的最小单元,由线程ID、程序计数器、寄存器集合和堆栈共同组成。线程的引入减小了程序并发执行时的开销,提高了操作系统的并发性能...
- 基于网络安全的Docker逃逸(docker)
-
如何判断当前机器是否为Docker容器环境Metasploit中的checkcontainer模块、(判断是否为虚拟机,checkvm模块)搭配学习教程1.检查根目录下是否存在.dockerenv文...
- Python编程语言被纳入浙江高考,小学生都开始学了
-
今年9月份开始的新学期,浙江省三到九年级信息技术课将同步替换新教材。其中,新初二将新增Python编程课程内容。新高一信息技术编程语言由VB替换为Python,大数据、人工智能、程序设计与算法按照教材...
- CentOS 7下安装Python 3.10的完整过程
-
1.安装相应的编译工具yum-ygroupinstall"Developmenttools"yum-yinstallzlib-develbzip2-develope...
- 如何在Ubuntu 20.04上部署Odoo 14
-
Odoo是世界上最受欢迎的多合一商务软件。它提供了一系列业务应用程序,包括CRM,网站,电子商务,计费,会计,制造,仓库,项目管理,库存等等,所有这些都无缝集成在一起。Odoo可以通过几种不同的方式进...
- Ubuntu 系统安装 PyTorch 全流程指南
-
当前环境:Ubuntu22.04,显卡为GeForceRTX3080Ti1、下载显卡驱动驱动网站:https://www.nvidia.com/en-us/drivers/根据自己的显卡型号和...
- spark+python环境搭建(python 环境搭建)
-
最近项目需要用到spark大数据相关技术,周末有空spark环境搭起来...目标spark,python运行环境部署在linux服务器个人通过vscode开发通过远程python解释器执行代码准备...
- centos7.9安装最新python-3.11.1(centos安装python环境)
-
centos7.9安装最新python-3.11.1centos7.9默认安装的是python-2.7.5版本,安全扫描时会有很多漏洞,比如:Python命令注入漏洞(CVE-2015-2010...
- Linux系统下,五大步骤安装Python
-
一、下载Python包网上教程大多是通过官方地址进行下载Python的,但由于国内网络环境问题,会导致下载很慢,所以这里建议通过国内镜像进行下载例如:淘宝镜像http://npm.taobao.or...
- centos7上安装python3(centos7安装python3.7.2一键脚本)
-
centos7上默认安装的是python2,要使用python3则需要自行下载源码编译安装。1.安装依赖yum-ygroupinstall"Developmenttools"...
- 利用本地数据通过微调方式训练 本地DeepSeek-R1 蒸馏模型
-
网络上相应的教程基本都基于LLaMA-Factory进行,本文章主要顺着相应的教程一步步实现大模型的微调和训练。训练环境:可自行定义,mac、linux或者window之类的均可以,本文以ma...
- 【法器篇】天啦噜,库崩了没备份(天啦噜是什么意思?)
-
背景数据库没有做备份,一天突然由于断电或其他原因导致无法启动了,且设置了innodb_force_recovery=6都无法启动,里面的数据怎么才能恢复出来?本例采用解析建表语句+表空间传输的方式进行...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- resize函数 (64)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- mybatis大于等于 (64)
- xcode-select (66)
- mysql授权 (74)
- 下载测试 (70)
- skip-name-resolve (63)
- linuxlink (65)
- pythonwget (67)
- logstashinput (65)
- hadoop端口 (65)
- vue阻止冒泡 (67)
- oracle时间戳转换日期 (64)
- jquery跨域 (68)
- php写入文件 (73)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)