原来我们早就会了git管理

git拉码/上传

先说一句
  掘友们好,这里是沉曦!一个前端的小学生。
  

通过Git工具上传到托管平台(gitee/github)

1.创建在托管平台上创建远程仓库,并保留地址

2.进入到项目文件夹,通过命令 git init 目录初始化,提交到本地git仓库,会生成一个.git文件夹

git init
复制代码
  1. 将需要提交的文件,提交到暂存区 (git add index.js =提交index文件, git add .=提交目录下的所有文件)
  git add . 
复制代码
  1. 检查状态(绿色=提交成功)
git status 
复制代码
  1. 用命令 git commit告诉git,把文件提交到暂存区。引号内为提交说明
git commit -m '第一次提交'
复制代码
  1. 关联到远程库
git remote add origin[仓库地址]
复制代码
  1. 提交到远程仓库
git push add origin
复制代码

通过Git工具从托管平台上拉码(gitee/github)

方法1 – 克隆(Clone)源代码到本地

克隆之后会把源代码下载到本地,创建一个本地的代码库,可以任意在本地修改代码并使用git所提供的命令操作代码,有代码对应的历史记录和分支。

git clone [仓库地址]
复制代码

方法2 – 下载源代码Zip包

最后通过 npm i 还原依赖, npm run xxx 即可运行代码

基本命令大全

# 配置个人信息
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"

# 切换目录初始化
$ git init

# 文件添加到仓库
$ git add -p <file>

# 把文件提交到仓库
$ git commit -m "add LICENSE"

# 查看仓库当前状态
$ git status

# 查看difference
$ git diff

# 显示从最近到最远的提交日志
$ git log --pretty=oneline # 格式化输出信息

# 版本退回
$ git reset --hard HEAD^ # 当前版本HEAD,上一个版本HEAD^,上上个版本HEAD^^
$ git reset --hard 130f10a # 或HEAD~100

# 查看命令记录
$ git reflog

# 丢弃工作区的修改,回到最近一次git commit或git add时的状态:
$ git checkout -- README.md

# 把暂存区的修改撤销掉(unstage)
$ git reset HEAD READER.md

# 从版本库中删除该文件
$ git rm README.md
$ git commit -m "remove READER.md"

# 把误删的文件恢复到最新版本,checkout其实用版本库里的版本替换工作区的版本
$ git checkout -- README.md
复制代码

远程仓库

$ ssh-keygen -t rsa -C "youremail@example.com"
# 测试是否成功
$ ssh -T git@github.com

# 把一个已有的本地仓库与之关联
$ git remote add origin git@github.com:Windrivder/Windrivder.git

# 把本地库的所有内容推送到远程库上(推送master分支的内容)
$ git push -u origin master

# 向远程库推送更新
$ git push origin master

# 从远程库克隆
$ git clone git@github.com:michaelliao/gitskills.git
复制代码

分支管理

# 创建+切换dev分支
$ git checkout -b dev

# 相当于
$ git branch dev # 创建分支
$ git checkout dev

# 查看当前分支,当前分支前面标有×号
$ git branch

# 切换回master分支
$ git checkout master

# 合并指定分支到当前分支
$ git merge dev

# 删除dev分支
$ git branch -d dev

# 查看分支合并情况
$ git log --graph --pretty=oneline --abbrev-commit
*   59bc1cb conflict fixed
|\
| * 75a857c AND simple
* | 400b400 & simple
|/
* fec145a branch test

# 删除feature1分支
$ git branch -d feature1

# 创建并切换dev分支
$ git checkout -b dev

# 修改readme.txt文件,并提交一个新的commit
$ git add readme.txt
$ git commit -m "add merge"

# 切换回master
$ git checkout master

# 合并dev分支,请注意--no-ff参数,表示禁用Fast forward
$ git merge --no-ff -m "merge with no-ff" dev

# 看看分支历史
$ git log --graph --pretty=oneline --abbrev-commit
*   7825a50 merge with no-ff
|\
| * 6224937 add merge
|/
*   59bc1cb conflict fixed

# 如果需要临时修复Bug,可以把当前工作现场“储藏”起来,等Bug修复后恢复现场后继续工作
$ git stash

# 此时查看工作区是干净
# 切换到需要修复Bug的分支,创建临时分支来修复
$ git checkout master
$ git checkout -b issue-101

# 修复完成后切换到master分支,完成合并,删除临时分支
$ git checkout master
$ git merge --no-ff -m "merged bug fix 101" issue-101
$ git branch -d issue-101

# Bug修复后,切换回dev分支继续干活
$ git checkout dev

# 查看工作现场列表
$ git stash list

# 恢复工作现场
$ git stash pop # 恢复的同时把stash内容也删了
$ git stash apply # 恢复,不删除stash的内容,使用git stash drop

# 再次查看工作现场列表,干净
$ git stash list

# 可以多次stash,恢复时指定恢复
$ git stash apply stash@{0}

# 强行删除一个没有合并过的分支
$ git branch -D <name>

# 要查看远程库的信息
$ git remote
$ git remote -v

# 推送其他分支
$ git push origin dev

# 从远程库clone,默认情况只能看到master分支,需要在dev分支,必须创建远程origin的dev分支到本地
$ git checkout -b dev origin/dev
$ git checkout -b branch-name origin/branch-name
$ git branch --set-upstream branch-name origin/branch-name # 关联

# 向远程库推送dev有冲突
$ git pull # 抓取到本地合并解决冲突,再向远程推送
$ git push origin dev
复制代码

搭建 Git 服务器

  1. 安装 git:
$ sudo apt-get install git
复制代码
  1. 创建一个 git 用户,用来运行 git 服务:
$ sudo adduser git
复制代码
  1. 创建证书登录:收集所有需要登录的用户的公钥,就是他们自己的 id_rsa.pub 文件,把所有公钥导入到 /home/git/.ssh/authorized_keys 文件里,一行一个

  2. 初始化 Git 仓库:

# 选定一个目录作为 Git 仓库,假定是 /srv/sample.git,在 /srv 目录下输入命令

$ sudo git init --bare sample.git
# 把 owner 改为 git
$ sudo chown -R git:git sample.git
复制代码
  1. 禁用 shell 登录:
# 编辑/etc/passwd文件
git:x:1001:1001:,,,:/home/git:/bin/bash # 修改成下面的内容
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell
复制代码
  1. 克隆远程仓库,在各自的电脑上运行:
$ git clone git@server:/srv/sample.git
复制代码

最后一句

这是沉曦的学习心得!若有不正,还望斧正。希望掘友们不要吝啬对我的建议哦,回见。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享