公司購買了Zoho公司的資產管理軟件AssetExplorer,該資產管理軟件能夠經過在客戶機電腦上安裝Agent客戶端軟件收集客戶機的硬件及軟件信息。公司有若干臺iMac電腦,運行的是Mac OS X 10.6的系統,因爲AssetExplorer只支持Windows版本的Agent,對於其餘系統的計算機須要經過在客戶端執行bash腳本文件的方式,收集客戶機的信息並上傳到服務器。這就要求客戶機的Mac OS X系統啓動的時候可以自動執行腳本程序,並且要基於系統服務層面,用戶無需登陸,腳本也能在後臺運行,最好腳本程序後臺還能作到固定時間自動運行。vim
咱們能夠利用Mac OS X內置的一種稱爲Launch Daemon / Agent的機制來實現系統啓動時自動執行腳本程序。Mac OS X從10.4 開始,採用 launchd進程來管理整個操做系統的服務及進程。傳統的UNIX 會使用 /etc/rc.* 或其餘的機制來管理開機時要啓動的啓動服務,而如今的Mac OS X則使用launchd來管理,它的啓動服務稱爲Launch Daemon / Agents。利用Launch Daemon / Agent,咱們就能夠令腳本程序在系統啓動的時候在後臺運行了。bash
Launch Daemon和Launch Agent的區別服務器
Launch Daemon和Launch Agent 是同一種東西在不一樣應用範圍的名稱。Launch Daemon是系統級別的服務,稱爲daemon,Launch Agent是用戶級別的服務,稱爲agent,前者在開機時會加載,後者在用戶登陸後纔會加載。因此咱們採用Launch Daemon的方式運行腳本。網絡
從AssetExolorer導出腳本文件app
選擇掃描→孤立工做站審計→經過腳本掃描工做站→Mac導出腳本文件ae_scan_mac.sh,並修改腳本文件中的hostName="服務器IP地址或域名地址",並檢查portNo一項是否正確。運維
建立plist配置文件編輯器
Launchd進程須要讀取一個xml格式的plist配置文件,建立該文件並將其放置在/System/Library/LaunchDaemons/ 或者/Library/LaunchDaemons/目錄下。可在Windows下預先建立該文件,須要使用支持Unix格式的文本編輯器(好比UltraEdit)建立該文件。ide
其中plist文件格式及每一個字段的含義:工具
ae_scan_mac.plist文件範例:測試
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <plist version="1.0"> <dict> <key>Label</key> <string>com.manageengine.ae_scan_mac</string> <key>Program</key> <string>ae_scan_mac.sh</string> <key>RunAtLoad</key> <true/> <key>WorkingDirectory</key> <string>/Library/LaunchDaemons/</string> <key>KeepAlive</key> <false/> <key>StartCalendarInterval</key> <dict> <key>Hour</key> <integer>11</integer> <key>Minute</key> <integer>0</integer> </dict> </dict> </plist>
其中的關鍵字解釋:
1)Label(必選)
該項服務的名稱。
2)Program(ProgramArgument是必選的,在沒有ProgramArgument的狀況下,必需要包含Program關鍵字)
指定可執行文件的路徑和名稱。
3)RunAtLoad(可選)
標識launchd在加載完該項服務以後當即啓動路徑指定的可執行文件。默認值爲false。設置爲true便可實現開機運行腳本文件。
4)WorkingDirectory(可選)
運行可執行文件以前,指定當前工做目錄的路徑。
5)KeepAlive(可選)
這個關鍵字能夠用來控制是否讓可執行文件持續運行,默認值爲false,也就是說知足具體條件以後才啓動。當設置值爲ture時,代表無條件的開啓可執行文件,並使之保持在整個系統運行週期內。
6)StartCalendarInterval(可選)
該關鍵字能夠用來設置定時執行可執行程序,可以使用Month、Day、Hour、Minute等子關鍵字,它能夠指定腳本在多少月、天、小時、分鐘、星期幾等時間上執行,若缺乏某個關鍵字則表示任意該時間點,相似於Unix的Crontab計劃任務的設置方式,好比在該例子中設置爲天天11點鐘執行腳本文件。
全部key關鍵字詳細使用說明能夠在Mac OS X終端下使用命令man launchd.plist查詢。
在客戶機部署配置文件和腳本文件
1) 首先爲Mac OS X系統的當前的用戶設置一個密碼,在系統偏好設置→帳戶中設置。
而後,可經過共享等方式將腳本文件ae_scan_mac.sh和plist文件ae_scan_mac.plist拷貝到本地硬盤的一個臨時目錄中,而後打開實用工具→終端,使用如下命令:
sudo mv ae_scan_mac.* /Library/LaunchDaemons
將這兩個文件移動到/Library/LaunchDaemons/目錄下。
2) 修改文件權限:
sudo chown root:wheel /Library/LaunchDaemons/ae_scan_mac.*
sudo chmod a+x /Library/LaunchDaemons/ae_scan_mac.sh
sudo chmod 644 /Library/LaunchDaemons/ae_scan_mac.plist
3) plist文件的編輯和檢查
可以使用命令sudo vim ae_scan_mac.plist對文件進行修改。
檢查plist文件的語法:
plutil ae_scan_mac.plist
若返回OK則表示文件語法正確。
4) 啓動服務並載入plsit文件:
sudo launchctl load /Library/LaunchDaemons/ae_scan_mac.plist
或者重啓Mac電腦也能夠。
要留意的是,每次修改完plist文件後必須使用如下命令從新載入plist文件又或者重啓電腦,plist的配置纔會生效。
sudo launchctl unload /Library/LaunchDaemons/ae_scan_mac.plist
sudo launchctl load /Library/LaunchDaemons/ae_scan_mac.plist
接着,檢查服務的運行狀態:
sudo launchctl list
5) 最後待腳本運行後,就能在AssetExplorer服務器上看到這臺客戶機的信息了,以後客戶機就會自動按照plist文件設置的時間或者重啓機器後將機器信息上傳到服務器。
兩個文件的部署有幾個地方須要注意的:
1)文件的權限必須正確,兩個文件全部者必須爲root,腳本文件必須有執行權限。
2)plist文件的語法必須正確,要留意配置中的程序工做目錄和運行參數不要錯。可執行:sudo launchctl start /Library/LaunchDaemons/ae_scan_mac.plist
強制運行服務,或者直接運行一下腳本程序,測試一下腳本文件的運行是否正常。
3)每次plist文件修改後必須執行launchctl unload/load卸載並從新載入plist文件,才能使新的配置文件立刻生效。
腳本程序和配置文件分別在多臺客戶機一次性部署後,AssetExplorer就能夠自動收集到全部Mac電腦的硬件和軟件信息,即便機器配置更改了也無需手動添加,方便了公司的資產管理。Launchd進程的功能比較強大,Apple推薦並已使用該進程替代傳統的cron了,你們有興趣能夠再研究一下。
原文爲博主所著,並刊登於《網絡運維與管理》雜誌2014.02.3.4期。