GitHub 入门实践
1 GitHub简介
- GitHub是基于git实现的代码托管。git是目前最好用的版本控制系统了,非常受欢迎,比之svn更好。
- GitHub可以免费使用,并且快速稳定。即使是付费帐户,每个月不超过10美刀的费用也非常便宜。
- 利用GitHub,你可以将项目存档,与其他人分享交流,并让其他开发者帮助你一起完成这个项目。优点在于,他支持多人共同完成一个项目,因此你们可以在同一页面对话交流。
- 创建自己的项目,并备份,代码不需要保存在本地或者服务器,GitHub做得非常理想。
- 学习Git也有很多好处。他被视为一个预先维护过程,你可以按自己的需要恢复、提交出现问题,或者您需要恢复任何形式的代码,可以避免很多麻烦。Git最好的特性之一是能够跟踪错误,这让使用Github变得更加简单。Bugs可以公开,你可以通过Github评论,提交错误。
- 在GitHub页面,你可以直接开始,而不需要设置主机或者DNS。对于我来说,我可以在公司和家编辑同样的一套代码了,用U盘或者网盘都好麻烦的说
本篇博客剩下内容结构:
- 安装git客户端
- 在网页版GitHub创建github repository(仓库)
- 为Github账户设置SSH key
- 上传本地项目到网页版GitHub的常用命令
2 安装git客户端
Git是目前世界上最先进的分布式版本控制系统,git与svn的五个基本区别。它有以下特点:
1)分布式 : Git版本控制系统是一个分布式的系统, 是用来保存工程源代码历史状态的命令行工具;
2)保存点 : Git的保存点可以追踪源码中的文件, 并能得到某一个时间点上的整个工程项目额状态; 可以在该保存点将多人提交的源码合并, 也可以会退到某一个保存点上;
3)Git离线操作性 :Git可以离线进行代码提交, 因此它称得上是完全的分布式处理, Git所有的操作不需要在线进行; 这意味着Git的速度要比SVN等工具快得多, 因为SVN等工具需要在线时才能操作, 如果网络环境不好, 提交代码会变得非常缓慢;
4)Git基于快照 : SVN等老式版本控制工具是将提交点保存成补丁文件, Git提交是将提交点指向提交时的项目快照, 提交的东西包含一些元数据(作者, 日期, GPG等);
5)Git的分支和合并 : 分支模型是Git最显著的特点, 因为这改变了开发者的开发模式, SVN等版本控制工具将每个分支都要放在不同的目录中, Git可以在同一个目录中切换不同的分支;
6)分支即时性 : 创建和切换分支几乎是同时进行的, 用户可以上传一部分分支, 另外一部分分支可以隐藏在本地, 不必将所有的分支都上传到GitHub中去;
7)分支灵活性 : 用户可以随时 创建 合并 删除分支, 多人实现不同的功能, 可以创建多个分支进行开发, 之后进行分支合并, 这种方式使开发变得快速, 简单, 安全。
2.1 下载git客户端
官方下载地址:http://git-scm.com/download/ ,会自动识别本机操作系统。
下载好之后咋们开始安装吧,欢迎界面,下一步。
选择安装路径,千万别选带中文的路径,有时候会引起不必要的误会。
选择安装组件,按默认的来就好了。
1)图标组件(Addition icons) : 选择是否创建快速启动栏图标 或者 是否创建桌面快捷方式;
2)桌面浏览(Windows Explorer integration) : 浏览源码的方法, 单独的上下文浏览 只使用bash 或者 只用Git GUI工具; 高级的上下文浏览方法 使用git-cheetah plugin插件;
3)关联配置文件(Associate .git*) : 是否关联git配置文件, 该配置文件主要显示文本编辑器的样式;
4)关联shell脚本文件(Associate .sh) : 是否关联Bash命令行执行的脚本文件;
5)使用TrueType编码 : 在命令行中是否使用TruthType编码, 该编码是微软和苹果公司制定的通用编码;
设置开始菜单中快捷方式的目录名称,默认就好,下一步吧
设置环境变量 : 选择使用什么样的命令行工具, 一般情况下我们默认使用Git Bash即可, 默认选择;
1)Git自带 : 使用Git自带的Git Bash命令行工具;
2)系统自带CMD : 使用Windows系统的命令行工具;
3) 二者都有 : 上面二者同时配置, 但是注意, 这样会将windows中的find.exe 和 sort.exe工具覆盖, 如果不懂这些尽量不要选择;
选择换行格式 ,依然是默认就好。
1)检查出windows格式转换为unix格式 : 将windows格式的换行转为unix格式的换行在进行提交;
2)检查出原来格式转为unix格式 : 不管什么格式的, 一律转为unix格式的换行在进行提交;
3)不进行格式转换 : 不进行转换, 检查出什么, 就提交什么;
选择终端模拟器,依然默认就好
1)使用MinTTY,就是在Windows开了一个简单模拟Linux命令环境的窗口Git Bash
2)使用windows的系统的命令行程序cmd.exe
选择默认就好,不用文件系统缓存
安装中……
git终于安装成功咯。
2.2 利用git客户端绑定用户(自己的github账号)
1)建立一个本地GitHub文件夹
进入文件夹右键出现如下图,点击git bush
git config –global 参数,有了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然你也可以对某个仓库指定的不同的用户名和邮箱。
3 创建github repository(仓库)
3.1 登录github
github的官方网址:https://github.com ,如果没有账号,赶紧注册一个。
3.2创建repository(仓库)
登录后可以从下面的地方切换到repository选项卡
点击进入后也能看到repository,之后可以看到很醒目的new按钮。点击它,开始创建自己的粮仓了。
下面是创建仓库信息,只有名字是必填项,现在我创建了一个仓库叫:20170617test1
创建成功后,可以看到自己的仓库地址,如此,我的远程免费的仓库就创建了。它还介绍了github仓库的常用指令。这个指令需要在本地安装git客户端。
- git init //把这个目录变成Git可以管理的仓库
- git add README.md //文件添加到仓库
- git add. //不但可以跟单一文件,还可以跟通配符,更可以跟目录。一个点就把当前目录下所有未追踪的文件全部add了
- git commit -m “first commit” //把文件提交到仓库
- git remote add origin [email protected]:wangjiax9/practice.git //关联远程仓库
- git push -u origin master //把本地库的所有内容推送到远程库上
4 为Github账户设置SSH key
众所周知ssh key是加密传输。
加密传输的算法有好多,git使用rsa,rsa要解决的一个核心问题是,如何使用一对特定的数字,使其中一个数字可以用来加密,而另外一个数字可以用来解密。这两个数字就是你在使用git和github的时候所遇到的public key也就是公钥以及private key私钥。
其中,公钥就是那个用来加密的数字,这也就是为什么你在本机生成了公钥之后,要上传到github的原因。从github发回来的,用那公钥加密过的数据,可以用你本地的私钥来还原。
如果你的key丢失了,不管是公钥还是私钥,丢失一个都不能用了,解决方法也很简单,重新再生成一次,然后在github.com里再设置一次就行
4.1 生成ssh key
首先检查是否已生成** cd ~/.ssh,ls如果有2个文件,则**已经生成,id_rsa.pub就是公钥
也可以打开我的电脑C:\Users\Administrator.ssh 里面找到,如下图所示:
如果没有生成,那么通过$ ssh-****** -t rsa -C “[email protected]”来生成。
1)是路径确认,直接按回车存默认路径即可
2)直接回车键,这里我们不使用密码进行登录, 用密码太麻烦;
3)直接回车键
生成成功后,去对应目录C:\Users\Administrator.ssh里(Administrator为电脑用户名,每个人不同)用记事本打开id_rsa.pub,得到ssh key公钥
4.2 为github账号配置ssh key
切换到github,展开个人头像的小三角,点击settings
然后打开SSH keys菜单, 点击Add SSH key新增**,填上标题,跟仓库保持一致吧,好区分。接着将id_rsa.pub文件中key粘贴到此,最后Add key生成**吧。
如此,github账号的SSH keys配置完成。
5 上传本地项目到github
5.1 创建一个本地项目
我这创建了一个文件20170617test,并创建了两个test1,test2 文本文件,.git的隐藏文件是执行git init 命令之后生成的。
5.2 建立本地仓库
创建新仓库的指令:
1. git init //把这个目录变成Git可以管理的仓库 ,初始化成功后你会发现项目里多了一个隐藏文件夹.git
2. git add README.md //文件添加到仓库 ,可有可无,推荐写上,注意git是不能管理空的文件夹的,文件夹里必须有文件才能add。
3. git add. //不但可以跟单一文件,还可以跟通配符,更可以跟目录。一个点就把当前目录下所有未追踪的文件全部add了
4. git commit -m “first commit” //把文件提交到仓库 ,双引号内是提交注释,本次修改内容概要。
5. git remote add origin https://github.com/liuliu629/20170217test.git //关联远程仓库
6. git push -u origin master //把本地库的所有内容推送到远程库上
首先,进入到20170617test项目目录,还记得创建仓库成功后的那个页面吧,指令都在呢。
其次,上传修改的文件或文件中的内容,在此以test3为例
6 参考资料:
主要参考资料:github入门到上传本地项目
其他参考文献,这里包括git GUI的使用
Git Gui for Windows的建库、克隆(clone)、上传(push)、下载(pull)、合并
推荐资料
廖雪峰git教程
git 常用命令
git常用命令
常用 Git 命令清单
Git常用命令
总结自己的Git常用命令