• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預(yù)料,人們需要更細(xì)心的觀察別人,要隨時(shí)注意才能保護(hù)別人,因?yàn)樗麄兾幢刂雷约阂裁础ぁぁぁぁ?/span>

            SSH是一個(gè)非常偉大的工具,如果你要在互聯(lián)網(wǎng)上遠(yuǎn)程連接到服務(wù)器,那么SSH無疑是最佳的候選。下面是通過網(wǎng)絡(luò)投票選出的25個(gè)最佳SSH命令,你必須牢記于心。

            1、復(fù)制SSH密鑰到目標(biāo)主機(jī),開啟無密碼SSH登錄

            ssh-copy-id user@host

            如果還沒有密鑰,請(qǐng)使用ssh-keygen命令生成。

            2、從某主機(jī)的80端口開啟到本地主機(jī)2001端口的 ssh 隧道

            ssh -N -L2001:localhost:80 somemachine

            現(xiàn)在你可以直接在瀏覽器中輸入http://localhost:2001訪問這個(gè)網(wǎng)站。

            3、將你的麥克風(fēng)輸出到遠(yuǎn)程計(jì)算機(jī)的揚(yáng)聲器

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

            這樣來自你麥克風(fēng)端口的聲音將在SSH目標(biāo)計(jì)算機(jī)的揚(yáng)聲器端口輸出,但遺憾的是,聲音質(zhì)量很差,你會(huì)聽到很多嘶嘶聲。

            4、比較遠(yuǎn)程和本地文件

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

            在比較本地文件和遠(yuǎn)程文件是否有差異時(shí)這個(gè)命令很管用。

            5、通過SSH掛載目錄/文件系統(tǒng)

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

            從http://fuse.sourceforge.net/sshfs.html下載sshfs,它允許你跨網(wǎng)絡(luò)安全掛載一個(gè)目錄。

            6、通過中間主機(jī)建立SSH連接

            ssh -t reachable_host ssh unreachable_host

            Unreachable_host表示從本地網(wǎng)絡(luò)無法直接訪問的主機(jī),但可以從reachable_host所在網(wǎng)絡(luò)訪問,這個(gè)命令通過到reachable_host的“隱藏”連接,創(chuàng)建起到unreachable_host的連接。

            7、通過你的電腦,復(fù)制遠(yuǎn)程 host1 主機(jī)上的文件到遠(yuǎn)程 host2 主機(jī)上的文件

            ssh root@host1 “cd /somedir/tocopy/ && tar -cf – .” | ssh root@host2 “cd /samedir/tocopyto/ && tar -xf -”

            如果只有你能同時(shí)訪問 host1 和 host 2 ,但它們不能訪問你的主機(jī)(因此 ncat 是無法工作的),而且它們之間也無法直接訪問。

            8、運(yùn)行任何遠(yuǎn)程主機(jī)上的 GUI 程序

            ssh -fX <user>@<host> <program>

            SSH 服務(wù)器端必須要具備以下條件:

            X11Forwarding yes #確保 X11 轉(zhuǎn)發(fā)是打開的

            同時(shí)也可以打開

            Compression delayed

            當(dāng)然,你要能訪問主機(jī)A才行。

            9、創(chuàng)建到目標(biāo)主機(jī)的持久化連接

            ssh -MNf <user>@<host>

            在后臺(tái)創(chuàng)建到目標(biāo)主機(jī)的持久化連接,將這個(gè)命令和你~/.ssh/config中的配置結(jié)合使用:

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

            所有到目標(biāo)主機(jī)的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個(gè)命令將非常有用,因?yàn)槊看未蜷_一個(gè)SSH連接時(shí)不會(huì)創(chuàng)建新的套接字。

            10、通過SSH 直接開啟并還原 screen 命令

            ssh -t remote_host screen –r

            直接連接到遠(yuǎn)程 screen 會(huì)話(節(jié)省了無用的父bash進(jìn)程)。

            11、端口檢測(cè)(敲門)

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

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

            [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、刪除文本文件中的一行內(nèi)容,有用的修復(fù)

            ssh-keygen -R <the_offending_host>

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

            13、通過SSH運(yùn)行復(fù)雜的遠(yuǎn)程shell命令

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

            更具移植性的版本:

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

            14、通過SSH將MySQL數(shù)據(jù)庫復(fù)制到新服務(wù)器

            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一個(gè)MySQL數(shù)據(jù)庫,將其作為輸入傳遞給mysql命令,我認(rèn)為這是遷移數(shù)據(jù)庫到新服務(wù)器最快最好的方法。

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

            sed -i 8d ~/.ssh/known_hosts

            16、從一臺(tái)沒有SSH-COPY-ID命令的主機(jī)將你的SSH公鑰復(fù)制到服務(wù)器

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

            如果你使用Mac OS X或其它沒有ssh-copy-id命令的*nix變種,這個(gè)命令可以將你的公鑰復(fù)制到遠(yuǎn)程主機(jī),因此你照樣可以實(shí)現(xiàn)無密碼SSH登錄。

            17、實(shí)時(shí)SSH網(wǎng)絡(luò)吞吐量測(cè)試

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

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

            如果是Debian:

            apt-get install pv

            如果是Fedora:

            yum install pv

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

            18、如果建立一個(gè)可以重新連接的遠(yuǎn)程GNU screen

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

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

            19、繼續(xù)SCP大文件

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

            它可以恢復(fù)失敗的rsync命令,當(dāng)你通過VPN傳輸大文件,如備份的數(shù)據(jù)庫時(shí)這個(gè)命令非常有用,需要在兩邊的主機(jī)上安裝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捕捉遠(yuǎn)程主機(jī)上的網(wǎng)絡(luò)通信,通過SSH連接發(fā)送原始pcap數(shù)據(jù),并在wireshark中顯示,按下Ctrl+C將停止捕捉,但也會(huì)關(guān)閉 wireshark窗口,可以傳遞一個(gè)“-c #”參數(shù)給tshark,讓它只捕捉“#”指定的數(shù)據(jù)包類型,或通過命名管道重定向數(shù)據(jù),而不是直接通過SSH傳輸給wireshark,我建議你過濾數(shù) 據(jù)包,以節(jié)約帶寬,tshark可以使用tcpdump替代:

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

            21、保持SSH會(huì)話永久打開

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

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

            22、更穩(wěn)定,更快,更強(qiáng)的SSH客戶端

            ssh -4 -C -c blowfish-cbc

            強(qiáng)制使用IPv4,壓縮數(shù)據(jù)流,使用Blowfish加密。

            23、使用cstream控制帶寬

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

            使用bzip壓縮文件夾,然后以777k bit/s速率向遠(yuǎn)程主機(jī)傳輸。Cstream還有更多的功能,請(qǐng)?jiān)L問http://www.cons.org/cracauer/cstream.html#usage了解詳情,例如:

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

            24、一步將SSH公鑰傳輸?shù)搅硪慌_(tái)機(jī)器

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

            這 個(gè)命令組合允許你無密碼SSH登錄,注意,如果在本地機(jī)器的~/.ssh目錄下已經(jīng)有一個(gè)SSH密鑰對(duì),ssh-keygen命令生成的新密鑰可能會(huì)覆蓋 它們,ssh-copy-id將密鑰復(fù)制到遠(yuǎn)程主機(jī),并追加到遠(yuǎn)程賬號(hào)的~/.ssh/authorized_keys文件中,使用SSH連接時(shí),如果你 沒有使用密鑰口令,調(diào)用ssh user@host后不久就會(huì)顯示遠(yuǎn)程shell。

            25、將標(biāo)準(zhǔn)輸入(stdin)復(fù)制到你的X11緩沖區(qū)

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

            posted on 2012-12-17 18:17 小果子 閱讀(307) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 學(xué)習(xí)筆記
            国产成人久久久精品二区三区| 欧美一级久久久久久久大片| 少妇人妻综合久久中文字幕| 久久人人爽人人爽人人片AV高清| 久久精品中文字幕一区| 97精品久久天干天天天按摩 | 久久综合精品国产二区无码| 欧美精品丝袜久久久中文字幕| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 99久久久精品| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久狠狠爱亚洲综合影院| 麻豆亚洲AV永久无码精品久久| 99久久精品影院老鸭窝| 久久亚洲精品国产精品婷婷| 国产精品一区二区久久| 久久精品国产99久久久古代| 精品久久久无码中文字幕天天| 欧美午夜精品久久久久免费视| 人妻无码精品久久亚瑟影视| 久久成人影院精品777| 国产69精品久久久久9999APGF| 国产精品日韩深夜福利久久| 久久久久亚洲av无码专区喷水| 亚洲国产精品狼友中文久久久| 国内精品久久久人妻中文字幕| 久久精品国产色蜜蜜麻豆| 久久久久免费视频| 99久久99久久精品国产片果冻| 国产精品18久久久久久vr| 日韩精品无码久久久久久| 欧美亚洲国产精品久久| 久久99九九国产免费看小说| 日本高清无卡码一区二区久久| 久久久久亚洲爆乳少妇无 | 国产精品成人久久久久三级午夜电影| 久久精品国产亚洲AV无码麻豆| 亚洲∧v久久久无码精品| 国产A级毛片久久久精品毛片| 亚洲AV无码久久寂寞少妇| 亚洲午夜久久久久久久久久|