热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

git常用命令和github上传

Git版本控制器一、Git简介

Git 版本控制器

一、 Git 简介

什么是git?

Git是目前世界上最先进的分布式版本控制系统(没有之一)。

Git的诞生

​ Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?

​ 事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!

​ 到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。

​ 安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。

Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!

二、Git的使用

1. 创建版本库

git init

瞬间Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),细心的读者可以发现当前目录下多了一个.git的目录,这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。

2. 配置当前版本库的信息

```git config --global user.name ‘xxx’` ``

git config --global user.email 'xxx@qq.com'

3. 添加文件

git add

git add 1.html 添加1.html
git add . .添加修改文件到仓库
git add -all -all 添加所有文件

4. 提交文件

git commit

$ git commit -m '修改了冲突'
-m 提交的信息

4.1 查看冲突

git diff

5 . 查看git状态

git status

6. 版本控制

git reset

版本操作

跳到当前版本 git reset --hard HEAD
跳到上一版本 git reset --hard HEAD^
跳到上上版本 git reset --hard HEAD^^
跳到指定版本 git reset --hard commit_id

看提交历史

git log 查看当前历史

git log --pretty=oneline 只输出一行

git reflog 查询所有提交历史

git reflog 以便确定要回到未来的哪个版本

7. 撤销修改

git checkout -- file_name

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file_name。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令
git reset HEAD file_name,就回到了场景1,第二步按场景1操作

8 . 删除文件

2.git rm readme.txt
git add .
git commit -m “delete readme.txt"

撤销办法:
找回删除文件(版本会退):使用 git reset —hard HEAD^

9. 分支管理

查看分支:git branch
创建分支:git branch
切换分支:git checkout
创建+切换分支:git checkout -b
合并某分支到当前分支:git merge
删除分支:git branch -d

10. 远程仓库

关联远程仓库 remote

git remote add origin https://github.com/lamp402213226/php110.git

推送代码到仓库 push

git push -u origin master 将代码推送到master分支上

git push -u origin master:master 将本地的master分支上的代码推送到服务器上的master分支上

git push -u origin master:master -f
-f 强制推送 一般不要使用

拉取 pull

git pull origin master 拉取服务器上的版本

获分支新的的版本 fetch

git fetch

克隆版本库 clone

git clone https://github.com/lamp402213226/test.git

三、团队协作

场景应用

1. 组长

1. 在项目中初始化仓库 git init
2. 配置git的用户名 和 邮箱 git config ..
注意配置自己的邮箱 权限问题
*** 将自己的组员 添加到项目的协作者
3. 添加并且提交到本地的版本库 git commit
4. 添加本地的和远程仓库的关联
git remote add origin https://github.com/lamp402213226/object1.git
5.推送
git push -u origin master:master
-u 声明提交的用户 一般第一次提交的时候使用

2. 组员

1. 进行克隆
2. 配置版本库的用户名和邮箱
3. 添加新的分支
推送 git push origin lisi:lisi

3. 合并分支

1. 查看当前的分支 git fetch
2. 合并 git merge origin/xxxx
注意:合并要查看当前的工作区和版本库是否一致 git status

  1. 初始化
    git init

  2. 配置当前版本库的信息
    git config --global user.name ‘xxx’`
    git config --global user.email ‘xxx@qq.com’

  3. 添加文件
    git add 1.html 添加1.html
    git add . .添加修改文件到仓库
    git add -all -all 添加所有文件

  4. 查看当前状态
    git status

  5. 版本控制

    git log --pretty=oneline 查看当前的提交记录
    git reflog --pretty=oneline 查看所有的历史提交记录
    git reset --hard a41ee47 设置指针 指向某一个版本
    跳到当前版本 git reset --hard HEAD
    跳到上一版本 git reset --hard HEAD^
    跳到上上版本 git reset --hard HEAD^^
    跳到指定版本 git reset --hard commit_id

  6. 撤销修改

    git checkout – file_name

    场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout – file_name。
    场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令
    git reset HEAD file_name,就回到了场景1,第二步按场景1操作

  7. 删除文件

    2.git rm readme.txt
    git add .
    git commit -m “delete readme.txt"

    撤销办法:
    找回删除文件(版本会退):使用 git reset —hard HEAD^

  8. 分支git

    查看分支:git branch
    创建分支:git branch
    切换分支:git checkout
    创建+切换分支:git checkout -b
    合并某分支到当前分支:git merge
    删除分支:git branch -d

  9. 关联远程仓库

    git remote add origin https://github.com/lamp402213226/php110.git

    推送代码
    将本地的master分支上的代码推送到服务器上的master分支上
    git push -u origin master:master
    强制推送
    git push -u origin master:master -f
    -f 强制推送 一般不要使用

  10. 团队配合

    组长
    # 下载框架 composer create-project --prefer-dist laravel/laravel blog
    1. 在项目中初始化仓库 git init
    2. 配置git的用户名 和 邮箱 git config …
    注意配置自己的邮箱 权限问题
    ***
    将自己的组员 添加到项目的协作者
    ***
    3. 添加并且提交到本地的版本库 git add . git commit
    4. 添加本地的和远程仓库的关联
    git remote add origin https://github.com/lamp402213226/object1.git
    5.推送
    git push -u origin master:master
    -u 声明提交的用户 一般第一次提交的时候使用

    组员
    1. 进行克隆 git clone https://github.com/lamp402213226/object1.git
    composer install
    cp .env.example .env
    php artisan key:generate

    2. 配置版本库的用户名和邮箱

    3. 添加新的分支
    推送 git push origin lisi:lisi


推荐阅读
author-avatar
mobiledu2502880517
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有