中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Linux上記錄和重放終端會話

發布時間:2021-08-18 09:40:25 來源:億速云 閱讀:171 作者:chen 欄目:系統運維

這篇文章主要講解了“怎么在Linux上記錄和重放終端會話”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么在Linux上記錄和重放終端會話”吧!

通常,Linux 管理員們都使用 history 命令來跟蹤在先前的會話中執行過哪些命令,但是 history 命令的局限性在于它不存儲命令的輸出。在某些情況下,我們要檢查上一個會話的命令輸出,并希望將其與當前會話進行比較。除此之外,在某些情況下,我們正在對 Linux 生產環境中的問題進行故障排除,并希望保存所有終端會話活動以供將來參考,因此在這種情況下,script 命令就變得很方便。

script 是一個命令行工具,用于捕獲/記錄你的 Linux 服務器終端會話活動,以后可以使用 scriptreplay 命令重放記錄的會話。在本文中,我們將演示如何安裝 script 命令行工具以及如何記錄 Linux 服務器終端會話活動,然后,我們將看到如何使用 scriptreplay 命令來重放記錄的會話。

安裝 script 工具

在 RHEL 7/ CentOS 7 上安裝 script 工具

script 命令由 RPM 包 util-linux 提供,如果你沒有在你的 CentOS 7 / RHEL 7 系統上安裝它,運行下面的 yum 安裝它:

[root@linuxtechi ~]# yum install util-linux -y
在 RHEL 8 / CentOS 8 上安裝 script 工具

運行下面的 dnf 命令來在 RHEL 8 / CentOS 8 上安裝 script 工具:

[root@linuxtechi ~]# dnf install util-linux -y
在基于 Debian 的系統(Ubuntu / Linux Mint)上安裝 script 工具

運行下面的 apt-get 命令來安裝 script 工具:

root@linuxtechi ~]# apt-get install util-linux -y

如何使用 script 工具

直接使用 script 命令,在終端上鍵入 script 命令,然后按回車,它將開始在名為 typescript 的文件中捕獲當前的終端會話活動。

[root@linuxtechi ~]# scriptScript started, file is typescript[root@linuxtechi ~]#

要停止記錄會話活動,請鍵入 exit 命令,然后按回車:

[root@linuxtechi ~]# exitexitScript done, file is typescript[root@linuxtechi ~]#

script 命令的語法格式:

~] # script {options}  {file_name}

能在 script 命令中使用的不同選項:

怎么在Linux上記錄和重放終端會話

options-script-command

讓我們開始通過執行 script 命令來記錄 Linux 終端會話,然后執行諸如 wroute -ndf -hfree -h,示例如下所示:

怎么在Linux上記錄和重放終端會話

script-examples-linux-server

正如我們在上面看到的,終端會話日志保存在文件 typescript 中:

現在使用 cat / vi 命令查看 typescript 文件的內容,

[root@linuxtechi ~]# ls -l typescript-rw-r--r--. 1 root root 1861 Jun 21 00:50 typescript[root@linuxtechi ~]#

怎么在Linux上記錄和重放終端會話

typescript-file-content-linux

以上內容確認了我們在終端上執行的所有命令都已保存在 typescript 文件中。

在 script 命令中使用定制文件名

假設我們要使用自定義文件名來執行 script 命令,可以在 script 命令后指定文件名。在下面的示例中,我們使用的文件名為 session-log-(當前日期時間).txt

[root@linuxtechi ~]# script sessions-log-$(date +%d-%m-%Y-%T).txtScript started, file is sessions-log-21-06-2019-01:37:39.txt[root@linuxtechi ~]#

現在運行該命令并輸入 exit

[root@linuxtechi ~]# exitexitScript done, file is sessions-log-21-06-2019-01:37:39.txt[root@linuxtechi ~]#

附加命令輸出到 script 記錄文件

假設 script 命令已經將命令輸出記錄到名為 session-log.txt 的文件中,現在我們想將新會話命令的輸出附加到該文件中,那么可以在 script 命令中使用 -a 選項。

[root@linuxtechi ~]# script -a sessions-log.txtScript started, file is sessions-log.txt[root@linuxtechi ~]# xfs_info /dev/mapper/centos-rootmeta-data=/dev/mapper/centos-root isize=512    agcount=4, agsize=2746624 blks         =                       sectsz=512   attr=2, projid32bit=1         =                       crc=1        finobt=0 spinodes=0data     =                       bsize=4096   blocks=10986496, imaxpct=25         =                       sunit=0      swidth=0 blksnaming   =version 2              bsize=4096   ascii-ci=0 ftype=1log      =internal               bsize=4096   blocks=5364, version=2         =                       sectsz=512   sunit=0 blks, lazy-count=1realtime =none                   extsz=4096   blocks=0, rtextents=0[root@linuxtechi ~]# exitexitScript done, file is sessions-log.txt[root@linuxtechi ~]#

要查看更新的會話記錄,使用 cat session-log.txt 命令。

無需 shell 交互而捕獲命令輸出到 script 記錄文件

假設我們要捕獲命令的輸出到會話記錄文件,那么使用 -c 選項,示例如下所示:

[root@linuxtechi ~]# script -c "uptime && hostname && date" root-session.txtScript started, file is root-session.txt 01:57:40 up  2:30,  3 users,  load average: 0.00, 0.01, 0.05linuxtechiFri Jun 21 01:57:40 EDT 2019Script done, file is root-session.txt[root@linuxtechi ~]#

以靜默模式運行 script 命令

要以靜默模式運行 script 命令,請使用 -q 選項,該選項將禁止 script 的啟動和完成消息,示例如下所示:

[root@linuxtechi ~]# script -c "uptime && date" -q root-session.txt 02:01:10 up  2:33,  3 users,  load average: 0.00, 0.01, 0.05Fri Jun 21 02:01:10 EDT 2019[root@linuxtechi ~]#

要將時序信息記錄到文件中并捕獲命令輸出到單獨的文件中,這可以通過在 script 命令中傳遞時序文件(-timing)實現,示例如下所示:

語法格式:

~ ]# script -t <timing-file-name>  {file_name}
[root@linuxtechi ~]# script --timing=timing.txt session.logScript started, file is session.log[root@linuxtechi ~]# uptime 02:27:59 up  3:00,  3 users,  load average: 0.00, 0.01, 0.05[root@linuxtechi ~]# dateFri Jun 21 02:28:02 EDT 2019[root@linuxtechi ~]# free -h              total        used        free      shared  buff/cache   availableMem:           3.9G        171M        2.0G        8.6M        1.7G        3.3GSwap:          3.9G          0B        3.9G[root@linuxtechi ~]# whoamiroot[root@linuxtechi ~]# exitexitScript done, file is session.log[root@linuxtechi ~]#[root@linuxtechi ~]# ls -l session.log timing.txt-rw-r--r--. 1 root root 673 Jun 21 02:28 session.log-rw-r--r--. 1 root root 414 Jun 21 02:28 timing.txt[root@linuxtechi ~]#

重放記錄的 Linux 終端會話活動

現在,使用 scriptreplay 命令重放錄制的終端會話活動。

注意:scriptreplay 也由 RPM 包 util-linux 提供。scriptreplay 命令需要時序文件才能工作。

[root@linuxtechi ~]# scriptreplay --timing=timing.txt session.log

上面命令的輸出將如下所示,

怎么在Linux上記錄和重放終端會話

記錄所有用戶的 Linux 終端會話活動

在某些關鍵業務的 Linux 服務器上,我們希望跟蹤所有用戶的活動,這可以使用 script 命令來完成,將以下內容放在 /etc/profile 文件中,

[root@linuxtechi ~]# vi /etc/profile&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;if [ "x$SESSION_RECORD" = "x" ]thentimestamp=$(date +%d-%m-%Y-%T)session_log=/var/log/session/session.$USER.$$.$timestampSESSION_RECORD=startedexport SESSION_RECORDscript -t -f -q 2>${session_log}.timing $session_logexitfi&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;&hellip;

保存文件并退出。

/var/log 文件夾下創建 session 目錄:

[root@linuxtechi ~]# mkdir /var/log/session

給該文件夾指定權限:

[root@linuxtechi ~]# chmod 777 /var/log/session/[root@linuxtechi ~]#

現在,驗證以上代碼是否有效。在我正在使用 pkumar 用戶的情況下,登錄普通用戶到 Linux 服務器:

~ ] # ssh root@linuxtechiroot@linuxtechi's password:[root@linuxtechi ~]$ uptime 04:34:09 up  5:06,  3 users,  load average: 0.00, 0.01, 0.05[root@linuxtechi ~]$ dateFri Jun 21 04:34:11 EDT 2019[root@linuxtechi ~]$ free -h              total        used        free      shared  buff/cache   availableMem:           3.9G        172M        2.0G        8.6M        1.7G        3.3GSwap:          3.9G          0B        3.9G[root@linuxtechi ~]$ iduid=1001(pkumar) gid=1002(pkumar) groups=1002(pkumar) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023[root@linuxtechi ~]$ whoamipkumar[root@linuxtechi ~]$ exit Login as root and view user&rsquo;s linux terminal session activity [root@linuxtechi ~]# cd /var/log/session/[root@linuxtechi session]# ls -l | grep pkumar-rw-rw-r--. 1 pkumar pkumar 870 Jun 21 04:34 session.pkumar.19785.21-06-2019-04:34:05-rw-rw-r--. 1 pkumar pkumar 494 Jun 21 04:34 session.pkumar.19785.21-06-2019-04:34:05.timing[root@linuxtechi session]#

怎么在Linux上記錄和重放終端會話

Session-output-file-linux

我們還可以使用 scriptreplay 命令來重放用戶的終端會話活動:

[root@linuxtechi session]# scriptreplay --timing session.pkumar.19785.21-06-2019-04\:34\:05.timing session.pkumar.19785.21-06-2019-04\:34\:05

感謝各位的閱讀,以上就是“怎么在Linux上記錄和重放終端會話”的內容了,經過本文的學習后,相信大家對怎么在Linux上記錄和重放終端會話這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

承德县| 德江县| 桂东县| 永修县| 长泰县| 丹东市| 毕节市| 鹰潭市| 安顺市| 乌海市| 洛阳市| 安康市| 湘西| 清苑县| 汝南县| 会宁县| 崇义县| 乡城县| 台中市| 沁源县| 柳河县| 依安县| 乌兰浩特市| 东台市| 鄂托克旗| 遂川县| 尚义县| 阿克苏市| 宜州市| 昆山市| 博湖县| 县级市| 镇江市| 什邡市| 原平市| 施秉县| 信丰县| 岳阳县| 尚志市| 常山县| 阜南县|