<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Asyncio on syno blog</title><link>https://synodriver.github.io/tags/asyncio/</link><description>Recent content in Asyncio on syno blog</description><generator>Hugo</generator><language>locale</language><lastBuildDate>Fri, 05 Jun 2026 00:41:47 +0800</lastBuildDate><atom:link href="https://synodriver.github.io/tags/asyncio/index.xml" rel="self" type="application/rss+xml"/><item><title>Home Assistant 核心架构与实现深度解析</title><link>https://synodriver.github.io/post/homeassistant_architecture/</link><pubDate>Fri, 05 Jun 2026 00:41:47 +0800</pubDate><guid>https://synodriver.github.io/post/homeassistant_architecture/</guid><description>&lt;h1 id="home-assistant-核心架构与实现深度解析"&gt;Home Assistant 核心架构与实现深度解析&lt;/h1&gt;
&lt;blockquote&gt;
&lt;p&gt;基于源码版本 2026.7.0.dev0，Python 3.14.2+&lt;/p&gt;
&lt;/blockquote&gt;
&lt;h2 id="目录"&gt;目录&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href="#1-%E9%A1%B9%E7%9B%AE%E6%80%BB%E4%BD%93%E7%BB%93%E6%9E%84"&gt;1. 项目总体结构&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#2-%E6%A0%B8%E5%BF%83%E7%B1%BB%E4%B8%8E%E5%9F%BA%E7%B1%BB%E4%BD%93%E7%B3%BB"&gt;2. 核心类与基类体系&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#3-%E5%90%AF%E5%8A%A8%E6%B5%81%E7%A8%8B%E8%AF%A6%E8%A7%A3"&gt;3. 启动流程详解&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#4-%E9%9B%86%E6%88%90%E5%8A%A0%E8%BD%BD%E6%9C%BA%E5%88%B6"&gt;4. 集成加载机制&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#5-%E9%85%8D%E7%BD%AE%E6%B5%81configflow%E6%9C%BA%E5%88%B6"&gt;5. 配置流(ConfigFlow)机制&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#6-%E5%AE%9E%E4%BD%93entity%E4%BD%93%E7%B3%BB"&gt;6. 实体(Entity)体系&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#7-%E6%9C%8D%E5%8A%A1service%E6%9C%BA%E5%88%B6"&gt;7. 服务(Service)机制&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#8-%E5%B9%B3%E5%8F%B0platform%E4%B8%8E-entitycomponent-%E7%BC%96%E6%8E%92"&gt;8. 平台(Platform)与 EntityComponent 编排&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#9-%E9%9B%86%E6%88%90%E5%AE%9E%E7%8E%B0%E5%AE%8C%E6%95%B4%E7%A4%BA%E4%BE%8Bhue"&gt;9. 集成实现完整示例：Hue&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#10-%E5%A6%82%E4%BD%95%E5%AE%9E%E7%8E%B0%E8%87%AA%E5%B7%B1%E7%9A%84%E9%9B%86%E6%88%90"&gt;10. 如何实现自己的集成&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="#11-%E5%85%B3%E9%94%AE%E8%AE%BE%E8%AE%A1%E6%A8%A1%E5%BC%8F%E6%80%BB%E7%BB%93"&gt;11. 关键设计模式总结&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h2 id="1-项目总体结构"&gt;1. 项目总体结构&lt;/h2&gt;
&lt;h3 id="11-顶层目录"&gt;1.1 顶层目录&lt;/h3&gt;
&lt;div class="highlight"&gt;&lt;div class="chroma"&gt;
&lt;table class="lntable"&gt;&lt;tr&gt;&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code&gt;&lt;span class="lnt"&gt; 1
&lt;/span&gt;&lt;span class="lnt"&gt; 2
&lt;/span&gt;&lt;span class="lnt"&gt; 3
&lt;/span&gt;&lt;span class="lnt"&gt; 4
&lt;/span&gt;&lt;span class="lnt"&gt; 5
&lt;/span&gt;&lt;span class="lnt"&gt; 6
&lt;/span&gt;&lt;span class="lnt"&gt; 7
&lt;/span&gt;&lt;span class="lnt"&gt; 8
&lt;/span&gt;&lt;span class="lnt"&gt; 9
&lt;/span&gt;&lt;span class="lnt"&gt;10
&lt;/span&gt;&lt;span class="lnt"&gt;11
&lt;/span&gt;&lt;span class="lnt"&gt;12
&lt;/span&gt;&lt;span class="lnt"&gt;13
&lt;/span&gt;&lt;span class="lnt"&gt;14
&lt;/span&gt;&lt;span class="lnt"&gt;15
&lt;/span&gt;&lt;span class="lnt"&gt;16
&lt;/span&gt;&lt;span class="lnt"&gt;17
&lt;/span&gt;&lt;span class="lnt"&gt;18
&lt;/span&gt;&lt;span class="lnt"&gt;19
&lt;/span&gt;&lt;span class="lnt"&gt;20
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class="lntd"&gt;
&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-gdscript3" data-lang="gdscript3"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;E&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;\&lt;span class="n"&gt;pyproject&lt;/span&gt;\&lt;span class="n"&gt;core&lt;/span&gt;\
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;homeassistant&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 核心源代码主目录&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;core&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# HomeAssistant 主类、EventBus、StateMachine、ServiceRegistry&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;config_entries&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# ConfigEntry、ConfigFlow、ConfigEntries 管理器&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;bootstrap&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# 启动引导，分阶段加载&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;loader&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# Integration 类，manifest 解析，自定义集成管理&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;setup&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# async_setup_component，依赖解析&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;data_entry_flow&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# FlowHandler/FlowManager 基类&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;config&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# 配置文件处理&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="k"&gt;const&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# 全局常量、Platform 枚举&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;runner&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# 运行器，事件循环设置&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;__main__&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;py&lt;/span&gt; &lt;span class="c1"&gt;# CLI 入口&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;auth&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 认证系统&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;components&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 所有内置集成（2000+个）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;generated&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 自动生成的代码（蓝牙、DHCP、SSDP 数据等）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;helpers&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 辅助模块（entity、entity_registry、template 等）&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;│&lt;/span&gt; &lt;span class="err"&gt;└──&lt;/span&gt; &lt;span class="n"&gt;util&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 工具模块&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;tests&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 测试代码&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;├──&lt;/span&gt; &lt;span class="n"&gt;custom_components&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="c1"&gt;# 自定义集成目录&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="err"&gt;└──&lt;/span&gt; &lt;span class="n"&gt;pyproject&lt;/span&gt;&lt;span class="o"&gt;.&lt;/span&gt;&lt;span class="n"&gt;toml&lt;/span&gt; &lt;span class="c1"&gt;# 项目配置&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;h3 id="12-集成组织方式"&gt;1.2 集成组织方式&lt;/h3&gt;
&lt;p&gt;所有集成都以子目录形式存放在 &lt;code&gt;homeassistant/components/&lt;/code&gt; 下，目录名即域名。每个集成至少包含：&lt;/p&gt;</description></item><item><title>异步三坑</title><link>https://synodriver.github.io/post/async_bugs/</link><pubDate>Sat, 25 Apr 2026 03:11:51 +0800</pubDate><guid>https://synodriver.github.io/post/async_bugs/</guid><description>&lt;h1 id="异步三坑"&gt;异步三坑&lt;/h1&gt;
&lt;h3 id="1-论cancel"&gt;1. 论cancel&lt;/h3&gt;
&lt;p&gt;&lt;em&gt;asyncio.CancelledError&lt;/em&gt; 简直是神出鬼没，任何await的地方都可能冒出来，对他们的恰当处理是重中之重&lt;/p&gt;
&lt;h3 id="2-论future"&gt;2. 论Future&lt;/h3&gt;
&lt;p&gt;&lt;em&gt;Future.set_result()&lt;/em&gt; 和 &lt;em&gt;Future.set_exception()&lt;/em&gt; 这两个方法是Future的核心，然而，调用的时候是否判断了他的状态？
如果Future已经完成了，再调用&lt;em&gt;set_result()&lt;em&gt;或者&lt;/em&gt;set_exception()&lt;/em&gt;，就会抛出&lt;em&gt;InvalidStateError&lt;/em&gt;，
与上一个坑结合起来，&lt;em&gt;await future&lt;/em&gt;的时候被cancel了，抛出CancelledError，future的状态已经是cancelled，这时候就不能再对future搞事了。&lt;/p&gt;</description></item></channel></rss>