• ubantu下git的连接和使用


    本文整理了Ubuntu下git的一些常用操作命令清单,方便以后查阅。学习网站参考廖雪峰老师网站

    操作命令

    创建仓库,并提交一个readme文件。

    sudo apt-get install git

    mkdir mygit

    cd mygit

    git init

    git config --global user.email "angiing.ooe@gmail.com"

    git config --global user.name "zltingg"

    vi readme.txt

    git add readme.txt

    git commit -m "wrote a readme file."

    文件改动怎么办

    git status随时掌握工作区的状态,告诉你有文件被修改过

    git diff查看文件修改内容

    git log git log --pretty=oneline显示从最近到最远的提交日志

    版本回退

    git reset --hard commit_id允许我们在版本的历史之间穿梭(commit后没有推到远程库), HEAD指向的版本就是当前版本,HEAD^指向上一个版本

    git reflog查看命令历史,以便确定要回到未来的哪个版本

    版本库(Repository)

    工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

    Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD

    git diff HEAD -- readme.txt命令可以查看工作区和版本库里面最新版本的区别

    撤销修改

    git checkout -- readme.txt丢弃工作区文件的修改

    git reset HEAD readme.txt可以把暂存区的修改撤销掉(unstage),重新放回工作区

    删除文件

    rm test.txt删除test文件

    git rm test.txt删除版本库中的这个test文件

    或者git checkout -- test.txt恢复误删

    git checkout本质是用版本库里的版本替换工作区的版本

    远程仓库

    1. 在/home/zlt下面创建SSH Key:ssh-keygen -t rsa -C "angiing.ooe@gmail.com",两次回车后要求输入密码(至少5位),输入两次密码后创建SSH Key完成。

    在/home/zlt/.ssh中出现id_rsa和 id_rsa.pub文件即为创建成功。

    1. 在GitHub下添加SSH Key的公钥,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容。

      如果有若干电脑,只要把每台电脑的Key都添加到GitHub,就可以在每台电脑上往GitHub推送了。

    添加远程库

    本地有一个仓库,想要在GitHub上同步这个仓库。

    步骤:

    1. 新建一个仓库,设置Repository name为mygit(与本地库相同)
    2. git remote add origin git@github.com:zltingg/mygit.git关联远程库,远程库的名字就是origin
    3. git push -u origin master第一次推送master分支的所有内容

    如果推送失败,可以检查一下github上settings-Emails的设置,把Keep my email address private取消勾选。

    先创建远程库,再从远程库克隆。(常用)

    在用户主目录下执行git clone git@github.com:zltingg/gitskills.git

    分支管理

    创建切换

    查看分支:git branch

    创建dev分支:git branch dev

    切换到master分支:git checkout master

    创建+切换到dev分支:git checkout -b dev

    合并dev分支到当前master分支:git merge dev(fast forward看不到合并历史)

    git merge --no-ff -m "merge with no-ff" dev可以看到合并历史

    删除dev分支:git branch -d dev

    git branch -D dev强行删除没有被合并过的dev分支

    冲突

    1. 本地两个分支对同一文件作修改并提交,merge时产生冲突:

      手动修改冲突文件,再提交,再删除小分支,再push。

      git log --graph --pretty=oneline --abbrev-commit查看分支合并的情况。

    解决bug

    1. git stash把当前工作现场存起来
    2. 通过创建新的bug分支修复bug,然后合并,最后删除
    3. git stash list 查看工作现场存到哪儿了
    4. git stash pop恢复现场并删除stash内容

    多人协同

    1. 首先,可以试图用git push origin <branch-name>推送自己的修改;
    2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
    3. 如果合并有冲突,则解决冲突,并在本地提交;
    4. 没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

    如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>

    查看远程库信息,使用git remote -v

    在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致

    rebase

    git rebase把本地未push的分叉提交历史整理成直线

    标签管理

    创建标签

    发布一个版本时,我们通常先在版本库中打一个标签(tag):

    git tag <tagname>用于新建一个标签,默认为HEAD,也可以指定一个commit id

    git tag -a <tagname> -m "blablabla..."可以指定标签信息

    git tag可以查看所有标签

    删除标签

    • 命令git push origin <tagname>可以推送一个本地标签;
    • 命令git push origin --tags可以推送全部未推送过的本地标签;
    • 命令git tag -d <tagname>可以删除一个本地标签;
    • 命令git push origin :refs/tags/<tagname>可以删除一个远程标签。

    配置别名

    git config --global alias.lg "log --graph --pretty=oneline --abbrev-commit"以后输入git lg就可以查看commit历史。

    用户主目录下vi .gitconfig可查看alias.的内容

    忽略特殊文件

    问题:把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件。

    解决方法:在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件。

  • 相关阅读:
    Hsl PLC
    .NET平台常用框架整理
    SSH全注解实例详解
    word2vec (CBOW、分层softmax、负采样)
    pandas dataframe 一行变多行 (query pv统计term pv)
    python 按二维数组的某行或列排序 (numpy lexsort)
    基于决策树的分类算法
    【linux】 mail/mutt 发送邮件
    【python】含中文字符串截断
    【python】 判断纯ascii串
  • 原文地址:https://www.cnblogs.com/zlting/p/9603430.html
Copyright © 2020-2023  润新知