老闆對我說,你要是能找出公司里摸魚的人,我就給你漲薪!於是我寫了兩個腳本……

来源:https://www.cnblogs.com/yychuyu/archive/2020/05/16/12901263.html
-Advertisement-
Play Games

最近老闆沉迷於抖音,時不時在那邊呵呵傻笑,於是我偷偷湊過去一看,好家伙,他正在看朱一旦~ 這天,老闆幽幽地走到我身邊,淡淡地跟我說,良許,你要是能找到公司里混水摸魚的人,我就給你漲薪!我回過頭,望著他朱一旦似的枯燥笑臉,自信說道,放心,有我在,公司里就沒有摸魚的人! 作為一名資深摸魚專家,熟知 10 ...


最近老闆沉迷於抖音,時不時在那邊呵呵傻笑,於是我偷偷湊過去一看,好家伙,他正在看朱一旦~

這天,老闆幽幽地走到我身邊,淡淡地跟我說,良許,你要是能找到公司里混水摸魚的人,我就給你漲薪!我回過頭,望著他朱一旦似的枯燥笑臉,自信說道,放心,有我在,公司里就沒有摸魚的人!

作為一名資深摸魚專家,熟知 108 種摸魚手段,精通 18 般躲避領導突擊檢查方法,所以,誰想摸魚都逃不出我的火眼精睛。

作為一名 Linux 程式員,每天都要跟伺服器打交道,那麼想要找到誰在摸魚,只要關註他的兩個指標就行:

  • 登錄系統次數
  • 登錄系統時長

Linux 系統給我們提供了大量非常實用的命令,當然有一些命令可以用來查看系統各用戶在系統上登錄的次數,以及使用系統總時間。用戶的這些信息是保存在 /var/log/wtmp 文件里,所以我們就可以通過一些簡單的命令把我們想要的信息提取出來。

這些信息就是摸魚的證據!

使用 last 命令獲取用戶登錄信息

一個可以實現這個目的的命令就是 last 命令。這個命令可以列出用戶登錄的詳細信息,可供我們進行追溯。它的典型輸出如下:

$ last | head -5 | tr -s " "
liangxu pts/0 192.168.0.14 Wed Jan 14 09:44 still logged in
liangxu pts/0 192.168.0.14 Wed Jan 14 09:41 - 09:41 (00:00)
liangxu pts/0 192.168.0.14 Wed Jan 14 09:40 - 09:41 (00:00)
alex pts/1 192.168.0.18 Wed Jan 14 09:38 still logged in
liangxu pts/0 192.168.0.14 Tue Jan 13 06:15 - 18:18 (00:24)

在上面這行命令中,tr -s " " 表示將多個空格合併為一個,這樣可以節約篇幅。如果沒有加上 tr 命令的話,它的輸出會類似下麵這樣:

$ last | head -5
liangxu      pts/0        192.168.0.14     Wed Jan 14 09:44   still logged in
liangxu      pts/0        192.168.0.14     Wed Jan 14 09:41 - 09:41  (00:00)
liangxu      pts/0        192.168.0.14     Wed Jan 14 09:40 - 09:41  (00:00)
alex         pts/1        192.168.0.18     Wed Jan 14 09:38   still logged in
liangxu      pts/0        192.168.0.14     Wed Jan 14 09:15 - 09:40  (00:24)

像上面那樣 last 命令沒有跟任何參數的話,它會列出所有用戶的登錄信息。如果你只想看某個用戶登錄情況,那麼只需在 last 後面跟上具體的用戶名即可,即:

$ last username

這裡還加了 head -5 命令,它的作用是只列出 last 命令結果的前 5 條信息。如果不加這個命令的話,那麼出來的結果將很長,我們可以用 wc 命令稍微瞧一眼:

$ last | wc -l

所以,通過 last 命令可以看到每個人的登錄情況,摸魚的小伙伴們,請接招!

第一招:統計每個用戶登錄次數

在 last 命令的結果里,用戶每登錄一次,就會產生一條記錄,所以這裡我們就可以使用這些記錄來統計每個用戶登錄的次數。

$ for user in `ls /home`; do echo -ne "$user\t"; last $user | wc -l; done
dorothy 21
dory    13
eel     29
jadep   124
jdoe    27
jimp    42
alex    9
shark   17
liangxu     423
test    2
waynek  201

在上面的命令里,我們先獲取 home 目錄下所有用戶,然後依次使用 last 命令獲取他們的登錄情況,再使用 wc 命令統計他們的登錄次數。

當然,為了查看大家的登錄次數,每次都要敲這麼長的一條命令,那真的很讓人抓狂。所以一個比較好的辦法就是將這條命令直接寫成 shell 腳本,下次我們想用的時候就可以直接運行它了。

我們可以新建一個 show_user_logins.sh 腳本,然後使用 vim 寫入以下內容:

#!/bin/bash

echo -n "Logins since "
who /var/log/wtmp | head -1 | awk '{print $3}'
echo "======================="

for user in `ls /home`
do
  echo -ne "$user\t"
  last $user | wc -l
done

寫完之後按 :wq 保存退出。再之後使用命令 chmod +x show_user_logins.sh 使這個腳本具有可執行屬性。

一切準備就緒後我們就可以運行這個腳本,可以看到得到的結果跟我們在命令行里手動敲的命令結果一致。

$ ./show_user_logins
Logins since 2019-12-05
=======================
dorothy 21
dory    13
eel     29
jadep   124
jdoe    27
jimp    42
alex    9
shark   17
liangxu     423
test    2
waynek  201

通過第一招,摸魚的小伙伴已經浮出水面,並受到重重一擊:

但作為資深摸魚專家,我肯定知道,用戶每登錄一次就會有一次記錄,那麼多登幾次就會顯得自己很勤快,所以使用這種方法很容易躲避追擊。

不急,我還有第二招,想在我眼皮底下摸魚沒那麼容易!

2020 精選 阿裡/騰訊等一線大廠 面試、簡歷、進階、電子書 公眾號「良許Linux」後臺回覆「資料」免費獲取

第二招:統計每個用戶登錄時長

last 命令只能統計用戶的登錄記錄,但不能統計用戶的登錄時長。如果想統計每個用戶的登錄時長,那麼就要使用另一個命令了:ac 命令。

ac 命令使用方法很簡單,只需在 ac 後面跟上你想統計的用戶即可,如下:

$ ac alex
        total       31.61

這個結果表示用戶 alex 在這臺電腦上的總登錄時長是 31.61 小時(ac 命令統計出來的結果預設單位是 小時 )。

我們可以仿照上面寫出統計每個用戶登錄時長的命令:

$ for user in `ls /home`; do ac $user | sed "s/total/$user\t/" ; done
        dorothy         9.12
        dory            1.67
        eel             4.32
	  …

同樣地,這裡先獲取 home 目錄下所有用戶名,然後再將這些用戶名作為參數傳給 ac 命令,就可以統計出來所有每個用戶的登錄時長了。

我們可以從上面的 ac 命令結果看到,它的執行結果都是 total + 時長 ,如果所有用戶的結果都這樣,那麼我們就無法區別誰是誰了。所以我們在這裡再使用 sed 命令,將 total 替換為具體的用戶名,以作區分。

這裡還有個小小的瑕疵,就是每個用戶名之前會空出幾個空格,雖然不影響結果,但看起來有點彆扭,我們可以再使用一個 sed 命令將其去掉。

$ for user in `ls /home`; do ac $user | sed "s/^\t//" | sed "s/total/$user\t/" ; done
dorothy         9.12
dory            1.67
eel             4.32
...

同樣地,我們可以將以上命令寫成腳本,後面就可以更方便使用。這裡我們所使用的腳本名稱是 show_user_hours.sh ,當然你可以自定義。

#!/bin/bash

echo -n "hours online since "
who /var/log/wtmp | head -1 | awk '{print $3}'
echo "============================="

for user in `ls /home`
do
  ac $user | sed "s/^\t//" | sed "s/total/$user\t/"
done

腳本的執行結果如下,同樣與手敲命令結果一致:

$ ./show_user_hours
hours online since 2019-12-05
=============================
dorothy        70.34
dory            4.67
eel            17.05
jadep         186.04
jdoe           28.20
jimp           11.49
alex           11.61
shark          13.04
liangxu        3563.60
test            1.00
waynek        312.00

通過第二招,摸魚的小伙伴已經無處遁形,並受到了 100 點傷害:

後續

寫完這兩個腳本,我十分開心,於是跑過去找老闆領功。看著自己兩個都是排名第一,我估計升職加薪,迎娶白富美的日子不遠了!

老闆看了我的腳本和結果,依然一副朱一旦式的枯燥笑容,默默地給我看一眼朱一旦開除十佳員工的視頻,意味深長地看著我……

完了……

看完的都是真愛,點個贊再走唄?您的「三連」就是良許持續創作的最大動力!

  1. 關註原創公眾號「良許Linux」,第一時間獲取最新Linux乾貨!
  2. 公眾號後臺回覆【資料】【面試】【簡歷】獲取精選一線大廠面試、自我提升、簡歷等資料。
  3. 關註我的博客:lxlinux.net

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 需求提出: GridControl表格控制項的使用過程中,如果表格能根據單元格數據的範圍,擁有不同的Appearance,包括前景色,背景色,圖標甚至進度條等,表格的表現力將大大增加。此時可在表格的設計視窗添加對應的Format Rules,設置相應範圍及外觀即可。 此處針對的數據類型基本屬於數值類型 ...
  • 用戶管理 1 選擇 1.1 增加一個新用戶admin,許可權是root?(A) ​ A.useradd u 0 o admin B.useradd g 0 o admin C.useradd g 1 o admin D.useradd u 1 o admin 1.2 普通用戶的ID一般是(BC) ​ ...
  • 磁碟管理 1 選擇 1 若一臺電腦的記憶體為8GB,則交換分區的大小通常是(c) A.64GB B.128GB C.16GB D.32GB 2 若一臺電腦的記憶體為128M,則交換分區的大小通常為(C) A.64M B.128M C.256M D.512M 3在安裝Linux操作系統時,必須創建的兩 ...
  • 如何從安裝了Windows的工作電腦連遠程接到Linux伺服器?其實有很多軟體,比如 PuTTY、XShell、CRT、MobaXterm等等。不過還是 PuTTY最簡單易用、無需安裝、並且開源免費。PuTTY其實是一個軟體套裝,裡邊除了最常用的putty之外,還包含了像 pscp、psftp等可以 ...
  • 什麼是容器?在生活中我們常見的容器有各種瓶瓶罐罐、各種能夠容納其它物料的東西叫容器;容器的特點就是有著很好的隔離作用,使得不同的物料互相隔離;除此之外容器還方便運輸、方便儲存;這是生活中所說的容器,以及它的特點;在電腦領域中,所謂容器不外乎也有同生活中的容器的特點,隔離,方便“運輸”(電腦中的... ...
  • 文件操作 help——列出cygwin支持的所有命令 pwd——顯示當前的路徑 ls——顯示當前文件夾中的所有文件 mkdir——建立目錄 rmdir——刪除目錄 rm——刪除文件 cat bj.log ——打開文件 grep 查找命令 cat bj.log grep Baiduspider >xi ...
  • 本文檔是根據網路資料整理的,參考文章眾多,若有雷同,純屬巧合! Linux 目錄 - /:根目錄,一般只存放目錄,不存放文件 - /bin -> /usr/bin:可執行二進位文件的目錄,也是常用命令目錄,如常用的命令 ls、cat、mv 等 - /boot:該目錄中存放系統的內核文件,系統引導時使 ...
  • 最近研究CentOS8 發現右鍵打開後沒有終端這一項: 1.經過查詢發現是沒有安裝一個包 2.使用命令進行安裝並重啟: [root@base ~]# yum -y install nautilus-open-terminal CentOS-BaseOS-8 - Media 3.8 MB/s | 3. ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...