git宝典—应付平常工做使用足够的指北手册

最近公司gitlab又迁移,一堆git的命令骚操做,然鹅git命令,感受仍是得复习下——其实,git如今界面操做工具蛮多,好比intellij 自带的git操做插件就不错,gitlab github 插件市场也有不少,——可是,基本命令仍是整理汇总,记下笔记!php

创建本地仓库git

git init  建立本地仓库 git init [project-name]github

git remote add origin git@github.com:UserName/yourProjectName.git   把本地仓库和远程仓库关联起来, 若是不执行这个命令的话,每次 push 的时候都须要指定远程服务器的地址shell

 

git clone https://github.com/zhoulujun/yourProjectName.git缓存

提交本地修改到远程仓库中:

git add -- 将改动添加到本地仓库中  服务器

  • git add [file1] [file2] ...  ||  git add [dir] 添加指定文件||目录到暂存区ssh

  • git add -A ||  git add .添加当前目录的全部文件到暂存区ide

  • git add -p 添加每一个变化前,都会要求确认,对于同一个文件的多处变化,能够实现分次提交工具

git rm xxx      -- 从本地仓库中删除指定文件gitlab

  • git rm -r xxx   -- 从本地仓库中删除指定文件夹

  • git rm --cached [file]

  • git mv [file-original] [file-renamed]  更名文件,而且将这个更名放入暂存区

 

git commit -m "注释"    -- 把本机缓存中的内容提交到本机的 HEAD 里面

  • git commit -a 提交工做区自上次commit以后的变化,直接到仓库区

  • git commit -v 提交时显示全部diff信息

  • git commit --amend -m [message] 使用一次新的commit,替代上一次提交,若是代码没有任何新变化,则用来改写上一次commit的提交信息

  • git commit --amend [file1] [file2] ... 重作上一次commit,并包括指定文件的新变化

 

git push origin master  -- 把本地的 commit(提交) push 到远程服务器上, origin 也就是以前 git remote add origin 那个命令里面的 origin,origin 替代了服务器仓库地址:git@github.com:zhoulujun/yourProjectName.git 

 

git push remoteBranchName tagName提交指定tag

git push remoteBranchName --tags 提交全部tag

git转态查看

git status 查看状态

git branch 查看本地全部分支

  • git branch -r查看远程全部分支

  • git branch -a查看本地和远程全部分支

git tag  列出全部tag

git show tagName 查看tag信息

git log --stat 显示commit历史,以及每次commit发生变动的文件

分支操做

git checkout branchName 切换到指定分支,并更新工做区

git merge branchName 合并指定分支到当前分支

git branch newBranchName 新建一个分支,但依然停留在当前分支

git branch --track branch remote-branch 新建一个分支,与指定的远程分支创建追踪关系

git branch -D branchName //删除目标分支

git checkout -b branchName 新建并切换至新分支

git branch -d -r branchName 删除远程分支,其中

git branch -m oldbranchname newbranchname  重命名分支 使用-M则表示强制重命名

重命名远程分支

  • git branch -m old_name new_name 重命名分支

  • git checkout -b new_branch_name from_branch_name 本地创建 branch 並当即 checkout 切換過去

  • git push origin –delete old_name

git强制覆盖本地代码

与git远程仓库保持一致

git fetch --all

git reset --hard origin/master

git pull

git强制覆盖本地命令(单条执行):

git fetch --all && git reset --hard origin/master && git pull

git修改远程仓库地址

方法有三种:

1.修改命令

git remote origin set-url [url]

2.先删后加

git remote rm origin

git remote add origin [url]

3.直接修改config文件

.git文件夹,找到config,编辑,把就的项目地址替换成新的。

 

git 配置

git config --list        查看配置列表

git config --global user.name "xxx"   -- 配置用户名,上传本地 repository 到服务器上的时候,在 Github 上会显示这里配置的上传者信息

git config --global user.email "xxx"    -- 配置邮箱

配置 sshkey : 上传代码时使用这个 sshkey 来确认是否有上传权限

    1. 建立本地 ssh : ssh-keygen -t rsa -C "Github 的注册邮箱"

    2. 在 Github 中添加这个 sshkey : 

        复制  C:\Documents and Settings\Administrator\.ssh\id_rsa.pub 文件中的内容;

        登陆 Github --> Account Setting  --> SSH-KEY --> Add SSH-KEY --> 粘贴id_rsa.pub中的内容;

    3. 验证: ssh -T git@github.com

        出现 Hi xxx! You've successfully authenticated, but GitHub does not provide shell access. 说明配置成功,能够链接上 Github

 

使用 .gitignore 文件忽略指定的内容

    1. 在本地仓库根目录建立 .gitignore 文件。Win7 下不能直接建立,能够建立 ".gitignore." 文件,后面的标点自动被忽略;

    2. 过滤文件和文件夹: [Tt]emp/ 过滤 Temp\temp 文件夹; *.suo 过滤 .suo 文件;

    3. 不过滤文件和文件夹: !*.c

原文地址:git宝典-应付平常工做使用足够的指北手册 - git使用的的一些平常小结合集 - 周陆军的我的网站

不按期更新,文有不妥之处,请留言告知,多谢

相关文章
相关标签/搜索