跳到主要內容

macOS 上ssh-copy-id還是會問 Enter passphrase for key

最近升級到macOS Sierra後,發現 ssh 到之前用ssh-copy-id 的機器,都會問 Enter passphrase for key 。
問了股溝大神後,大概知道情況,解法備份如下:
  1. 先用homebrew裝好ssh-copy-id設好ssh key
  2. 編輯/新增  /Users/$USER/Library/LaunchAgents/ssh-agent.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.ssh.ssh-agent</string>
    <key>OnDemand</key>
    <false/>
    <key>Program</key>
    <string>/Users/username/.ssh/ssh-agent.sh</string>
    <key>RunAtLoad </key>
    <true/>
    <key>ServiceDescription</key>
    <string>Launch ssh-agent</string>
    </dict></plist>
    
  3. 在 /Users/$USER/.ssh  目錄 增加一個檔案 /Users/$USER/.ssh/ssh-agent.sh ,內容如下:
    #!/bin/sh
    rm /Users/$USER/.ssh/ssh-agent.pipe
    exec /usr/bin/ssh-agent -a /Users/$USER/.ssh/ssh-agent.pipe -d
    

    這檔案裡的$USER最好換成自己的username
  4. 再執行
    $ chmod +x /Users/$USER/.ssh/ssh-agent.sh
  5. 接著執行
    $ launchctl start com.ssh.ssh-agent
  6. 在 ~/.profile  或是 ~/.zshrc 加上
    export SSH_AUTH_SOCK=/Users/$USER/.ssh/ssh-agent.pipe
    ssh-add -K
出處

留言

這個網誌中的熱門文章

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!

在Windows Server設定L2TP over IPSec VPN

簡單地說,macOS Sierra與iOS 10發表後,大家忽然發現Apple不再支援PPTP,所以一定得設定其他的VPN型態。若不要另外裝client,用L2TP是最方便的,SSL VPN雖然好,但若沒有安裝Agent要連線到任一電腦或是非網頁服務還是挺麻煩的。