git 使用说明

作者: 多飞 | 来源:发表于2016-05-24 22:25 被阅读160次

    一、工作步骤:

    1. 创建一个远程的空代码库(在BitBucket上)
    2. 在本地代码库添加一个项目
    3. 在分支上开发新功能
    4. a) 保留新功能 或者b) 丢弃它们
    5. 也许,回到某个早先的时间点
    6. 将本地代码库推送到远程代码库
    7. 在另一台机器上取得远程代码库

    二、前期准备

    2.1 创建一个远程代码库

    很多人喜欢用Github。我个人更喜欢BitBucket,因为它提供了不限制的私有代码库,那是我最需要的。你可以将下列指令转换到Github上,这些过程是相同的。
    那么,去到bitbucket并注册一个账号。一旦完成,登录后点击最上方的“create(创建)”按钮。照着填写表格,勾选私有代码库。

    2.2 配置Git

    在我们能用Git工作之前,我们需要做个一次性的配置。为了Git能跟踪到谁做了修改,我们需要设置你的用户名。我强烈建议你使用与注册BitBucket账号相同的用户名和电子邮箱地址。发送这些命令,相应地替换掉其中的“your_username”your_email@domain.com(注意引号):
    $ git config --global user.name lnj
    $ git config --global user.email lnj321@gmail.com
    我们都设好了。你无需在你的机器上再重复这些配置,但如果你在另一台机器上工作的话,不要忘记这些配置。如果你忘记做初始的配置,Git不会允许你提交任何东西,这会让你困扰。

    2.3 创建一个本地代码库

    作为例子,我们会假装我们有一个网站(无所谓技术)存在于我们机器上的‘workspace’文件夹下的’my_site’文件夹内。在命令行中,去到你的站点的根文件夹。在OS XLinux上

    cd ~/workspace/my_site/

    在Windows上:

    cd c:\workspace\my_site

    我们首先需要告诉Git这个文件夹是我们需要跟踪的项目。所以我们发送这个命令来初始化一个新的本地Git代码库
    git init
    Git会在my_site文件夹内创建一个名为.git的隐藏文件夹,那就是你的本地代码库。

    三、git 操作步骤

    3.1 加载(Stage)文件

    我们现在需要命令Git我们需要加载(stage)所有项目文件。发送:

    git add .

    最后的“.”符号的意思是“所有文件、文件夹和子文件夹”。假如我们只想要把特定文件添加到源代码控制中去,我们可以指定它们:

    git add my_file, my_other_file

    3.2 提交文件

    现在,我们想要提交已加载(staged)的文件。阅读“添加一个时间点,在这里你的文件处在一个可还原的状态”。我们提交我们的文件时,总是附带着有意义的注释,描述了它们现在的状态。我一直用“initial commit”来作为第一个提交的注释。
    git commit -m "initial commit"

    就这样。现在你随时都可以回滚到这个提交状态。如果你有需要检查你现在的已加载(staged)和未加载(unstaged)文件的状态、提交等,你可以询问git的状态:

    git status

    3.3 创建分支

    建立分支是你创建代码的独立版本的动作,独立于你的主干分支。默认地,每次你提交到Git的文件都会被储存到“master(主干)”分支。
    现在我们来说说,你想要向项目里添加一个功能,但你想要能够回滚到现在版本,以防出现差错,或者你决定要放弃这个功能。这就是你创建分支的时候了。创建并同时切换到你新建的分支,发送:

    git checkout -b new_feature

    或者,你可以先创建一个分支然后手动切换,就像这样:

    git branch new_feature
    git checkout new_feature

    要看你现在项目下所有的分支,发送这个:

    git branch

    现在你可以在你的项目上无所顾忌地做任何你想做的:任何时候,你都可以回到你创建分支前的状态。注意,你同时可以有多个分支,甚至可以从一个分支上再创建一个分支。

    3.4 合并分支

    当你对你的新功能满意了的时候,你想要把它加到主干分支上。当你在你的新功能分支上时,你首先需要加载(stage)并且提交你的文件:

    git add .
    git commit -m "adds my new feature"

    然后你移到你的主干分支:

    git checkout master

    像这样合并:

    git merge new_feature

    此时,你的主干分支和你的新功能分支会变成一样的了。

    3.5丢弃分支

    相反,如果你打算丢弃你在分支里做的修改,你首先需要加载(stage)你的文件并且在分支里提交:

    git add .
    git commit -m "feature to be discarded"

    然后,你移到主干分支:

    git checkout master

    现在,你的代码处于你创建分支之前的状态了。

    3.6 删除一个分支

    如果你要把你的分支合并到主干分支,从主干(master)分支上发送:

    git branch -d new_feature

    假如修改已经合并了,它只会删除分支。假如分支没有合并,你会得到一个错误信息。删除一个未合并的分支(通常你不想保留的修改),你需要发送一样的命令附带一个大写D。意思是“强制删除分支,无论如何我不想要它了。”:

    git branch -D new_feature

    3.7 回滚到之前的提交状态

    在某些时候,你可能想要回到之前的代码版本。首先,你需要找到你想回到哪个版本。要看所有的完成了的提交,发送:

    git log --graph

    这会输出你的提交的历史记录,像这样:

    * commit 230a1a564dd773d029f44606bf7c66b373f9558a
    | Author: duofei <duofei3g@163.com>
    | Date:   Fri May 20 16:22:54 2016 +0800
    |
    |     水情简报,时间筛选
    |
    * commit bfad84ce1268eb1f7eb022149bf347ea81947587
    | Author: duofei <duofei3g@163.com>
    | Date:   Thu May 19 17:16:14 2016 +0800
    |
    |     水情简报,最新简报
    |
    * commit 77ea9237b0498d61a6089c5e1e308ddef240e24f
    | Author: duofei <duofei3g@163.com>
    | Date:   Thu May 19 13:48:23 2016 +0800
    |
    |     水情简报,cell
    |
    * commit 54c19ee394334026b36c5c01dafa8cc46eeb344c
    | Author: ritalina5969 <ritalina5969@gmail.com>
    | Date:   Tue May 17 17:39:47 2016 +0800
    |
    |     CGRectMakeInViewWillAppear
    

    如果你想回到“水情简报,cell”这个提交,简单地用提交的ID做签出(checkout)(我通常只用到ID开头的9个字符)

    git checkout 77ea9237b
    git reset --hard 77ea9237b

    你也可以签出到一个新的分支,像这样:

    git checkout -b my_previous_version 77ea9237b

    只是别太疯狂了!你的分支越复杂,就越难确定你真正在做什么。

    3.8 推送到远程代码库

    在第一次你想推送一个本地代码库到远程代码库时,你需要把它添加到你的项目配置里。像这样做:

    git remote add origin https://your_username@bitbucket.org/your_username/name_of_remote_repository.git
    

    注意这里的“origin”只是一个习惯。它是你的远程代码库的别名,但是你可以用其他任何你喜欢的词。你甚至可以有多个远程代码库,你只需要给它们起不同的别名。
    之后,你想要推送你的本地代码库的主干分支到你的远程代码库:

    git push origin master//将代码推送到远程代码库
    建议一般建议在 push之前先执行:
    git pull origin master //将远程代码库的代码同步至本地仓库
    

    如果你使用Bitbucket,在这时,你会被请求输入你的密码。照做,你的本地代码库会被推送到你的远程代码库上。

    3.9 取得远程代码库的一份本地拷贝

    如果你还没有一份远程代码库的本地版本(例如,如果你在另一台机器上开始工作,这台机器上还没有用过这个项目),你首先需要拷贝(clone)它。去到你的代码库想要拷贝到的文件夹下,并发送:

    git clone https://your_username@bitbucket.org/your_username/name_of_remote_repository.git
    

    另一方面,如果你已经在本地的项目上工作了,只是想从远程代码库上取得它最新的版本,移动到项目的根目录下,并发送:

    git pull origin master

    3.10 别名

    Git允许你为你常用的命令创建快捷方式(别名)。例如,如果你不想每次都输入git commit -m “some comment”,而是输入git c “some comment”,你可以向你的git全局配置里添加一个别名来实现,像这样:

    git config --global alias.c 'commit -m'

    这是我使用的别名列表:

    git config --global alias.c 'commit -m'
    git config --global alias.co 'checkout'
    git config --global alias.cob 'checkout -b'
    git config --global alias.br 'branch'
    git config --global alias.m 'merge'
    git config --global alias.a 'add .'
    git config --global alias.s 'status'
    git config --global alias.dbr 'branch -d'
    

    四、git常用命令大全

    4.1 远程仓库相关命令

    检出仓库:$ git clone git://github.com/jquery/jquery.git
    查看远程仓库:$ git remote -v
    添加远程仓库:$ git remote add [name] [url]
    删除远程仓库:$ git remote rm [name]
    修改远程仓库:$ git remote set-url --push [name] [newUrl]
    拉取远程仓库:$ git pull [remoteName] [localBranchName]
    推送远程仓库:$ git push [remoteName] [localBranchName]
    

    4.2 分支(branch)操作相关命令

    查看本地分支:$ git branch
    查看远程分支:$ git branch -r
    创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切        换为当前分支
    切换分支:$ git checkout [name]
    创建新分支并立即切换到新分支:$ git checkout -b [name]
    删除分支:$ git branch -d [name] ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项
    合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并
    创建远程分支(本地分支push到远程):$ git push origin [name]
    删除远程分支:$ git push origin :heads/[name] 或 $ gitpush origin :[name]`
    
    *创建空的分支:(执行命令之前记得先提交你当前分支的修改,否则会被强制删干净没得后悔)
    $git symbolic-ref HEAD refs/heads/[name]
    $rm .git/index
    $git clean -fdx
    

    4.3 常用命令(把常用的指令记住,其他不常用的用到时候在来查就好了)

    git branch 查看本地所有分支
    git status 查看当前状态 
    git commit 提交 
    git branch -a 查看所有的分支
    git branch -r 查看本地所有分支
    git commit -am "init" 提交并且加注释
    git remote add origin git@192.168.1.119:ndshow
    git push origin master 将文件给推到服务器上
    git remote show origin 显示远程库origin里的资源
    git push origin master:develop
    git push origin master:hb-dev 将本地库与服务器上的库进行关联
    git checkout --track origin/dev 切换到远程dev分支
    git branch -D master develop 删除本地库develop
    git checkout -b dev 建立一个新的本地分支dev
    git merge origin/dev 将分支dev与当前分支进行合并
    git checkout dev 切换到本地dev分支
    git remote show 查看远程库
    git add .
    git rm 文件名(包括路径) 从git中删除指定文件
    git clone git://github.com/schacon/grit.git 从服务器上将代码给拉下来
    git config --list 看所有用户
    git ls-files 看已经被提交的
    git rm [file name] 删除一个文件
    git commit -a 提交当前repos的所有的改变
    git add [file name] 添加一个文件到git index
    git commit -v 当你用-v参数的时候可以看commit的差异
    git commit -m "This is the message describing the commit" 添加commit信息
    git commit -a -a是代表add,把所有的change加到git index里然后再commit
    git commit -a -v 一般提交命令
    git log 看你commit的日志(当前状态为终点的日志)
    git reflog (查看当前仓库执行过的所有日志)注意区别,都能查看哈希值、commit、
    checkout、reset、merge等git命令。
    git diff 查看尚未暂存的更新
    git rm a.a 移除文件(从暂存区和工作区中删除)
    git rm --cached a.a 移除文件(只从暂存区中删除)
    git commit -m "remove" 移除文件(从Git中删除)
    git rm -f a.a 强行移除修改后文件(从暂存区和工作区中删除)
    git diff --cached 或 $ git diff --staged 查看尚未提交的更新
    git stash push 将文件给push到一个临时空间中
    git stash pop 将文件从临时空间pop下来
    git remote add origin git@github.com:username/Hello-World.git
    git push origin master 将本地项目给提交到服务器中
    git pull 本地与服务器端同步
    git push (远程仓库名) (分支名) 将本地分支推送到服务器上去。
    git push origin serverfix:awesomebranch
    git fetch 相当于是从远程获取最新版本到本地,不会自动merge
    git commit -a -m "log_message" (-a是提交所有改动,-m是加入log信息)   本地修改同步至服务器端 :
    git branch branch_0.1 master 从主分支master创建branch_0.1分支
    git branch -m branch_0.1 branch_1.0 将branch_0.1重命名为branch_1.0
    git checkout branch_1.0/master 切换到branch_1.0/master分支

    相关文章

      网友评论

        本文标题:git 使用说明

        本文链接:https://www.haomeiwen.com/subject/oygzrttx.html