Mac上簡單常用Terminal命令


方案1

SSH是一個非常偉大的工具,如果你要在互聯網上遠程連接到服務器,那么SSH無疑是最佳的候選。SSH是加密的,OpenSSH加密所有通信(包括密碼),有效消除了竊聽,連接劫持和其它攻擊。本文將為大家介紹25個最佳的SSH命令,希望您在閱讀之后能獲得一些啟發。

AD:51CTO 網+ 第十二期沙龍:大話數據之美_如何用數據驅動用戶體驗

 

 

【51CTO精選譯文】編輯導讀:任何一個系統管理員或站長對SSH都不會陌生,這個偉大的技術(51CTO系統頻道剛剛在感恩節對它表示了感謝)免去了我們跑去機房管理服務器,或者在遠程連接服務器時時刻擔心內容被竊取的心驚膽戰。本文將為大家介紹25個最佳的SSH命令,如果您還沒用過,那么有必要將它們記錄一下。

51CTO推薦專題:Ubuntu 11.04——敏捷的獨角鯨

OpenSSH是SSH連接工具的免費版本。telnet,rlogin和ftp用戶可能還沒意識到他們在互聯網上傳輸的密碼是未加密的,但SSH是加密的,OpenSSH加密所有通信(包括密碼),有效消除了竊聽,連接劫持和其它攻擊。此外,OpenSSH提供了安全隧道功能和多種身份驗證方法,支持SSH協議的所有版本。

SSH是一個非常偉大的工具,如果你要在互聯網上遠程連接到服務器,那么SSH無疑是最佳的候選。下面是通過網絡投票選出的25個最佳SSH命令,你必須牢記於心。

(注:有些內容較長的命令,在本文中會顯示為截斷的狀態。如果你需要閱讀完整的命令,可以把整行復制到您的記事本當中閱讀。)

1、復制SSH密鑰到目標主機,開啟無密碼SSH登錄

ssh-copy-id user@host

如果還沒有密鑰,請使用ssh-keygen命令生成。

2、從某主機的80端口開啟到本地主機2001端口的隧道

ssh -N -L2001:localhost:80 somemachine

現在你可以直接在瀏覽器中輸入http://localhost:2001訪問這個網站。

3、將你的麥克風輸出到遠程計算機的揚聲器

dd if=/dev/dsp | ssh -c arcfour -C username@host dd of=/dev/dsp

這樣來自你麥克風端口的聲音將在SSH目標計算機的揚聲器端口輸出,但遺憾的是,聲音質量很差,你會聽到很多嘶嘶聲。

4、比較遠程和本地文件

ssh user@host cat /path/to/remotefile | diff /path/to/localfile –

在比較本地文件和遠程文件是否有差異時這個命令很管用。

5、通過SSH掛載目錄/文件系統

sshfs name@server:/path/to/folder /path/to/mount/point

http://fuse.sourceforge.net/sshfs.html下載sshfs,它允許你跨網絡安全掛載一個目錄。

6、通過中間主機建立SSH連接

ssh -t reachable_host ssh unreachable_host

Unreachable_host表示從本地網絡無法直接訪問的主機,但可以從reachable_host所在網絡訪問,這個命令通過到reachable_host的“隱藏”連接,創建起到unreachable_host的連接。

7、將你的SSH公鑰復制到遠程主機,開啟無密碼登錄 – 簡單的方法

ssh-copy-id username@hostname

8、直接連接到只能通過主機B連接的主機A

ssh -t hostA ssh hostB

當然,你要能訪問主機A才行。

9、創建到目標主機的持久化連接

ssh -MNf <user>@<host>

在后台創建到目標主機的持久化連接,將這個命令和你~/.ssh/config中的配置結合使用:

Host host
ControlPath ~/.ssh/master-%r@%h:%p
ControlMaster no

所有到目標主機的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個命令將非常有用,因為每次打開一個SSH連接時不會創建新的套接字。

10、通過SSH連接屏幕

ssh -t remote_host screen –r

直接連接到遠程屏幕會話(節省了無用的父bash進程)。

11、端口檢測(敲門)

knock <host> 3000 4000 5000 && ssh -p <port> user@host && knock <host> 5000 4000 3000

在一個端口上敲一下打開某個服務的端口(如SSH),再敲一下關閉該端口,需要先安裝knockd,下面是一個配置文件示例。

[options]
logfile = /var/log/knockd.log
[openSSH]
sequence = 3000,4000,5000
seq_timeout = 5
command = /sbin/iptables -A INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT
tcpflags = syn
[closeSSH]
sequence = 5000,4000,3000
seq_timeout = 5
command = /sbin/iptables -D INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT
tcpflags = syn

12、刪除文本文件中的一行內容,有用的修復

ssh-keygen -R <the_offending_host>

在這種情況下,最好使用專業的工具。

13、通過SSH運行復雜的遠程shell命令

ssh host -l user $(<cmd.txt)

更具移植性的版本:

ssh host -l user “`cat cmd.txt`”

14、通過SSH將MySQL數據庫復制到新服務器

mysqldump –add-drop-table –extended-insert –force –log-error=error.log -uUSER -pPASS OLD_DB_NAME | ssh -C user@newhost “mysql -uUSER -pPASS NEW_DB_NAME”

通過壓縮的SSH隧道Dump一個MySQL數據庫,將其作為輸入傳遞給mysql命令,我認為這是遷移數據庫到新服務器最快最好的方法。

15、刪除文本文件中的一行,修復“SSH主機密鑰更改”的警告

sed -i 8d ~/.ssh/known_hosts

16、從一台沒有SSH-COPY-ID命令的主機將你的SSH公鑰復制到服務器

cat ~/.ssh/id_rsa.pub | ssh user@machine “mkdir ~/.ssh; cat >> ~/.ssh/authorized_keys”

如果你使用Mac OS X或其它沒有ssh-copy-id命令的*nix變種,這個命令可以將你的公鑰復制到遠程主機,因此你照樣可以實現無密碼SSH登錄。

17、實時SSH網絡吞吐量測試

yes | pv | ssh $host “cat > /dev/null”

通過SSH連接到主機,顯示實時的傳輸速度,將所有傳輸數據指向/dev/null,需要先安裝pv。

如果是Debian:

apt-get install pv

如果是Fedora:

yum install pv

(可能需要啟用額外的軟件倉庫)。

18、如果建立一個可以重新連接的遠程GNU screen

ssh -t user@some.domain.com /usr/bin/screen –xRR

人們總是喜歡在一個文本終端中打開許多shell,如果會話突然中斷,或你按下了“Ctrl-a d”,遠程主機上的shell不會受到絲毫影響,你可以重新連接,其它有用的screen命令有“Ctrl-a c”(打開新的shell)和“Ctrl-a a”(在shell之間來回切換),請訪問http://aperiodic.net/screen/quick_reference閱讀更多關於screen命令的快速參考。

19、繼續SCP大文件

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file

它可以恢復失敗的rsync命令,當你通過VPN傳輸大文件,如備份的數據庫時這個命令非常有用,需要在兩邊的主機上安裝rsync。

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file local -> remote

rsync –partial –progress –rsh=ssh $user@$host:$remote_file $destination_file remote -> local

20、通過SSH W/ WIRESHARK分析流量

ssh root@server.com ‘tshark -f “port !22″ -w -' | wireshark -k -i –

使用tshark捕捉遠程主機上的網絡通信,通過SSH連接發送原始pcap數據,並在wireshark中顯示,按下Ctrl+C將停止捕捉,但也會關閉wireshark窗口,可以傳遞一個“-c #”參數給tshark,讓它只捕捉“#”指定的數據包類型,或通過命名管道重定向數據,而不是直接通過SSH傳輸給wireshark,我建議你過濾數據包,以節約帶寬,tshark可以使用tcpdump替代:

ssh root@example.com tcpdump -w – ‘port !22′ | wireshark -k -i –

21、保持SSH會話永久打開

autossh -M50000 -t server.example.com ‘screen -raAd mysession’

打開一個SSH會話后,讓其保持永久打開,對於使用筆記本電腦的用戶,如果需要在Wi-Fi熱點之間切換,可以保證切換后不會丟失連接。

22、更穩定,更快,更強的SSH客戶端

ssh -4 -C -c blowfish-cbc

強制使用IPv4,壓縮數據流,使用Blowfish加密。

23、使用cstream控制帶寬

tar -cj /backup | cstream -t 777k | ssh host ‘tar -xj -C /backup’

使用bzip壓縮文件夾,然后以777k bit/s速率向遠程主機傳輸。Cstream還有更多的功能,請訪問http://www.cons.org/cracauer/cstream.html#usage了解詳情,例如:

echo w00t, i’m 733+ | cstream -b1 -t2

24、一步將SSH公鑰傳輸到另一台機器

ssh-keygen; ssh-copy-id user@host; ssh user@host

這個命令組合允許你無密碼SSH登錄,注意,如果在本地機器的~/.ssh目錄下已經有一個SSH密鑰對,ssh-keygen命令生成的新密鑰可能會覆蓋它們,ssh-copy-id將密鑰復制到遠程主機,並追加到遠程賬號的~/.ssh/authorized_keys文件中,使用SSH連接時,如果你沒有使用密鑰口令,調用ssh user@host后不久就會顯示遠程shell。

25、將標准輸入(stdin)復制到你的X11緩沖區

ssh user@host cat /path/to/some/file | xclip

你是否使用scp將文件復制到工作用電腦上,以便復制其內容到電子郵件中?xclip可以幫到你,它可以將標准輸入復制到X11緩沖區,你需要做的就是點擊鼠標中鍵粘貼緩沖區中的內容。

如果你還有其它SSH命令技巧,歡迎在本文評論中帖出。

 

 

方案2
 

SSH(Secure Shell Client)常用命令

一、ls 只列出文件名 (相當於dir,dir也可以使用)

-A:列出所有文件,包含隱藏文件。

-l:列表形式,包含文件的絕大部分屬性。

-R:遞歸顯示。

--help:此命令的幫助。

 

二、cd 改變目錄

cd /:進入根目錄

cd :回到自己的目錄(用戶不同則目錄也不同,root為/root,xxt為/home/xxt

cd ..:回到上級目錄

pwd:顯示當前所在的目錄

 

三.less 文件名:查看文件內容。

tail -f 日志名:查看日志

 

四.q 退出打開的文件。

 

五.上傳文件: rz 選擇要傳送的文件,確定。

 

六.下載文件: sz 指定文件名,enter敲,即下載到了secureCRT/download目錄下。

 

七:刪除文件: rm 刪除文件 ,rmdir 刪除空目錄。rm -rf 強行刪除非空目錄

 

八.顯示 最近輸入的20條命令:history 20

 

九.獲得幫助命令 --help查看命令下詳細參數:  如:rz --help   , sz --help  。

 

 

 

十.cd 進入某個文件夾的命令:

mkdir+文件夾名 創建某個文件夾的命令

sz+文件名 從服務器端向本機發送文件的命令

rz 從本機向服務器端傳送文件的命令

ll 列出當前目錄下的所有文件,包括每個文件的詳細信息

dir 對當前文件夾

vi 打開當前文件

 

十一.在編輯某個文件的時候:

a 切換到編輯模式

ctrl+c 退出編輯模式

dd 刪除整行

:q 退出當前文件

:w 寫入並保存當前文件

-f 強行xx的參數。。。

 

 

 

其它命令:

1.ps -ef  //查看server的進程,以列表形式顯示的server進程。

 ps 顯示當前在系統運行的進程 /usr/bin/ps [選項] -e 顯示每個現在運行的進程 -f 生成一個完全的列表

 

2.ant -buildfile CMS_MainTrunk.xml  //build 包

 

3.vi test.txt  //瀏覽文件內容

i {insert寫輸入}

esc  退出insert

:wq! write 保存並退出vi模式  

:q!  不保存退出vi模式

4、secureCRT中亂碼解決:Options->SessionOptions->Appearance->font把default改成UTF-8,就可以顯示中文字體了。

6.hostname:查hostname

 

7.ifconfig 查詢主機IP

 

8.在S-CRT下用ctrl+c 和ctrl+v:

Options---Global Options---Edit default Settings進去后點Terminal---Emulation然后點Mapped Keys,點中低部的,use windows copy and paste key,點確認。

 

 

 

 

9.進入vi的命令:

vi filename :打開或新建文件,並將光標置於第一行首

vi +n filename :打開文件,並將光標置於第n行首

vi + filename :打開文件,並將光標置於最后一行首

vi +/pattern filename:打開文件,並將光標置於第一個與pattern匹配的串處

 

10.移動光標類命令:

}:光標移至段落開頭

{:光標移至段落結尾

nG:光標移至第n行首

n+:光標下移n行

n-:光標上移n行

n$:光標移至第n行尾

H :光標移至屏幕頂行

M :光標移至屏幕中間行

L :光標移至屏幕最后行

0:(注意是數字零)光標移至當前行首

$:光標移至當前行尾

 

11.屏幕翻滾類命令:

Ctrl+u:向文件首翻半屏

Ctrl+d:向文件尾翻半屏

Ctrl+f:向文件尾翻一屏  //好像是 r

Ctrl+b;向文件首翻一屏

 

12.搜索命令:

/pattern:從光標開始處向文件尾搜索pattern

?pattern:從光標開始處向文件首搜索pattern

n:在同一方向重復上一次搜索命令

N:在反方向上重復上一次搜索命令

 

postgres使用:

1.進入sql運行環境。

[test@test bin]$ ./psql -n dbname -U usrname

stay81=# select count(*) from table1;

 count

-------

  5986

(1 row)

 

2. 退出,使用結束后退出,不然連接一直被掛起。

stay81=# \q 

 

3.postgres 數據導出。

[postgres@test bin]$ ./pg_dump -U postgres -t testTable -d testDB > testTable.dump

或[postgres@test bin]$ ./pg_dump -U postgres -d testDB -t testTable -F c -v > testTable.dump

 

4. postgres 數據導入。

[postgres@test bin]$ ./psql -U postgres -d testDB < testTable.dump

或[postgres@test bin]$ ./pg_restore -U postgres -d testDB < testTable.dump

 

5.一台主機上將數據庫目錄轉儲到另一台主機上。

pg_dump -h host1 -p 5432 dbname | psql -h host2 -p post1 dbname

或./pg_dump -U postgres -d testDB1 -t testTable | ./psql -U postgres -d testDB2

-U 為用戶名 ,-d 為DB名,-t 為表名稱,如果整個數據庫導出,不需此項。

 

6.php執行。

[test@test bin]$ /usr/bin/php -q ./batchstart.php

 

方案3

轉自:今日雜記。

不論是在Mac還是iPhone上,都是離不開Terminal的,有Terminal干很多事情都會簡單很多,而且有的事情必須用Terminal才能完成,特別是遇到需要特殊權限的時候,Terminal就派上大用場了。下面這些就是我平時常用到的命令。

root登陸:su root

root密碼重設:passwd root

建立文件夾:mkdir 例:mkdir todaym 建立名為todaym的文件夾

建立文件:touch 例:touch todaym.txt 建立名為todaym的txt文件

已安裝deb查看:dpkg -l

deb安裝:dpkg -i 例:dpkg -i todaym.deb 安裝名為todaym.deb的文件

deb卸載:dpkg -r 例:dpkg -r todaym 卸載已安裝名為todaym的deb文件包,想卸載deb,先用“dpkg -l”命令查看該deb名稱。

deb解壓:dpkg -x 例:dpkg -x todaym.deb 解壓名為todaym.deb的文件

deb打包:dpkg-deb --build 例:dpkg-deb --build todaym 把todaym文件夾內文件打包生成deb

刪除文件:rm 例:rm todaym.txt 刪除名為todaym.txt文件

刪除文件夾:rmdir 例:rmdir todaym 刪除名為todaym文件夾

刪除文件夾及其內所有文件:rm -r 例:rm -r todaym 刪除todaym文件夾及其內全部文件

建立鏈接:ln -s 例:ln -s /var /var/mobile 指在mobile文件夾下建立訪問/var文件夾的鏈接

權限賦予:chmod 例:chmod 777 /var 賦予/var讀寫權限
例:chmod 777 -R /var 賦予/var下所有文件讀寫權限

解壓rar:unrar e 例:unrar e todaym.rar 解壓名為todaym的rar文件

解壓zip:unzip 例:unzip todaym.zip 解壓名為todaym的zip文件

查看文件:ls 例:ls 顯示該文件夾下文件及文件夾
例:ls -w 顯示中文
例:ls -l 顯示詳細信息
例:ls -a 顯示隱藏文件

查看進程:ps 例:ps ax 查看正在運行的進程以及PID
例:ps aux 查看正在運行進程所占PID、CPU、內存、PID、進程開始時間

結束進程:kill PID 例:kill 14 關閉PID為14的進程(每個進程PID不固定,即時用ps命令查看)

重新啟動:reboot

打開文件夾:cd 例:cd todaym 打開名為todaym的文件夾

重命名:mv 例:mv todaym.txt nie.txt 把名為todaym的txt文件重命名為nie

更改擁有者:chown 例:chown root:wheel todaym.txt 將文件todaym.txt的擁有者設為root,組設為wheel

查找文件:find 例:find /var/mobile -name todaym.txt 在/var/mobile文件夾下查找名為todaym的txt文件

解除鎖定:chflags -R nouchg 例:chflags -R nouchg todaym 解除被鎖定的文件(文件夾)todaym
技巧:在Terminal輸入這個命令后加個空格,可把文件或文件夾直接拖到Terminal窗口內

SSH遠程訪問:

ssh -p 8080 用戶名@服務器ip地址

SSH翻Qiang命令:ssh -D 7070 username@yoursite.com  具體教程參考:SSH配PAC讓iPhone/iPod Touch翻牆

更新:-----------------------------------------------------

復制:cp 例:cp todaym.txt /var/mobile/Documents 復制當前文件夾下todaym.txt文件到/var/mobile/Documents文件夾下。復制時注意權限,復制不成功可能是你權限不夠

復制加密:scp 例:scp todaym.txt nie@demo.dreamhost.com:~/nie/docs 復制當前文件夾下todaym.txt文件到你的服務器nie@dreamhost.com的/nie/docs文件夾下,其間需要你輸入服務器登陸密碼
例:scp nie@demo.dreamhost.com:~/nie/docs/read.html /var/mobile 復制nie@demo.dreamhost.com服務器里/nie/docs/文件夾內的read.html文件到本地的/var/mobile文件夾內
具體例子參考:讓iPhone/iPod Touch/Mac的SSH連接自動登錄中第四步。

隱藏文件:chflags hidden 例:chflags hidden /Users/Nie/Desktop/TodayM.txt 隱藏Nie桌面上的TodayM.txt文件。如果想隱藏文件到圖片中,可以參考:Mac/iPhone/iTouch/iPad把文件隱藏到圖片中

iPhone/Mac中的這些命令和Linux/Unix系統中絕大部分是一樣的,特別是Unix,因為Mac就是基於Unix系統。iOS在4.0以后Mobile Terminal就不大好用,在iTunes里Nie目前找到最好的免費Terminal替代軟件:Mobile Admin

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM