创建
- 创建本地仓库:
git init
- 获取远程仓库:
git clone [url]
例:`git clone https://github.com/you/yourpro.git`
远程
- 添加一个新的 remote 远程仓库:
git remote add [remote-name] [url]
例:git remote add origin https://github.com/you/yourpro.git
,origin:相当于该远程仓库的别名
- 列出所有 remote 的别名:
git remote
- 列出所有 remote 的 url:
git remote -v
- 删除一个 remote:
git remote rm [name]
- 重命名 remote:
git remote rename [old-name] [new-name]
- 修改远程仓库地址:
- 直接修改
git remote set-url origin [url]
例如:`git remote set-url origin https://github.com/you/yourpro.git`
- 先删后加
git remote rm origin
git remote add origin [url]
提交
- 从本地仓库中添加新的文件:
git add . // 添加所有文件
git add file.txt // 添加指定文件
- 从本地仓库中删除:
git rm file.txt // 从版本库中移除,删除文件
git rm file.txt -cached // 从版本库中移除,不删除原始文件
git rm -r xxx // 从版本库中删除指定文件夹
- 提交,把内容提交到 HEAD 里:
git commit -m "注释"
- 撤销:
git revert HEAD // 撤销最近的一个提交
git reset --mixed // 取消 commit + add
git reset --soft // 取消 commit
git reset --hard // 取消 commit + add + local working
- 把本地提交 push 到远程服务器:
git push [remote-name] [loca-branch]:[remote-branch]
例:git push origin master:master
更新代码
- 查看状态:
git status
- 从远程库中下载新的改动-方式1:
git fetch [remote-name]/[branch]
- 从远程库中下载新的改动-方式2:
git pull [remote-name] [branch]
例:`git pull origin master`
pull = fetch + merge
- 合并下载的改动到分支-方式1:
git merge [remote-name]/[branch]
解决冲突...
git add .
git commit -m'fix conflict'
- 合并下载的改动到分支-方式2:
git rebase [remote-name]/[branch]
解决冲突...
git add .
git rebase --continue
分支
// 列出分支
git branch
// 创建一个新的分支
git branch (branch-name)
// 删除一个分支
git branch -d (branch-nam)
// 删除 remote 的分支
git push (remote-name) :(remote-branch)
// 切换到一个分支
git checkout [branch-name]
// 创建并切换到该分支
git checkout -b [branch-name]
与github建立ssh通信,让Git操作免去输入密码的繁琐
- 首先呢,我们先建立ssh密匙。
ssh key must begin with 'ssh-ed25519', 'ssh-rsa', 'ssh-dss', 'ecdsa-sha2-nistp256', 'ecdsa-sha2-nistp384', or 'ecdsa-sha2-nistp521'. -- from github
根据以上文段我们可以知道github所支持的ssh密匙类型,这里我们创建ssh-rsa密匙。
- 在command line 中输入以下指令:
ssh-keygen -t rsa
去创建一个ssh-rsa密匙。如果你并不需要为你的密匙创建密码和修改名字,那么就一路回车就OK,如果你需要,请您自行Google翻译,因为只是英文问题。
$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/Liang Guan Quan/.ssh/id_rsa)
您可以根据括号中的路径来判断你的.ssh文件放在了什么地方
- 到 https://github.com/settings/keys 这个地址中去添加一个新的SSH key,然后把你的xx.pub文件下的内容文本都复制到Key文本域中,然后就可以提交了。
- 添加完成之后 我们用
ssh git@github.com
命令来连通一下github,如果你在response里面看到了你github账号名,那么就说明配置成功了。 let's enjoy github ;)
gitignore
在本地仓库根目录创建 .gitignore 文件。Win7 下不能直接创建,可以创建 ".gitignore." 文件,后面的标点自动被忽略;
/.idea // 过滤指定文件夹
/fd/* // 忽略根目录下的 /fd/ 目录的全部内容
*.iml // 过滤指定的所有文件
!.gitignore // 不忽略该文件
网友评论