太基础的就不写了,没必要。
# delete local branch, -d是删除, -D是强制删除
git branch -D localBranchName
for branch in `git branch -r | grep -v '\->'`; do
git branch --track "${branch#origin/}" "$branch"
done
git push --all && git push --tags
# delete remote branch or tag
git push origin --delete <remoteBranchName or tagName>
# 清除远程已经不存在的分支的跟踪分
git fetch -p
# create tag
git tag <tag_name>
# delete tag
git tag -d <tag_name>
# push tag to remote
git push --tags
git push --tag
git config color.ui true
# git lfs need git version >= 1.8.2
yum install git-lfs -y
git lfs install
git submodule add [email protected]:miaoyc666/pyArsenal.git
git submodule init
git submodule update
git lfs install
开启lfs功能- 大文件cp到git库
git lfs track
进行大文件追踪, 例如:git lfs track abc/aaa.tgz
此时cat .gitattributes
,会看到:abc/aaa.tgz filter=lfs diff=lfs merge=lfs -text
git add .gitattributes
commit
git lfs ls-files
可以显示当前跟踪的文件列表
git push -u origin {branch name}
git remote rm origin
git remote add origin <new project>
git reset --hard {commit_id}
git push --force # 慎重使用
git merge -X theirs origin/xxxxx-branch
git rebase -i HEAD~3 # 3此处为可变,数值表示需要修改的最近几条提交的数量
git commit --amend
git rebase --continue
三条语句组合使用
# 举例如下:修改最后一条提交记录的时间
1.git rebase -i HEAD~1, 输入完命令后在弹出框内选择commit, 修改commit前的标识为edit
2.git commit --amend --date="2021-12-26T23:01:07"
3.git rebase --continue
4.git push --force # 慎重使用
git filter-branch --env-filter '
OLD_EMAIL="[email protected]"
CORRECT_NAME="miaoyc"
CORRECT_EMAIL="[email protected]"
if [ "$GIT_COMMITTER_EMAIL" = "$OLD_EMAIL" ]
then
export GIT_COMMITTER_NAME="$CORRECT_NAME"
export GIT_COMMITTER_EMAIL="$CORRECT_EMAIL"
fi
if [ "$GIT_AUTHOR_EMAIL" = "$OLD_EMAIL" ]
then
export GIT_AUTHOR_NAME="$CORRECT_NAME"
export GIT_AUTHOR_EMAIL="$CORRECT_EMAIL"
fi
' -f --tag-name-filter cat -- --branches --tags
# 镜像仓库的方式
1. git clone --bare [email protected]:miaoyc666/rd-manual.git
2. 新建git库: [email protected]:miaoyc666/rd-manual_new.git
3. cd rd-manual.git
4. git push --mirror [email protected]:miaoyc666/rd-manual_new.git
# 修改远程仓库的方式
1. 新建git库: [email protected]:miaoyc666/rd-manual_new.git
2. 在旧仓库新增远程仓库:git remote add home [email protected]:miaoyc666/rd-manual_new.git
3. git push home
git clone https://example.com/repo-B.git
cd repo-B
git remote add repo-A https://example.com/repo-A.git
git push repo-A main --force # 此处main表示想要推送的仓库B的分支名称,如果仓库A存在main分支,会覆盖提交
1. 重新git clone项目;
2. 修改.git/config文件, 将[email protected]:miaoyc666/rd-manual.git替换为[email protected]:miaoyc666/rd-manual_new.git
git push --force