git ssh使用公钥授权怎么都不通过

前提: 
1.客户端生成了id_rsa.pub和id_rsa 
2.服务端在.ssh/authorized_keys也加入了客户端的id_res.pub 
3./etc/ssh/sshd_config开启了:

  1. RSAAuthentication yes  
  2. PubkeyAuthentication yes  
  3. AuthorizedKeysFile     .ssh/authorized_keys

但在客户端执行ssh依然报错:

Permission denied (publickey,gssapi-keyex,gssapi-with-mic).


最后在网上折腾了半天才发现原来是SELinux的问题,只要关闭SELinux在重新启动就可以了: 
暂时关闭(重启后恢复): 

setenforce 0  

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Git 在服务器上使用 SSH 公钥授权是一种常见的授权方式,它通过设置公钥和私钥的配对来进行认证和授权。下面是具体的步骤: 1. 生成 SSH 密钥对:在本地终端中使用 `ssh-keygen` 命令生成 SSH 密钥对,该命令将生成一对公钥和私钥文件,一般默认保存在 `~/.ssh` 目录下。 2. 添加公钥到服务器:将生成的公钥文件中的内容复制到服务器上的 `~/.ssh/authorized_keys` 文件中,每个公钥应占据一行。如果 `authorized_keys` 文件不存在,可以使用 `touch ~/.ssh/authorized_keys` 创建新文件。 3. 配置服务器相关设置:确保服务器上的 `sshd_config` 文件中设置了以下配置项: ``` PubkeyAuthentication yes AuthorizedKeysFile .ssh/authorized_keys ``` 如果有必要,重启 SSH 服务。 4. 测试连接:在本地终端中执行 `ssh -T git@服务器IP地址` 命令进行测试,如果返回欢迎信息,则表示连接成功。 5. 配置 Git 仓库权限:进入服务器上的 Git 仓库目录,执行 `git init --bare` 命令以设置一个空的 Git 仓库。然后,在本地终端中进入相应的本地 Git 仓库目录,执行 `git remote add origin ssh://服务器IP地址/仓库路径` 命令将远程仓库关联到本地仓库。 这样,当你在本地进行 Git 操作(如 push 或 pull)时,Git使用 SSH 公钥与服务器进行授权验证,确保只有拥有相应私钥的用户才能进行操作。这种方式安全可靠,并且不需要每次输入用户名和密码进行授权
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值