关于git

关于用户名记录

全局 git config --global credential.helper store

单个项目

最简单的方式:在.git/config文件里面设置 url = https://帐号:密码@github.com/xxx/xxxlery-demo.git # 添加用户名密码
如果在创建git clone的时候 设置url为上面这个就最好了。不用二次设置。

 git clone https://demousername:demopassword@gitee.com/demogitaddr/demorep.git demosite

服务器中存在多个ssh密钥的,各个项目使用不同密钥

创建密钥时,保存文件名
ssh-keygen -t rsa -b 4096 -C "your_email@example.com" -f ~/.ssh/my_new_key
创建.ssh/config

   Host github1111
HostName github.com
User git
IdentityFile ~/.ssh/id_rsa_user1_1111

在git clone的时候 放弃使用 git@github.com/aa/bbrep 的方式而是使用 git@github1111/aa/bbrep
相当于对git地址去一个别名,由config从别名的host中取一个配置组。

ssssss

关于冲突

保留双方代码 git stash ;git commit;git stash pop
本地代码不要了 git reset --hard ;git pull

关于分支

本地自己(某项功能)的分支dev1 checkout -b dev1 ; 分支提交代码直到写完; 但主分支出现了小东西需要修复一下checkout master ;提交master的修复bug ;回到dev1继续写功能 checkout dev1;
写完了;到主分支去合并代码checkout master;git merge dev1 ;删掉这个写完的分支checkout -d dev1 ;回到自己的分支 checkout myself。
参考地址
git学习地址 阮一峰 http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html

关于git

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 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分支
du -hs

git branch 删除远程branch
git push origin :branch_remote_name
git branch -r -d branch_remote_name
-----------------------------------------------------------

初始化版本库,并提交到远程服务器端
mkdir WebApp
cd WebApp
git init 本地初始化
touch README
git add README 添加文件
git commit -m 'first commit'
git remote add origin git@github.com:XXXXX/XXX.git

记住用户名密码
git config --global credential.helper store

git冲突

方法1

git pull 出现冲突后可以暂存本地修改git stash save "savemessage",然后git pull 更新代码,git stash list可查看暂存记录列表,释放本地暂存 git stash apply stash@{0} ,出现冲突文件,找到并解决,然后可以提交git add .加入索引库,然后本地提交git commit -m '注释' 最后git push到远程

方法2:

当执行git pull更新代码时,发现以下错误
error: Your local changes to the following files would be overwritten by merge:application.yml
Please commit your changes or stash them before you merge.
​ 这说明你的application.yml与远程有冲突,你需要先提交本地的修改然后更新。

git add application.yml,然后使用 git commit -m '冲突解决',

提交本地的application.yml文件,不进行推送远程

git pull,更新代码会出现以下错误提示

Auto-merging application.yml
CONFLICT (content): Merge conflict in application.yml
Automatic merge failed; fix conflicts and then commit the result.
更新后你的本地分支上会出现 (develop|MERGING)类似这种标志

找到你本地的application.yml文件,并打开

你会在文件中发现<<<<<<< HEAD ,======= ,>>>>>>> ae9a0f6b7e42fda2ce9b13cfc5344d61

这种标记,<<<<<<< HEAD和=======中间的是你自己的代码, ======= 和>>>>>>>中间的是其他人修改的代码

自己确定保留那一部分代码,最后删除<<<<<<< HEAD ,======= ,>>>>>>>这种标志

重新使用git add application.yml,然后git commit -m '冲突解决结束',再次将本地的application.yml文件提交

解决冲突后,使用git push,将文件推送到远程

posted @ 2021-04-22 11:12  DH余独不觉  阅读(139)  评论(0编辑  收藏  举报