1、問題描述
java啓動項目命令:
nohup java -jar -server -Dserver.port=10001 -Xms1024M -Xmx1024M -Dspring.profiles.active=dev /usr/local/application/laowang/laowang.jar >/dev/null 2>&1 &
執行起來是沒問題,關於日誌輸出重定向,開始有點搞混了,記錄下。
2、解決方案
1、首先要明確的是,nohup這些是在linux下執行的shell命令,其中的重定向也是shell命令參數的一種,不是java專用命令;
2、 nohup --- & ,這個是shell命令,表明是在後臺運行,掛起,關閉ssh窗口也不會被關閉;
3、我們經常使用nohup command &
命令形式來啓動一些後臺程序,比如一些java服務:
# nohup java -jar xxxx.jar &
爲了不讓一些執行信息輸出到前臺(控制檯),我們還會加上剛纔提到的>/dev/null 2>&1
命令來丟棄所有的輸出:
# nohup java -jar xxxx.jar >/dev/null 2>&1 &
當執行shell命令時,會默認打開3個文件,每個文件有對應的文件描述符來方便我們使用:
類型 | 文件描述符 | 默認情況 | 對應文件句柄位置 |
---|---|---|---|
標準輸入(standard input) | 0 | 從鍵盤獲得輸入 | /proc/self/fd/0 |
標準輸出(standard output) | 1 | 輸出到屏幕(即控制檯) | /proc/self/fd/1 |
錯誤輸出(error output) | 2 | 輸出到屏幕(即控制檯) | /proc/self/fd/2 |
(1)“>/dev/null"
這條命令的作用是將標準輸出1重定向到/dev/null
中。 /dev/null
代表linux的空設備文件,所有往這個文件裏面寫入的內容都會丟失,俗稱“黑洞”。那麼執行了>/dev/null
之後,標準輸出就會不再存在,沒有任何地方能夠找到輸出的內容;
(2)"2>/dev/null"
意思就是把錯誤輸出到“黑洞”;
(3)“>/dev/null 2>&1"
默認情況是1,也就是等同於1>/dev/null 2>&1。意思就是把標準輸出重定向到“黑洞”,還把錯誤輸出2重定向到標準輸出1,也就是標準輸出和錯誤輸出都進了“黑洞”;
(4)"2>&1 >/dev/null"
意思就是把錯誤輸出2重定向到標準出書1,也就是屏幕,標準輸出進了“黑洞”,也就是標準輸出進了黑洞,錯誤輸出打印到屏幕;
(5) >log.log 是將信息輸出到log.log日誌中
# nohup java -jar xxxx.jar >/var/log.log 2>&1 &
2>&1 是將標準錯誤信息轉變成標準輸出,這樣就可以將錯誤信息輸出到log.log 日誌裏面來。
更多信息請關注公衆號:「軟件老王」,關注不迷路,軟件老王和他的IT朋友們,分享一些他們的技術見解和生活故事。