mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
translated
This commit is contained in:
parent
60dc6eaca4
commit
480db25565
@ -1,164 +0,0 @@
|
|||||||
[#]: subject: "Record your terminal session with Asciinema"
|
|
||||||
[#]: via: "https://opensource.com/article/22/1/record-terminal-session-asciinema"
|
|
||||||
[#]: author: "Seth Kenlon https://opensource.com/users/seth"
|
|
||||||
[#]: collector: "lujun9972"
|
|
||||||
[#]: translator: "geekpi"
|
|
||||||
[#]: reviewer: " "
|
|
||||||
[#]: publisher: " "
|
|
||||||
[#]: url: " "
|
|
||||||
|
|
||||||
Record your terminal session with Asciinema
|
|
||||||
======
|
|
||||||
Show don't tell with Asciinema, an open source terminal session
|
|
||||||
recorder.
|
|
||||||
![4 different color terminal windows with code][1]
|
|
||||||
|
|
||||||
Support calls are important and often satisfying in the end, but the act of clear communication can be arduous for everyone involved. If you've ever been on a support call, you've probably spent several minutes spelling out even the shortest commands and explaining in detail where the spaces and returns fall. While it's often easier to just seize control of a user's computer, that's not really the best way to educate. What you might try instead is sending a user a screen recording, but one that they can copy commands from and paste into their own terminal.
|
|
||||||
|
|
||||||
Asciinema is an open source terminal session recorder. Similar to the `script` and `scriptreplay` commands, Asciinema records exactly what your terminal displays. It saves your "movie" recording to a text file and then replays it on demand. You can upload your movie to Asciinema.org and share them just as you would any other video on the internet, and you can even embed your movie into a webpage.
|
|
||||||
|
|
||||||
### Install Asciinema
|
|
||||||
|
|
||||||
On Linux, you can install Asciinema using your package manager.
|
|
||||||
|
|
||||||
On Fedora, CentOS, Mageia, or similar:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ sudo dnf install asciinema`
|
|
||||||
```
|
|
||||||
|
|
||||||
On Debian, Linux Mint, or similar:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ sudo apt install asciinema`
|
|
||||||
```
|
|
||||||
|
|
||||||
On macOS, you can install using Homebrew:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ sudo brew install asciinema`
|
|
||||||
```
|
|
||||||
|
|
||||||
On BSD and any other platform using [Pkgsrc][2]:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
$ cd /usr/pkgsrc/misc/py-asciinema
|
|
||||||
|
|
||||||
$ sudo bmake install clean
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
### Making movies out of text
|
|
||||||
|
|
||||||
To start recording with Asciinema, you use the `rec` subcommand:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
$ asciinema rec mymovie.cast
|
|
||||||
|
|
||||||
asciinema: recording asciicast to mymovie.cast
|
|
||||||
|
|
||||||
asciinema: press <ctrl-d> or type "exit" when you're done
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
Some friendly output alerts you that you're recording, and it tells you how to stop: Press **Ctrl+D** or just type `exit`.
|
|
||||||
|
|
||||||
Everything you do in your terminal while Asciinema is active gets recorded. This includes input, output, errors, awkward pauses, mistakes, or successes. If you see it in your terminal during recording, it makes the cut.
|
|
||||||
|
|
||||||
When you're finished demonstrating how the terminal works, press **Ctrl+D** or type `exit` to stop the recording.
|
|
||||||
|
|
||||||
In this example, the resulting file, `mymovie.cast` is a collection of timestamps and actions that serve as a script (in the sense of a movie script) for the playback mechanism.
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
{"version": 2, "width": 139, "height": 36, "timestamp": 1641457358, "env": {"SHELL": "/bin/bash", "TERM": "xterm-256color"}}
|
|
||||||
|
|
||||||
[0.05351, "o", "\u001b]0;seth:~\u0007"]
|
|
||||||
|
|
||||||
[0.05393, "o", "\u001b[1;31m$ \u001b[00m"]
|
|
||||||
|
|
||||||
[1.380059, "o", "e"]
|
|
||||||
|
|
||||||
[1.443823, "o", "c"]
|
|
||||||
|
|
||||||
[1.514674, "o", "h"]
|
|
||||||
|
|
||||||
[1.595238, "o", "o"]
|
|
||||||
|
|
||||||
[1.789562, "o", " "]
|
|
||||||
|
|
||||||
[2.09658, "o", "\""]
|
|
||||||
|
|
||||||
[2.19683, "o", "h"]
|
|
||||||
|
|
||||||
[2.403994, "o", "e"]
|
|
||||||
|
|
||||||
[2.466784, "o", "l"]
|
|
||||||
|
|
||||||
[2.711183, "o", "lo"]
|
|
||||||
|
|
||||||
[3.120852, "o", "\""]
|
|
||||||
|
|
||||||
[3.427886, "o", "\r\nhello\r\n"]
|
|
||||||
|
|
||||||
[...]
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
If you've made a mistake, you can cut the mistake by removing the lines recreating the error. Should you find yourself making lots of edits or belaboring long pauses during the recording, you can install and use the [asciinema-edit][3] utility, which can trim out blocks of "footage" by timestamps of your definition, or by eliminating idle time.
|
|
||||||
|
|
||||||
### Playing an Asciinema movie
|
|
||||||
|
|
||||||
You can playback your Asciinema using the `play` subcommand:
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ asciinema play mymovie.cast`
|
|
||||||
```
|
|
||||||
|
|
||||||
This takes over your terminal session and makes it into the nearest equivalent of the Silver Screen as it's likely ever to be (aside from that time you watched Star Wars in ASCII over `telnet`). Your text-based movie plays—demonstrating for your users exactly how a complex task gets done. Of course, the _actual_ commands getting played don't actually execute. This isn't a shell script in action, so even though you may have created a file `hello.txt` in your movie, there won't be a new `hello.txt` after playback. This is just for show.
|
|
||||||
|
|
||||||
And yet it's more than just a show. You can pause Asciinema movies, select the text you see on the screen and paste it into an active terminal to run the command. Asciinema is useful documentation. It shows users how to do a task, and it allows them to copy and paste to ensure accuracy.
|
|
||||||
|
|
||||||
### Upload your Asciinema movie
|
|
||||||
|
|
||||||
No Asciinema movie has yet reached a blockbuster status, but you can upload yours to Asciinema.org and share it with the world nevertheless.
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
`$ asciinema upload mymovie.cast`
|
|
||||||
```
|
|
||||||
|
|
||||||
If you're used to YouTube upload times, you'll be pleasantly surprised by how quickly Asciinema movies transfer. A `.cast` file is usually only a few kilobytes, or at the most a few megabytes, so the upload is nearly instantaneous. You don't need an account to share your movie, but all unclaimed movies get deleted after seven days. To preserve your masterpiece, you can open an account on Asciinema and then sit back and wait for the Academy to call.
|
|
||||||
|
|
||||||
### Asciinema as documentation
|
|
||||||
|
|
||||||
Asciinema is a great way to demonstrate even the most basic of concepts. Because it retains the ability to copy and paste code from the recording, provides the ability to pause and play on-demand, and is completely accurate in what it portrays, it's not just as good as a screen recording. It's much, much better. Whether you use it to show off your terminal skills to your friends or whether you use it to educate colleagues and students, Asciinema is an invaluable, social, and accessible tool.
|
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
via: https://opensource.com/article/22/1/record-terminal-session-asciinema
|
|
||||||
|
|
||||||
作者:[Seth Kenlon][a]
|
|
||||||
选题:[lujun9972][b]
|
|
||||||
译者:[译者ID](https://github.com/译者ID)
|
|
||||||
校对:[校对者ID](https://github.com/校对者ID)
|
|
||||||
|
|
||||||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
|
||||||
|
|
||||||
[a]: https://opensource.com/users/seth
|
|
||||||
[b]: https://github.com/lujun9972
|
|
||||||
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/freedos.png?itok=aOBLy7Ky (4 different color terminal windows with code)
|
|
||||||
[2]: https://opensource.com/article/19/11/pkgsrc-netbsd-linux
|
|
||||||
[3]: https://github.com/cirocosta/asciinema-edit
|
|
@ -0,0 +1,163 @@
|
|||||||
|
[#]: subject: "Record your terminal session with Asciinema"
|
||||||
|
[#]: via: "https://opensource.com/article/22/1/record-terminal-session-asciinema"
|
||||||
|
[#]: author: "Seth Kenlon https://opensource.com/users/seth"
|
||||||
|
[#]: collector: "lujun9972"
|
||||||
|
[#]: translator: "geekpi"
|
||||||
|
[#]: reviewer: " "
|
||||||
|
[#]: publisher: " "
|
||||||
|
[#]: url: " "
|
||||||
|
|
||||||
|
用 Asciinema 记录你的终端会话
|
||||||
|
======
|
||||||
|
用开源终端会话记录器 Asciinema 演示。
|
||||||
|
![4 different color terminal windows with code][1]
|
||||||
|
|
||||||
|
支持电话是很重要的,而且最后往往是令人满意的,但明确的沟通行为对每个参与的人来说都是艰巨的。如果你曾经参加过支持电话,你可能已经花了好几分钟拼出了最短的命令,并详细解释了空格和回车的位置。虽然直接夺取用户电脑的控制权往往更容易,但这并不是真正的教育的最佳方式。你可以尝试向用户发送一个屏幕记录,但是他们可以复制命令并粘贴到自己的终端。
|
||||||
|
|
||||||
|
Asciinema 是一个开源的终端会话记录器。与 `script` 和 `scriptreplay` 命令类似,Asciinema 准确记录了你的终端显示。它将你的“电影”记录保存到一个文本文件中,然后根据需要进行重放。你可以把你的电影上传到 Asciinema.org,就像你在互联网上分享任何其他视频一样,你甚至可以把你的电影嵌入到网页中。
|
||||||
|
|
||||||
|
### 安装 Asciinema
|
||||||
|
|
||||||
|
在 Linux 上,你可以使用你的包管理器安装 Asciinema。
|
||||||
|
|
||||||
|
在 Fedora、CentOS、Mageia 或类似系统上:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ sudo dnf install asciinema`
|
||||||
|
```
|
||||||
|
|
||||||
|
在 Debian、Linux Mint 或类似系统上:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ sudo apt install asciinema`
|
||||||
|
```
|
||||||
|
|
||||||
|
在 macOS 上,你可以用 Homebrew 安装:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ sudo brew install asciinema`
|
||||||
|
```
|
||||||
|
|
||||||
|
在 BSD 和任何其他平台上使用 [Pkgsrc][2]:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
$ cd /usr/pkgsrc/misc/py-asciinema
|
||||||
|
|
||||||
|
$ sudo bmake install clean
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
### 从文本中制作电影
|
||||||
|
|
||||||
|
要用 Asciinema 开始录制,你可以使用 `rec` 子命令:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
$ asciinema rec mymovie.cast
|
||||||
|
|
||||||
|
asciinema: recording asciicast to mymovie.cast
|
||||||
|
|
||||||
|
asciinema: press <ctrl-d> or type "exit" when you're done
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
一些友好的输出提醒你,你正在录制,并告诉你如何停止。按 **Ctrl+D** 或直接输入 `exit`。
|
||||||
|
|
||||||
|
当 Asciinema 处于活动状态时,你在终端所做的一切都会被记录下来。这包括输入、输出、错误、尴尬的停顿、错误或成功。如果你在录制过程中在你的终端中看到它,它会被剪辑。
|
||||||
|
|
||||||
|
当你演示完终端如何工作时,按 **Ctrl+D** 或输入 `exit` 来停止记录。
|
||||||
|
|
||||||
|
在这个例子中,产生的文件 `mymovie.cast` 是一个时间戳和动作的集合,作为播放机制的脚本(在电影脚本的意义上)。
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
{"version": 2, "width": 139, "height": 36, "timestamp": 1641457358, "env": {"SHELL": "/bin/bash", "TERM": "xterm-256color"}}
|
||||||
|
|
||||||
|
[0.05351, "o", "\u001b]0;seth:~\u0007"]
|
||||||
|
|
||||||
|
[0.05393, "o", "\u001b[1;31m$ \u001b[00m"]
|
||||||
|
|
||||||
|
[1.380059, "o", "e"]
|
||||||
|
|
||||||
|
[1.443823, "o", "c"]
|
||||||
|
|
||||||
|
[1.514674, "o", "h"]
|
||||||
|
|
||||||
|
[1.595238, "o", "o"]
|
||||||
|
|
||||||
|
[1.789562, "o", " "]
|
||||||
|
|
||||||
|
[2.09658, "o", "\""]
|
||||||
|
|
||||||
|
[2.19683, "o", "h"]
|
||||||
|
|
||||||
|
[2.403994, "o", "e"]
|
||||||
|
|
||||||
|
[2.466784, "o", "l"]
|
||||||
|
|
||||||
|
[2.711183, "o", "lo"]
|
||||||
|
|
||||||
|
[3.120852, "o", "\""]
|
||||||
|
|
||||||
|
[3.427886, "o", "\r\nhello\r\n"]
|
||||||
|
|
||||||
|
[...]
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
如果你犯了一个错误,你可以通过删除重现错误的行来去除这个错误。如果你发现自己在录制过程中做了很多编辑或冗长的停顿,你可以安装并使用 [asciinema-edit][3] 工具,它可以通过你定义的时间戳或消除空闲时间来剪掉这些“镜头”片段。
|
||||||
|
|
||||||
|
### 播放 Asciinema 电影
|
||||||
|
|
||||||
|
你可以使用 `play` 子命令播放你的 Asciinema:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ asciinema play mymovie.cast`
|
||||||
|
```
|
||||||
|
|
||||||
|
这将接管你的终端会话,并使其成为最接近银幕的形式(除了那次你通过 `telnet` 观看 ASCII 格式的星球大战)。你的基于文本的电影播放,向你的用户展示一个复杂的任务是如何完成的。当然,播放的_实际_命令并不真正执行。这不是一个正在运行的 shell 脚本,所以即使你在电影中创建了一个 `hello.txt` 文件,在播放后也不会有一个新的 `hello.txt`。这只是为了展示。
|
||||||
|
|
||||||
|
然而,它不仅仅是一个展示。你可以暂停 Asciinema 电影,选择你在屏幕上看到的文本,并将其粘贴到一个活动终端,以运行该命令。Asciinema 是有用的文档。它向用户展示了如何完成一项任务,并允许他们进行复制和粘贴以确保准确性。
|
||||||
|
|
||||||
|
### 上传你的 Asciinema 电影
|
||||||
|
|
||||||
|
目前还没有 Asciinema 电影达到大片的地位,但你可以把你的电影上传到 Asciinema.org,与全世界分享。
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ asciinema upload mymovie.cast`
|
||||||
|
```
|
||||||
|
|
||||||
|
如果你习惯了 YouTube 的上传时间,你会对 Asciinema 电影的传输速度感到惊喜。一个 `.cast` 文件通常只有几千字节,或最多几兆字节,所以上传几乎是瞬间完成的。你不需要一个账户来分享你的电影,但所有无人认领的电影在七天后会被删除。为了保存你的杰作,你可以在 Asciinema 上开设一个账户,然后坐等学院的召唤。
|
||||||
|
|
||||||
|
### Asciinema 作为文档
|
||||||
|
|
||||||
|
Asciinema 是演示最基本概念的好方法。因为它保留了从录制中复制和粘贴代码的能力,提供了按需暂停和播放的能力,并且完全准确地描绘了它的内容,它不仅仅是和屏幕录像一样好。它要好得多得多。无论你是用它来向你的朋友炫耀你的终端技能,还是用它来教育同事和学生,Asciinema 都是一个无价的、社交的、可利用的工具。
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://opensource.com/article/22/1/record-terminal-session-asciinema
|
||||||
|
|
||||||
|
作者:[Seth Kenlon][a]
|
||||||
|
选题:[lujun9972][b]
|
||||||
|
译者:[geekpi](https://github.com/geekpi)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]: https://opensource.com/users/seth
|
||||||
|
[b]: https://github.com/lujun9972
|
||||||
|
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/freedos.png?itok=aOBLy7Ky (4 different color terminal windows with code)
|
||||||
|
[2]: https://opensource.com/article/19/11/pkgsrc-netbsd-linux
|
||||||
|
[3]: https://github.com/cirocosta/asciinema-edit
|
Loading…
Reference in New Issue
Block a user