Host key verification failed

在应用内执行脚本 遇到 Host key verification failed

Posted on 2017-11-14 14:15:15 in Git, Laravel, PHP   阅读(7680)

应用背景:通过 GitHub 的 webhook 实现 git push 后,服务器自动更新代码
通过我的站点提供一个 Url 给 GitHub 回调 这里的站点是基于 Laravel 搭建的博客.

关键代码

public function webhook(Request $request) {  
        Log::info("git push 啦  该更新代码啦~");  
        $data = [];  
        exec('/脚本所在的目录/updateGit.sh 2>&1', $data, $data1);  
        Log::info($data );  
        Log::info($data1);  
        return view("success");  
}

脚本内容

#!/bin/bash
cd /项目所在的目录/myBlog/ 
git pull

执行自动更新脚本时报错

1 => 'Host key verification failed.',
2 => 'fatal: The remote end hung up unexpectedly'

问题的起因是因为当前站点执行脚本时的用户为 www 用户,当前 www 用户的公钥没有配置在 GitHub 上。所以解决方案也很简单,切换到 www 用户,生成 ssh-key 并保存到 GitHub 的 ssk-key 列表即可!
修改完成后,再次调用

'Already up-to-date.'

大功告成!