git和github新手快速操作流程

git和github新手快速操作流程

本文主要介绍利用git版本控制将项目托管到远程仓库github上的一般性操作流程,为了给正在学习git的同学们一个小小的参考,以便更轻松的去深入学习git,本文所有操作均在Windows环境下进行。git和github新手快速操作流程

安装配置部分

第一步:安装git

Windows平台可直接到官网http://www.git-scm.com/下载安装。或者下载Cmder这款工具代替git工具也是很不错的,具体参考:逆天神器cmder 和 Cmder简单使用小结 。

Linux平台安装: sudo apt-get install git-core

第二步:配置全局用户

打开Git Bash 工具敲入命令

 
1
2
git config --global user.name "codesboy"
git config --global user.email "565195693@qq.com"

此时在用户目录下会出现一个隐藏的配置文件 .gitconfiggit和github新手快速操作流程

第三步:生成密钥 SSH key

ssh-keygen -t rsa -C "565195693@qq.com"  三次回车默认即可,此时在用户目录下会出现一个隐藏的文件夹 .ssh/ ,在这个文件夹里会生成id_rsa和id_rsa.pub两个文件。git和github新手快速操作流程

如果出现 ssh-keygen不是内部或外部命令 这样的错误提示,则需要将ssh-keygen.exe所在路径添

加到系统环境变量中的path里去。

第四步:添加密钥 SSH key 到github

github官网注册一个账号,然后到个人设置面板里选择SSH and GPG keys选项,点击右侧的New SSH key,title随意写,把id_rsa.pub文件里面的内容复制添加到key值里面,,然后点击Add SSH Key.git和github新手快速操作流程

第五步:验证密钥

 
1
ssh -T git@github.com

需要输入yes确认,然后如果出现这样的信息表示密钥创建成功:

 
1
Hi codesboy! You've successfully authenticated, but GitHub does not provide shell access.

git和github新手快速操作流程

创建项目部分

第一步:在远程github上创建一个项目

点击 New repository选项创建一个新的仓库,填好仓库名称Repository name、此仓库的说明Description(optional)、其他选项默认或根据自己需求选择即可。最后点击 Create repository 完成仓库创建。

第二步:克隆远程仓库到本地

git clone https://github.com/codesboy/myproject.git

https://github.com/codesboy/myproject.git是上面新建好的远程仓库地址

注意这里有HTTPS和SSH两种clone方式

第三步:为克隆到本地的仓库修改或添加自己的项目文件

第四步:把添加或修改或删除的所有内容添加到索引中(本地暂存区)

git add . 或 git add --all

为commit做好准备,可以 git diff --cached  查看那些改动将被提交

第五步:提交修改 git commit 到本地仓库

git commit -m "my first commit"

注:my first commit是对本次提交的说明,如果不加-m参数 ,git将调到一个文本编译器(通常是vim)来让你输入提交的描述信息,

可能一天下来,你对工作树中的许多文档都进行了更新(文档添加、修改、删除),但是我忘记了它们的名字,此时若将所做的全部更新添加到索引中,比较轻省的做法就是:
git commit -a -m "提交的描述信息"
git commit 命令的-a 选项只将所有被修改或者已删除的且已经被git管理的文档提交倒仓库中,不能添加用户新增的文件到索引中,如果没有新增的内容就可以使用git commit -a -m ""或者git commit -am""命令
git commit --amend命令可以修改最近一次的提交说明(注释)

第六步:推送到远程github仓库

 
1
git push -u origin master  //输入用户名和密码

注:首次push 要加参数 -u

github免输帐号密码的配置:(Windows)

1、添加名为HOME的环境变量,值为%USERPROFILE%

2、在计算机用户文件夹下创建名为_netrc的文件,内容为:

machine github.com

login username

password password

 
1
##上面的username和password改成你自己的github用户名和密码

推荐另外一种在push的时候不需要输入密码的方式:

用ssh协议,而非https协议,用git remote -v可以查看使用的哪种方式

直接修改配置文件.git/config,把url项设置成如下格式

url = git@github.com:codesboy/xxx.git

经过上面这些步骤,这时到远程github仓库去查看就会看到有本地提交上来的文件


除了上面所列出的以外,git还有其他很多常用的命令,这里也总结一下:

git init 初始化仓库,在本地新建仓库会用到

git log 查看git日志

git status 查看当前状态

git remote add origin https://github.com/username/project.git 关联一个远程仓库

或者git remote add origin git@github.com:username/project.git(推荐)需要配置ssh

git remote -v 查看远程版本仓库连接

查看所有的分支和当前处于哪个分支:git branch

创建本地仓库分支:git branch 分支名称

删除本地仓库分支:git branch -d 分支名称

删除某个文件夹或路径:git rm -r --cached 文件夹或文件路径

切换到本地某分支:git checkout 分支名称

合并本地某分支到当前分支:git merge –no-ff -m “remark” 分支名称

创建并切换到本地该分支:git checkout -b dev

拉取版本库最新数据到本地仓库:git pull

2017-07-21新增:配置本地多个git用户

1.删除之前配置的全局用户名和邮箱文件C:\Users\admin\.gitconfig

2.配置第二个用户的ssh key

ssh-keygen -t rsa -C "201988099@qq.com"

执行该命令后,出现第一个选项不要直接回车,如果直接回车会覆盖掉第一个用户默认的ssh key文件id_rsa和id_rsa.pub,这里需要设置一个新的名称,比如id_rsa_user2。剩下的两项可以直接回车。然后会生成id_rsa_user2和id_rsa_user2.pub两个文件,将这两个文件移动到C:\Users\admin\.ssh下面去。

3.将id_rsa_user2.pub文件里面的内容复制到github里去。

4.在C:\Users\admin\.ssh下面新建一个config文件,写入以下内容

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Host codesboy
    HostName github.com
    User git
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/id_rsa
 
Host cnnet
    HostName github.com
    User git
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/cnnet
 
Host chinaweb
    HostName github.com
    User git
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/chinaweb

对此config配置文件解释一下:

Host
它涵盖了下面一个段的配置,我们可以通过他来替代将要连接的服务器地址。
这里可以使用任意字段或通配符。
当ssh的时候如果服务器地址能匹配上这里Host指定的值,则Host下面指定的HostName将被作为最终的服务器地址使用,并且将使用该Host字段下面配置的所有自定义配置来覆盖默认的/etc/ssh/ssh_config配置信息。
git@github.com:用户名/项目名.git

其中的git表示用户名,github.com表示服务器别名
Port
自定义的端口
User
账号,要与git config的email对应
HostName
真正连接的服务器地址一般为github.com或者git.oschina.net等其他git服务器
PreferredAuthentications
指定优先使用哪种方式验证,支持密码和秘钥验证方式
IdentityFile
指定本次连接使用的私钥文件,即用 ssh-keygen -t rsa -C "xxx@qq.com" 生成的文件名

Ps

通过config文件可以管理多个ssh会话。通过Host别名也可以直接【ssh 别名】登录到其他机器上

       配置了User,git push时就一定要配置相同的email
       如果不设置User,随意一个user.email都可以提交git push
       如果设置了User,user.email必须匹配到config中的User才能提交【git config user.email=xxxx@xxx.com】
 

5.验证ssh key

ssh -T git@cnnet cnnet是在config里自定义的Host别名

6.git remote也要使用别名

git remote add origin git@cnnet:cnnet/test.git

说明

id_rsa:私钥
id_rsa.pub:公钥
known_hosts:访问过的机器的公钥,第一次ssh 其他机器时如果有权限访问,会提示是否保存信息,下次会校验访问该机器的公钥与known_hosts中的是否一致,如果不一致则不能登录过去。解决方案是删除known_hosts中该条机器的记录
 
git push时需要配置user的email和name,除了上面说的配置了~/.ssh/config的User的情况。
email和name可以随便填写,不存在的github账号也可以提交成功,只要你把ssh的公钥加到github里即可。
只是如果email不存在,则github上提交记录上用户头像不能点击;如果真实存在的github账号,点击进入该用户的个人主页
 
 
上一篇:WPF新手快速入门系列 1.布局


下一篇:【转载】使用IntelliJ IDEA 配置Maven(入门)