Git从入门到精通,这些知识点必知必会

2022-12-24 0 611

Git是目前世界上最一流的分布式系统版控制技术。

git使用SSH公钥

1、版控制

众所周知代表者Word文档的撰稿,你的配置文档中呢有这样的情况:

word20160301.docword存储的.docword(小张).docword-03.docword.doc

而某一天,你可能需要从前修正过的版(即使,时常会碰到这种最怕的同僚或是顾客)

而由版控制给你增添的是:

版 使用者 表明 年份1 张三 删掉了应用软件服务项目条文5 7/12 10:382 张三 增加了License数目管制 7/12 18:093 张三 财务人员调整了合约数额 7/13 9:514 张三 缩短了完全免费升级换代周期性 7/14 15:17

而且,你想归还到这儿,就能归还到这儿!

读懂第两个关键字:(无穷无尽的)一丁点儿

1、分布式系统 VS 封闭式

封闭式,众所周知的代表者就是SVN,版别列济夫分散存放在华北局伺服器的,而干的时候,用的都是他们的笔记本电脑,所以要先从中央伺服器获得新一代的版,接着开始干,半天活了,再把他们的活发送给华北局伺服器。

分布式系统,分布式系统版控制技术显然没有“华北局伺服器”,每一人的笔记本电脑上都是两个完备的版库,分布式系统版控制技术的可靠性要高很多,即使每一人笔记本电脑里都有完备的版库,某两个人的笔记本电脑装好了没关系,就行了从他们那儿拷贝两个就能了。而封闭式版控制技术的华北局伺服器就算出了问题,其他人都显然无法干了。

Git圣索弗朗代兰县无须互联这么单纯,Git更强悍的是组成部分管理。

读懂第三个关键字:分布式系统

Git自然环境构筑

加装Git在Linux(Debian)上加装Git:apt-get install gitMac OS X上加装Git:第二种方法是加装homebrew,接着通过homebrew加装Git,利皮扬卡请参照homebrew的文档格式:http://brew.sh/。第二种方法更单纯,也是推荐的方法,就是直接从AppStore加装Xcode,Xcode集成了Git,不过默认没有加装,你需要运行Xcode,选择菜单“Xcode”->“Preferences”,在弹出窗口中找到“Downloads”,选择“Command Line Tools”,点“Install”就能完成加装了。在Windows上加装Git从这里https://git-for-windows.github.io/下载,双击加装加装完成后,能在右键菜单/开始菜单中找到“Git”->“Git Bash”,蹦出两个类似命令行窗口的东西,就表明Git加装成功!全局变量设置

就像Java需要设置Path一样,Git需要设置一些全局变量。

“Git”->“Git Bash”$ git config –global user.name “Your Name”$ git config –global user.email “[email protected]

设置使用者与Email,相当于自报家门,让版库有两个记录。注意:git config命令的–global是全局设置的意思。

创建版库

1、windows下,需要建立的版库的地方,右键git bash->

$ git init

瞬间Git就把仓库建好了,而且告诉你是两个空的仓库(empty Git repository),细心的读者能发现当前目录下多了两个.git的目录,这个目录是Git来跟踪管理版库的,没事千万不要手动修正这个目录里面的文档,不然改乱了,就把Git仓库给破坏了。

PS:如果你没有看到.git目录,那是即使这个目录默认是隐藏的

1、Linux中:

如果,需要在learngit目录下建立两个Git仓库,能如下操作

$ mkdir learngit$ cd learngit$ git init

你也能这样:

$ git init learngit

试一试吧!

SSH公钥

git使用https协议,每次pull, push都要输入密码,相当的烦。使用git协议,接着使用ssh公钥。这样能省去每次都输密码。

需要三个步骤:

一、本地生成公钥对;

二、设置github上的公钥;

三、修正git的remote url为git协议。

生成公钥

大多数 Git 伺服器都会选择使用 SSH 公钥来进行授权。系统中的每一使用者都必须提供两个公钥用于授权,没有的话就要生成两个。生成公钥的过程在所有操作系统上都差不多。首先先确认一下是否已经有两个公钥了。SSH 公钥默认储存在账户的主目录下的 ~/.ssh 目录。进去看看:

$ cd ~/.ssh$ lsauthorized_keys2 id_dsa known_hosts config id_dsa.pub

关键是看有没有用 something 和 something.pub 来命名的一对文档,这个 something 通常就是 id_dsa 或 id_rsa。有 .pub 后缀的文档就是公钥,另两个文档则是公钥。假如没有这些文档,或是干脆连 .ssh 目录都没有,能用 ssh-keygen 来创建。该程序在 Linux/Mac 系统上由 SSH 包提供,而在 Windows 上则包含在 MSysGit 包里:

$ ssh-keygen -t rsa -C “[email protected]”# Creates a new ssh key using the provided email # Generating public/private rsa key pair.# Enter file in which to save the key (/home/you/.ssh/id_rsa):

直接Enter就行。接着,会提示你输入密码,如下(建议输两个,安全一点,当然不输也行):

Enter passphrase (empty for no passphrase): [Type a passphrase]# Enter same passphrase again: [Type passphrase again]

完了之后,大概是这样。

Your identification has been saved in /home/you/.ssh/id_rsa.# Your public key has been saved in /home/you/.ssh/id_rsa.pub.# The key fingerprint is: # 01:0f:f4:3b:ca:85:d6:17:a1:7d:f0:68:9d:f0:a2:db [email protected]

这样。你本地生成公钥对的工作就做好了。

添加公钥到你的github帐户

2-1、查看你生成的公钥:大概如下:

$ cat ~/.ssh/id_rsa.pub ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAklOUpkDHrfHY17SbrmTIpNLTGK9Tjom/BWDSU GPl+nafzlHDTYW7hdI4yZ5ew18JH4JW9jbhUFrviQzM7xlELEVf4h9lFX5QVkbPppSwg0cda3 Pbv7kOdJ/MTyBlWXFCR+HAo3FXRitBqxiX1nKhXpHAZsMciLq8V6RjsNAQwdsdMFvSlVK/7XA t3FaoJoAsncM1Q9x5+3V0Ww68/eIFmb1zuUFljQJKprrX88XypNDvjYNby6vw/Pb0rwert/En mZ+AW4OZPnTPI89ZPmVMLuayrD2cE86Z/il8b+gw3r3+1nKatmIkjn2so1d01QraTlMqVSsbx NrRFi9wrf+M7Q== [email protected]

2-2、登陆你的github帐户。接着 Account Settings -> 左栏点击 SSH Keys -> 点击 Add SSH key

2-3、接着你拷贝上面的公钥内容,粘贴进“Key”文本域内。title域,你就行了填两个都行。

2-4、完了,点击 Add key。

这样,就OK了。接着,验证下这个key呢正常工作。

$ ssh -T [email protected]# Attempts to ssh to github

如果,看到:

Hi username! Youve successfully authenticated, but GitHub does not # provide shell access.

就表示你的设置已经成功了。

修正你本地的ssh remote url. 不用https协议,改用git 协议

确保:

你已经init了两个空仓库。你已经把远程git的url添加到了本地git仓库的配置文档

================================================

能用git remote -v 查看你当前的remote url

$ git remote -vorigin https://github.com/someaccount/someproject.git (fetch)origin https://github.com/someaccount/someproject.git (push)

能看到是使用https协议进行访问的。

你能使用浏览器登陆你的github,在上面能看到你的ssh协议相应的url。类似如下:

[email protected]:someaccount/someproject.git

这时,你能使用 git remote set-url 来调整你的url。

git remote set-url origin [email protected]:someaccount/someproject.git

完了之后,你便能再用 git remote -v 查看一下。

$ git remote -vorigin https://[email protected]:someaccount/someproject.git (fetch)origin https://[email protected]:someaccount/someproject.git (push)

OK。

至此,你就能省去输入密码的麻烦,也能很安全的进行push,pull,fetch,checkout等操作了。

你能用git fetch, git pull , git push。

「注意:」

第一次使用git push之前,需要对git push进行配置:

1.simple方式:

git config –global push.default.simple

2.matching方式:

git config –global push.default.matchingmatching means git push will push all your local branches to the ones with the same name on the remote. This makes it easy to accidentally push a branch you didnt intend to.

matching与simple方式的push的区别是:matching会把你所有本地的组成部分push到远程仓库中对应匹配的组成部分。

simple means git push will push only the current branch to the one that git pull would pull from, and also checks that their names match. This is a more intuitive behavior, which is why the default is getting changed to this.

simple方式,只会push你已经从远程仓库pull过的组成部分,意思是你曾经pull了组成部分dev,那么当你使用缺省git push时,当前组成部分为dev,远程组成部分dev就会收到你的commit。

3.或是使用git push [远程仓库] [本地组成部分]

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务