Command line instructions
首先在git上创建工程
Git global setup
git config --global user.name "dushaochong"
git config --global user.email "dushaochong@analysys.com.cn"
Create a new repository
本地创建空的仓库并添加README文件,本地默认创建一个空EGMonitor_SDK文件夹
git clone git@git.analysys.cn:MobileProjectiOS/EGMonitor_SDK.git
cd EGMonitor_SDK
touch README.md
git add README.md
git commit -m "add README"
git push -u origin master
Existing folder or Git repository
在空仓库中添加工程文件并push到git仓库
cd existing_folder
git init
git remote add origin git@git.analysys.cn:MobileProjectiOS/EGMonitor_SDK.git
git add .
git commit -m "新工程添加"
git push -u origin master
克隆git现有仓库
命令:git clone [url]
运行后首次需要输入用户名及密码,即可克隆到本地
如:
git clone http://git.analysys.cn/MobileProjectiOS/EGMonitor_SDK.git
或
git clone http://git.analysys.cn/MobileProjectiOS/EGMonitor_SDK.git NewCatalogueName
git分支
############## git branch 操作 ##############
git branch ## 查看当前用户所处的分支
git branch -v ## 查看各个分支最后一个提交对象的信息
git branch dev1.0 ## 创建分支dev1.0
git branch --edit-description 分支名称 ## 添加分支描述信息或查看分支描述信息
git branch --set-upstream-to=origin/dev1.0 dev1.0 ## 一般多人操作同一个工程时,创建分支完成后,都会对分支进行跟踪操作,或提交时跟踪
git branch -r ## 列出远程分支
git branch -a ## 列出本地和远程分支;若要看到最新提交的分支,则需要进行pull一下,之后再查看;之后便可使用checkout命令切换分支到本地
git branch -m | -M oldBranch newBranch ## 重命名分支,如果newBranch名字以存在,则需使用-M强制命名;否则使用-m重命名
**删除远程分支**
git branch -r -d origin/branch-name ## 删除branchName分支 不能再当前分支下删除,需要切换到别的分支
git push origin :branch-name ## 一定记得push
git remote update origin --prune ## 如果A电脑删除了分支dev,B电脑以前使用过,则B电脑需要先更新远程分支,然后把本地无效分支删掉
############## git checkout 操作 ##############
git checkout -b dev1.0 ## 创建分支dev1.0并切换到dev1.0分支,此命令相当于:① git branch iss53 ② git checkout iss53
git checkout dev1.0 ## 若分支不存在,则新建分支dev1.0;若存在则切换分支到dev1.0
**跟踪远程分支**
git checkout --track origin/serverfix
git checkout -b localname origin/serverfix
############## git push 操作 ##############
git push --set-upstream origin dev1.0 ## 切换分支首次提交,以后可直接使用git push
git push [远程名] [本地分支]:[远程分支]
git push origin dev:dev ## 将本地分支push到远程分支
git push 分支名 --delete <branchName> ## 删除远程分支。先删除本地分支,然后:git push origin :test 将本地分支推送到远程
git push origin --delete tag <tagname> ## 删除远程tag。先删除本地tag,然后:git push origin :test 将本地tag推送到远程
git push -u origin dev -f ## 强制提交dev分支
############## git pull 操作 ##############
git pull ## 同步项目。有时回报错需要提交新更改或删除更改(git stash)\
git pull -t ## 同步远程tag信息
############## git merge 操作 ##############
## merge hotfix分支已修改并提交本地完成,且master分支都已推送到远程服务器
git checkout master ## 切换到主分支
git merge hotfix ## merge分支名称
git branch -d hotfix ## 删除botfix分支
git branch --merged ## 查看哪些分支已被并入当前分支
git branch –no-merged ## 未被并入当前分支
git fetch origin ## 同步远程服务器上的数据到本地
############## git remote 操作 ##############
git remote show origin ## 查看remote地址,远程分支,还有本地分支与之相对应关系等信息
git remote prune origin ## 删除远程仓库不存在的分支
############## 分支重命名 ##############
a. 重命名远程分支对应的本地分支
git branch -m old-local-branch-name new-local-branch-name
b. 删除远程分支
git push origin :old-local-branch-name
c. 上传新命名的本地分支
git push origin new-local-branch-name
记录每次更新到仓库
**检查当前文件状态**
git status ## 列出当前git管理下文件的修改、变化情况
**跟踪新文件**
git add README.md ## 跟踪后可用git status查看状态
**忽略某些文件**
cat .gitignore *.[oa] *~ ## 忽略所有以 .o 或 .a 结尾的文件、忽略所有以波浪符(~
)结尾的文件
**列出已修改文件**
git diff
**查看已暂存和未暂存的更新**
git diff --staged
或
git diff --cached
**提交更新**
git commit ## 确保所有文件都已git add,可在首行空行中添加提交注释信息
或
git commit -m "提交注释信息"
**跳过使用暂存区域**
git commit -a -m 'added new benchmarks' ## 跳过 git add步骤
**移除文件**
git rm grit.gemspec ## 删除已跟踪文件,即使用git add 添加的文件。需先使用rm 命令在当前目录下删除后,再执行此命令
把文件从 Git 仓库中删除(亦即从暂存区域移除),但保留在当前工作目录中
git rm --cached readme.txt
**修改文件名称**
git mv README.txt README ## 修改被跟踪文件的名称
查看提交历史
git log ## 查看所有修改历史
git log -p -2 ## -p 选项展开显示每次提交的内容差异,用 -2 则仅显示最近的两次更新
**将每个提交放在一行显示**
git log --stat ## 显示简要的增改行数统计
git log --pretty=oneline
git log --pretty=format:"%h - %an, %ar : %s" ## 定制日志显示格式
git log --pretty=format:"%h %s" --graph ## 展示每个提交所在的分支及其分化衍合情况
git log --since=2.weeks ## 最近两周内的提交
git log --pretty="%h - %s" --author=gitster --since="2008-10-01" \
--before="2008-11-01" --no-merges -- t/ ## 查看 Git 仓库中,2008 年 10 月期间,Junio Hamano 提交的但未合并的测试脚本(位于项目的 t/ 目录下的文件)
git log --grep 文件提交 ## 过滤提交中含有“文件提交”的日志
版本回退
git log --pretty=oneline ## 查看提交日志版本号
git reset --hard HEAD^ ## 回退到上一个版本号
git reset --hard HEAD~100 ## 回退到上100个版本号
git reset --hard 3628164 ## 指定回退到某个版本。3628164为git log --pretty=oneline查出的版本号
撤消操作
**修改最后一次提交**
git commit --amend ## 提交完了才发现漏掉了几个文件没有加,或者提交信息写错了,撤销操作
**取消已经暂存的文件**
git reset HEAD test.md ## 不小心使用git add . 添加到缓存区后,取消文件test.md文件
**取消对文件的修改**
git checkout -- README.md
远程仓库的使用
**查看当前的远程库**
git remote
git remote -v ## 显示对应的克隆地址
**添加远程仓库**
git remote add [shortname] [url]
git remote add pb git://github.com/paulboone/ticgit.git ## 添加一个新的远程仓库
**从远程仓库抓取数据**
git fetch pb
**推送数据到远程仓库**
git push [remote-name] [branch-name]
git push origin master ## 把本地的 master 分支推送到origin服务器上
**查看远程仓库信息**
git remote show [remote-name]
git remote show origin
**远程仓库的删除和重命名**
git remote rename pb paul ## 把 pb 改成paul
git remote rm paul ## 移除远程仓库paul
打标签
**列显已有的标签**
git tag
git tag -l 'v1.4.2.*' ## 列出1.4.2 系列的版本
**新建标签**
git tag -a v1.4 -m 'my version 1.4'
git show v1.4 ## git show 查看某次提交的修改内容
**补打标签**
$ git tag -a v0.1.1 9fbc3d0 ##(通过提交标识打
tag)
**删除标签**
git tag -d v0.1 ## 删除本地标签
git push origin :v0.1 ## 删除远程tag
**分享标签**
git push origin v1.5 ## 显式命令才能分享标签到远端仓库
git push origin --tags ## 推送所有本地新增的标签上去
遇到问题
1、最近由于过年长时间未操作gitlab,导致更新提交报错,报错如下:
! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'http://git.***.cn/**/document'
此原因可能是gitlab长时间不操作,主动对分支进行了保护,可以登录git,依次找到project->setting->protected branch,进行解锁即可。如下图:
Paste_Image.png
Paste_Image.png
2、提交代码时终端闪退,重新打开命令行再次提交时,报错如下:
fatal: Unable to create '/Users/**/Desktop/GitLab/**/.git/index.lock': File exists.
Another git process seems to be running in this repository, e.g.
an editor opened by 'git commit'. Please make sure all processes
are terminated then try again. If it still fails, a git process
may have crashed in this repository earlier:
remove the file manually to continue.
analysys-C:EGMonitor-Swift analysys$ git commit
fatal: Unable to create '/Users/**/Desktop/GitLab/**-Swift/.git/index.lock': File exists.
解决方法:
到项目git目录下执行以下语句后,重新git add .
rm -f ./.git/index.lock
3、git push 权限不允许 (MAC)
感谢这位大哥的文章: 寒潇
这是一个坑爹的问题,在网上搜了N多个基本都不行,主要是由于多账号问题导致,当push时git使用原有已保存的git账号。报错信息:
remote: Permission to xxx/ccccc.git denied to xxx.
fatal: unable to access 'https://github.com/xxx/ccccc.git/': The requested URL returned error: 403
解决方法:
找到钥匙串访问 -> 密码 -> 搜索 github.com 的密码,右击某条数据,显示简介 -> 属性 -> 显示密码 可查看账户密码。找到报错的账户删除即可,若账户较多可以试着挨个删除,然后测试 git push 操作,若push时显示输入用户名密码,则重新输入后可push成功。
$ git push -u origin master
Username for 'https://github.com': git账号
Password for 'https://xxx@xxx.com.cn@github.com': git密码
4、生成SSH keys时找不到对应文件
$ ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
但在 open ~/.ssh/
目录下未见文件生成,默认生成在当前执行命令的目录下
解决办法:
到ssh目录下执行命令:
$ cd ~/.ssh/
$ ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
5、添加ssh keys
$ git config user.name ## 查看当前配置用户
$ git config user.email ## 查看当前用户配置邮箱
$ cd ~/.ssh/
$ ssh-keygen -t rsa -b 4096 -C "user.email" ## 生成ssh
然后添加至git SSH keys 中
网友评论