本文将介绍如何在MacOS下配置Nordic蓝牙开发环境, 器材为nRF52832(开发板NRF52-DK, PCA10040)。
通常来说人们会在windows上进行蓝牙开发, 但实际上MacOS也同样可以, 并且配合vscode可比Keil舒服多了。
如果你对Makefile等工具较为熟悉, 甚至可以获得比IDE更便捷的开发体验。
本文将介绍如何在MacOS下配置Nordic蓝牙开发环境, 器材为nRF52832(开发板NRF52-DK, PCA10040)。
通常来说人们会在windows上进行蓝牙开发, 但实际上MacOS也同样可以, 并且配合vscode可比Keil舒服多了。
如果你对Makefile等工具较为熟悉, 甚至可以获得比IDE更便捷的开发体验。
缓存一直是线上系统不可或缺的部分,本文总结了缓存系统中需要关注的一些问题
使用redis-benchmark工具对redis集群进行压测
redis-benchmark工具对于redis cluster支持并是不特别好,需要使用{tag}
来写入指定node,相关用法在这pr中。
但是使用{tag}测试后不好删除数据,并且根据业务需要,关注的是单Hash单Node下的性能表现,所以最后测试时,直接连接了测试key所在的node,避免了事后清除数据的麻烦。
根据测试结果,可以看出,使用Pipeline的情况下Redis吞吐量能提升一倍有余
在不使用pipeline的情况下猜测是网络开销占用了过多CPU,但具体是iowait还是其他因素造成仍需分析
此外AWS在Redis7/7.1上支持了(增强型IO多路复用)[https://docs.aws.amazon.com/zh_cn/AmazonElastiCache/latest/red-ug/supported-engine-versions.html#redis-version-7.0]可以很大程度上增强多客户端连接时的性能。
在项目的 settings 中 github pages 可以通过根目录或docs目录部署。但是这种方式不够灵活,对于一些前段项目,需要不停的通过CI生成站点文件,提交到git中再部署,git中存储了许多构建产物,显得冗余臃肿。
实际上,github也支持通过actions来部署pages,不需要将站点文件储存在git中。
我们都知道在编写github actions时,可以使用其他预定义好的github action,类似如下写法.
在ddb中,推荐使用双引号标记表名,列名,使用单引号标记字符串
1 | SELECT * |
可以在语句中使用order by等语句
1 | SELECT "column1", "column2" |
也可以使用CAST等函数
1 | SELECT CAST(column_name AS INT) |
update时要注意column_name是否存在,由于ddb类似于nosql的特性,如果对原本不存在的column赋值会导致在原本数据中新增一个字段
(虽然一般不会造成额外影响,但还是需要尽量避免)
1 | UPDATE "TableName" |
在使用单实例Redis时, 我们可以使用./redis-cli -h redis_ip -p redis 6379 --ldb --eval script.lua somekey , arg1 arg2
命令轻松的进入debug模式调试lua脚本
在正常情况下, 进入debug模式后可以使用一系列命令来执行控制脚本的执行, 使用help命令应该可以看到如下界面
在使用Redis时, 通常会使用EXPIRE
, PEXPIRE
系列函数设置生存时间, 当需要获取超时时间时使用TTL
, PTTL
获取剩余的生存时间。
同样的, 还可以使用EXPIREAT
, PEXPIREAT
以unix timestamp格式设置超时时间点, 但需要注意的是, Redis 7.0 之前没有函数能获取设置timestamp, 只能使用TTL
, PTTL
获取剩余的生存时间。
在实际使用中, 经常需要比较新旧生存周期的大小来决定是否更新数据, 如果你很幸运的使用7.0及之后的版本, 可以使用EXPIREAT
, PEXPIREAT
配合GT
参数来设置过期时间, 如果新的过期时间小于已有过期时间, 则会返回0
。
那么老版本的Redis该如何实现这种功能呢?
在terraform中,常见的输出json字符串或创建json文件的手段是使用流式标记, 如下代码所示:
1 | resource "user" "admin" { |
但是这样的写法不仅繁琐,也容易出错,由于字符串中夹杂大量的变量引用,DATA
标记中间的内容很难提供语法检查
常见的错误包括:
并且这些错误属于json语法问题,在terraform plan
甚至apply
期间是无法发现的,等到resource部署之后才被发现,可能会造成无法挽回的结果。
上述代码的json中便缺失一个逗号,读者是否有看出来呢?
为了解决这些问题,建议大家使用jsonencode
函数代替直接编写字符串,得益于tf在语法上的良好兼容,从json迁移到jsonencode
并不需要多少工作。
例如上述代码使用jsonencode可以简单的写成如下形式
1 | resource "user" "admin" { |
可以看到几乎就是简单的使用jsonencode讲原来的内容包了起来。
更进一步的,可以整理成如下形式
1 | resource "service" "portal" { |
或者
1 | resource "service" "portal" { |
由于tf语法对逗号非常宽容,因此不论写不写逗号都不会影响输出的json,同时就算有语法错误,在plan阶段也可以轻易发现,还能少写很多引号。
因此推荐大家在输出json时都使用这种方法。
1 | curl https://get.acme.sh | sh -s [email protected] |
文档: https://github.com/acmesh-official/acme.sh/wiki/dnsapi
1 | export Ali_Key="xxxxxxxxxxxxxxxx" |
1 | acme.sh --install-cert -d your.domain.com --key-file /etc/nginx/your.domain.com.key --fullchain-file /etc/nginx/your.domain.com.pem --reloadcmd "sudo systemctl restart nginx" |