Asciinema - 终端日志记录神器,开发者的福音

我们在做机器学习/深度学习开发的时候,经常会产生如下所示的大量日志:

这些日志如果不保存,转瞬即逝,当我们想要回去翻看某一轮训练日志的时候,会很遗憾的发现找不到了。

现在有了这个 Asciinema 这个神器,我们不仅能找到并导出当时的终端日志,还能够"重播日志"并"分享日志"。非常牛逼:

Asciinema 是使用Python开发的工具,请按下面的流程安装并使用。

1.准备

使用如下命令进行安装

复制代码
pip install asciinema

2.使用

终端输入如下命令,记录你的第一个终端日志:

复制代码
asciinema rec first.cast

输入完成后会显示如下的提示:

ruby 复制代码
(gs3_9) zjr@sgd-linux-1:~/cnn_test$ asciinema rec first.cast
  
asciinema: recording asciicast to first.cast
asciinema: press <ctrl-d> or type "exit" when you're done

意思就是日志会被保存在当前文件夹下的first.cast,如果你想结束录制,按 Ctrl + D 即可。

记录完毕后,以双倍速度重播该日志:

复制代码
asciinema play -s 2 first.cast

或以正常速度但空闲时间限制为 2 秒:

css 复制代码
asciinema play -i 2 first.cast

你也可以在启动终端日志录制时传递 -i 2 给 asciinema rec,将其永久设置在录制中:

css 复制代码
asciinema rec first.cast -i 2

空闲时间的限制使录制更有趣。试试吧。

如果你想在网络上观看和分享,请上传:

复制代码
asciinema upload first.cast

这个命令会将日志记录上传到 asciinema.org,此外,它会打印一个秘密链接,你可以使用该链接在网络浏览器中观看你录制的终端日志:

你可以通过省略文件名一步录制和上传终端的日志:

复制代码
asciinema rec

录制完成后,系统会要求你确认上传。未经你的同意,不会向任何地方发送任何内容。

3.播放日志

查看日志有四种方式,最普通的是通过本地文件进行终端重播:

bash 复制代码
asciinema play /path/to/asciicast.cast

以下键盘快捷键可用:

  • Space- 暂停,
  • .- 按帧步进(暂停时),
  • Ctrl+C- 退出

第二种方式是通过url播放:

ruby 复制代码
asciinema play https://asciinema.org/a/22124.cast
asciinema play http://example.com/demo.cast

这个方式需要你的日志已经上传到asciinema.org中。

第三种方式是通过你自己生成的html页面访问(需要在页面的 HTML 中):

arduino 复制代码
asciinema play http://your_html_path/post.html

第四种方式是通过标准输入输出播放:

bash 复制代码
cat /path/to/asciicast.cast | asciinema play -
# ssh user@host cat asciicast.cast | asciinema play -

可用选项:

  • -i, --idle-time-limit=<sec>- 将重播的终端空闲不动时间闲置为最大<sec>秒数
  • -s, --speed=<factor>- 播放速度

4.导出日志

导出终端日志到文本文件非常简单:

bash 复制代码
asciinema cat existing.cast > terminal_output.txt

所有的终端日志都会被导出到 terminal_output.txt 中,非常方便好用。

以上就是本次分享的所有内容,如果你觉得文章还不错,欢迎关注公众号:Python编程学习圈 ,每日干货分享,或是前往编程学习网,了解更多编程技术知识。

相关推荐
有来技术17 小时前
Spring Boot 4 + Vue3 企业级多租户 SaaS:从共享 Schema 架构到商业化套餐设计
java·vue.js·spring boot·后端
东东51619 小时前
学院个人信息管理系统 (springboot+vue)
vue.js·spring boot·后端·个人开发·毕设
三水不滴19 小时前
Redis缓存更新策略
数据库·经验分享·redis·笔记·后端·缓存
小邓吖20 小时前
自己做了一个工具网站
前端·分布式·后端·中间件·架构·golang
大爱编程♡20 小时前
SpringBoot统一功能处理
java·spring boot·后端
好好研究1 天前
总结SSM设置欢迎页的方式
xml·java·后端·mvc
小马爱打代码1 天前
Spring Boot:第三方 API 调用的企业级容错设计
java·spring boot·后端
csdn2015_1 天前
springboot task
java·spring boot·后端
czlczl200209251 天前
Spring Boot :如何高性能地在 Filter 中获取响应体(Response Body)
java·spring boot·后端
码界奇点1 天前
基于Spring Boot和Vue3的无头内容管理系统设计与实现
java·spring boot·后端·vue·毕业设计·源代码管理