个人 工作
2022-01-01
新的一年,岁数又会 +1,在这个一年开始的时候,对过去做个总结,对将来做个展望。
对过去的反思
- 工作这么多年,还是缺少拿得出手的项目经历,不足以支撑我对自己的定位或者目标
工作年限越长,这个问题就会更加突出
新的一年需要思考思考这个问题
- 技术深度不够
- 主力开发语言 Python 应该更加深入,完成 CPython 源码阅读
- PHP, Node, Golang 需要加强,能够熟练掌握 (主要是软件生态),使之达到新的线上业务开发的程度
- 前端也一样
- 知识结构缺乏深入的整理
- 比如软件设计的一些思考
- 应该对产品方面更加用心一些

现在就是对技术方面过于感兴趣而忽略了产品
这个问题对于工作来说比较突出,新的一年一定要注意这个问题
今年的计划
前提:工作习惯养成:1. 计划,2. 重要的事情优先完成,3. 不加班 (上班时间完成工作)
如果按平均每天 2h 来计划,全年有 730h。
对当前公司业务的梳理, 需要有计划有步骤的推进 (这一项可以在工作中完成)
完成 Golang 的学习目标, 达到熟练的程度(第一季度) (60h, 按一个月算)
CPython 源码阅读 (120h, 按两个月算)
英语和数学
真是 年年列计划, 年年没时间
英语达到六级词汇, 能不借助工具流利阅读英语资料 (180h, 按每天半小时算)
数学复习到高等数学, 不用达到应试的程度, 了解相关概念就行 (60h, 按一个月算)
计算机网络 (50h)
Markjour 文章更新速度放缓, 每周一篇就够了 (104h, 按每周两个小时算)
对以往知识的总结 (104h,按每周两个小时算)
剩下的时间 (52h) 差不多每周 1h, 用来记入其他学习任务。
个人项目的开发不占用这里的学习时间,另外从周末时间里面挤。
可选个人项目
- 短网址
- 记账
- Home Assistant 方向
我预测未来几年,智能家居会变的很流行
OpenWrt + Home Assistant 是一个很好的方案
- 通用管理后台
- 商城
- 重构 markjour
计算机网络 IPv6
2021-12-30
$ ip -c -6 addr show dev wlp6s0
3: wlp6s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
inet6 2409:8a4d:c81:c140::5/128 scope global dynamic noprefixroute
valid_lft 226977sec preferred_lft 140577sec
inet6 2409:8a4d:c81:c140:ca67:f46:7f29:1dad/64 scope global temporary dynamic
valid_lft 376sec preferred_lft 376sec
inet6 2409:8a4d:c81:c140:fcf0:3456:fac4:3b63/64 scope global dynamic mngtmpaddr noprefixroute
valid_lft 376sec preferred_lft 376sec
inet6 fe80::56f8:128b:b513:e571/64 scope link noprefixroute
valid_lft forever preferred_lft forever
# ipconfig /all
# ipconfig
无线局域网适配器 WLAN:
连接特定的 DNS 后缀 . . . . . . . :
IPv6 地址 . . . . . . . . . . . . : 2409:8a4d:c81:c140::6
IPv6 地址 . . . . . . . . . . . . : 2409:8a4d:c81:c140:68cd:b350:9fe8:9feb
临时 IPv6 地址. . . . . . . . . . : 2409:8a4d:c81:c140:757f:88b3:b455:5882
本地链接 IPv6 地址. . . . . . . . : fe80::68cd:b350:9fe8:9feb%5
IPv4 地址 . . . . . . . . . . . . : 192.168.1.7
子网掩码 . . . . . . . . . . . . : 255.255.255.0
默认网关. . . . . . . . . . . . . : fe80::1%5
192.168.1.1
DHCP 服务器 . . . . . . . . . . . : 192.168.1.1
DNS 服务器 . . . . . . . . . . . : 2409:804c:2000:1::1
2409:804c:2000:2::1
192.168.1.1
一、地址格式
IPv4 4 字节, 一般用四个十进制的数字表示,xxx.xxx.xxx.xxx
形式,每一段的范围是 0~255。
IPv6 16 字节,一般用 32 个十六进制数表示,每四个一组,共八组,xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx:xxxx
形式,每一段的范围是 0000~FFFF。
缩写
- 高位的 0 可以省略,比如
0001
就可以写成 1
- 全 0 段可以省略,用分号表示,比如
fe80::
, ::
(全 0), 又比如上面的 2409:8a4d:c81:c140::5
但是, 只能缩写一次,比如 A:B:0:0:C:D:0:0
不能写成 A:B::C:D::
, 只能缩写成 A:B::C:D:0:0
或 A:B:0:0:C:D::
百分号
如果一台机器有多张网卡,都有一个 fe80 的链路地址,操作系统无法区分一个包该走哪张网卡出。
在 IPv4 中,不同网卡一般配置了不同子网,比如 172.16.31.0/24
, 172.168.32.0/24
。
但是 IPv6 的分配可以自己生成(无状态地址自动配置),大家都在 fe80 段。
百分号后面附加的是 zone index,这个数据是操作系统解释的。Windows 会采用接口号(整型数),而 Linux 习惯端口名称,比如 eth0, enp7s0。
PS: 推荐阅读: 网卡名称的变迁(ethX -> enpXsY)
- windows:
netsh interface ipv6 show address
- linux:
ifconfig
注意:用在 URL 中时,这个百分号应该转义成 %25
。
二、前缀
IPv4 有分区的概念,一开始叫做分类网络,ABCDE 五类。后来又有无类网络 (Classless Inter-Domain Routing, CIDR),取任意长度作前缀,比如 172.16.0.0/12 以 1010 1100 0001
做前缀。
IPv6 也有分区的概念,和 CIDR 一样,可以取任意长度作前缀。
比如 fe80::/10 就是以 1111 1110 10
做前缀。
移动网络给我分配的是 /64 段,听说有地方能拿到更短前缀(V2EX, 2020/07, 电信 IPv6 大家还能拿到/56 么)。
如果拿到更短前缀,就可以自己在家划分子网了。根据现在的实践(SLAAC),一个网络最少需要留 64 位,如果正好分的是 64 位前缀,那么就不能采用 SLAAC 方案了,只能走 DHCP。
无状态自动配置
- RS, Router Solicitation
- RA, Router Advertisement 路由器告诉机器 IPv6 前缀
- NS, Neighbor Solicitation 机器广播自己将要采用某一个 IPv6
个人 工作
2021-12-27
处于安全原因,每隔几个月重新更换一次 OpenVPN 的配置文件,以防被攻击。运维讲配置文件加密打包分发给每个人,然后大家将其覆盖到现在的目录中。
我是 Linux 环境(Ubuntu, 准备切入 Fedora),这里我记录一下更新流程,下次务必 1 分钟之内切换完成。
- 通过密码解压配置文件
ls ~/Documents/Mine/config20211213/
# ca.crt client.crt client.key client.ovpn
- 备份之前的证书文件
cd /etc/openvpn
sudo mkdir backup20211227
sudo mv ca.crt client.crt client.key client.ovpn backup20211227/
sudo cp client.conf backup20211227/
- 采用新的证书文件
sudo mv ~/Documents/Mine/config20211213/{ca.crt,client.crt,client.key,client.ovpn} /etc/openvpn
sudo chmod 400 /etc/openvpn/{ca.crt,client.crt,client.key,client.ovpn}
- 通过和旧的 client.ovpn 文件比对,讲需要修改的地方同步到
/etc/openvpn/client.conf
中
sudo diff client.ovpn backup20211227/client.ovpn
sudo vim /etc/openvpn/client.conf
# w! sudo tee %
- 重新启动 OpenVPN,试一下是否配置成功
sudo systemctl restart openvpn@client
Tornado
2021-12-16
2020 年 10 月发布的 6.1,结果到现在,已经一年多过去了,6.2 还没有见到。
Update @ 2022-04-28: 又过去了小半年,6.2 还是没有影子。

从 GitHub 提交频率图上明显可以看到 Tornado 的活跃度大幅下滑,2020 年的提交已然不多,2021 年更加惨不忍睹。
官方协程框架 AsyncIO 的诞生,标志着 Tornado 的历史使命已经完成。
是时候带着对 Tornado 的回忆,全面转投原生协程生态了。