安装git:
https://git-scm.com/downloads
git官网下载安装包,安装时一路next即可
git config --global user.name 提交人姓名(自取)
git config --global user.email 提交人邮箱(自己邮箱)
查看配置结果:
git config --list
为实现免登录效果,使用ssh实现身份验证,不需要提供用户名和密码。依据公钥私钥配对实现免登录。
ssh-keygen -t rsa -C "您的邮箱地址"
回车后会提示您密钥生成位置–用户文件下生成.shh文件。打开.ssh文件,即可查看私钥和公钥
2. 进入密钥目录查看密钥
cd ~/.ssh
cat id_rsa.pub
4. 复制公钥:复制公钥到gitlab上。私钥保留在开发者上。实现连接认证
把刚刚 copy 的秘钥复制进去,取个名字,完成添加~
输入 ssh -T [email protected]
如果打印类似如下信息,即完成:
Hi xxxx! You’ve successfully authenticated, but GitHub does not provide shell access.
https的方式不用过多的配置,只需要配置本地git的username和email即可
git config --global user.name "[email protected]"
git config --global user.email "[email protected]"
用户名、邮箱自取
ssh-keygen -t rsa -C "[email protected]"
id_rsa_gitee
cd ~/.ssh
cat id_rsa_gitee.pub
注意:前面的ssh-rsa
也要带上
5. 登录gitee,个人中心 - 安全设置 - SSH公钥 - 添加公钥
6. 将私钥添加到本地ssh列表
ssh-add ~/.ssh/id_rsa_gitee
如果执行ssh-add时提示"Could not open a connection to your authentication agent",可以现执行命令:
ssh-agent bash
然后再运行ssh-add命令。
可以通过 ssh-add -l 来确私钥列表
ssh-add -l
可以通过 ssh-add -D 来清空私钥列表
ssh-add -D
注意如果我们是要配置多个ssh,一定要将多个私钥添加进去
7. 创建配置文件config(注意:config无后缀名)
touch config
vim config
通过i
然后复制如下内容,然后:wq
保存并退出【如果对vim不熟悉的同学,也可以直接通过windows图形化操作】
config文件(下面的配置按需修改即可):
# gitlab
Host gitlab.com
HostName gitlab.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_gitlab
# gitee
Host gitee.com
HostName gitee.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_gitee
# github
Host github.com
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_github
ssh -T [email protected]
如果还有其他错误的话,可以通过
ssh -Tvvv [email protected]
以debug方式来显示执行过程,然后排查错误
配置都大同小异,此处我就只给命令了
git config --global user.name "[email protected]"
git config --global user.email "[email protected]"
cd ~/.ssh
ssh-keygen -t rsa -C "[email protected]"
cat id_rsa_github.pub
ssh-add ~/.ssh/id_rsa_github
# github
Host github.com
HostName github.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_github
ssh -T [email protected]
Gitlab配置同理:
gitlab配置ssh
git config --global user.name 提交人姓名(自取)
git config --global user.email 提交人邮箱(自己邮箱)
设置好之后查看结果:
2. 进入ssh文件夹,生成ssh密钥
cd ~/.ssh
ssh-keygen -t rsa -C "你gitlab上的邮箱地址"
在生成过程中会提示我们文件名称
Enter file in which to save the key
,需要记住,文件名称不能和Gitee的重复
让我们输入密码Enter passphrase (empty for no passphrase):
,直接回车就行(下面让我们继续输入,直接继续回车)
cd ~/.ssh
注意:
需要根据公司的gitlab访问前缀来配置config
例如:
公司项目的gitlab项目的sms地址:
[email protected]:service/test-sms.git
那么我们需要在config中配置成如下:
# gitlab
Host gitlab.ali.com
HostName gitlab.ali.com
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa_gitlab
对应的,我们测试也需要使用如下命令:
ssh -T [email protected]
首先,远程仓库一般支持两种协议:SSH和HTTPS,SSH协议只认机器,HTTPS协议只认账号;也即为:如果使用SSH操作远程仓库的话,我们需要使用公钥和私钥对来做权限的认证,如果使用HTTPS操作远程仓库,则需要使用账号密码来做权限的认证。无论是公钥私钥对,还是账号密码,都只做权限的认证;但是远程仓库里需要记录这些提交记录是由谁来完成的;所以我们需要给本地的git设置用户名和邮箱,用于从本地仓库向远程仓库提交记录时,在远程仓库记录下这些操作是由谁来完成的。
目前有新的协议正在开发,暂时不做讨论
Q/A:
1、为什么要配置用户名和邮箱?
git是分布式版本管理系统,每个机器需要自报家门(username、email),这样
远程仓库才知道哪次提交是由谁完成的。
但是我们git配置的用户名与邮箱都不会进行验证,但是如果真的有人冒充的也是有办法可查的。
2、配置的用户名和邮箱对push代码到远程仓库有什么影响?
仅仅会出现在commits里,用来标识是谁提交了
首先,配置的用户名和邮箱对push代码到远程仓库时的身份验证没有作用,即不用他们进行身份验证;他们仅仅会出现在远程仓库的commits里。
其次,按正常操作来说,你应该配置你的真实用户名和邮箱,这样一来在远程仓库的commits里可以看到哪个操作是你所为。
最后,这个用户名和邮箱是可以随便配置的(不提倡),如果你配置的邮箱是github里真实存在的邮箱,则commits里显示的是这个邮箱对应的账号;如果配置的邮箱是一个在github里不存在的邮箱,则commits里显示的是你配置的用户名。
参考文章:
https://blog.csdn.net/ITWANGBOIT/article/details/103618427