
* Workspace:工作區
* Index / Stage:暫存區
* Repository:倉庫區(或本地倉庫)
* Remote:遠程倉庫
~~~bash
# 在當前目錄新建一個Git代碼庫
$ git init
# 新建一個目錄,將其初始化為Git代碼庫 project-name目錄/項目 名
$ git init [project-name]
# 下載一個項目和它的整個代碼歷史 url下載/克隆 地址
$ git clone [url]
~~~
## 二、配置
Git的設置文件為`.gitconfig`,它可以在用戶主目錄下(全局配置),也可以在項目目錄下(項目配置)。
> ~~~bash
>
> # 顯示當前的Git配置
> $ git config --list
>
> # 編輯Git配置文件 --global 添加上則表示全局
> $ git config -e [--global]
>
> # 設置提交代碼時的用戶信息
> $ git config [--global] user.name "[name]"
> $ git config [--global] user.email "[email address]"
> ~~~
> //查
> git config --global --list
> git config --global user.name
> //增
> git config --global --add user.name jianan
> //刪
> git config --global --unset user.name
> //改
## 三、增加/刪除文件
> ~~~bash
>
> # 添加指定文件到暫存區
> $ git add [file1] [file2] ...
>
> # 添加指定目錄到暫存區,包括子目錄
> $ git add [dir]
>
> # 添加當前目錄的所有文件到暫存區
> $ git add .
>
> # 添加每個變化前,都會要求確認
> # 對于同一個文件的多處變化,可以實現分次提交
> $ git add -p
>
> # 刪除工作區文件,并且將這次刪除放入暫存區
> $ git rm [file1] [file2] ...
>
> # 停止追蹤指定文件,但該文件會保留在工作區
> $ git rm --cached [file]
>
> # 改名文件,并且將這個改名放入暫存區
> $ git mv [file-original] [file-renamed]
> ~~~
## 四、代碼提交
> ~~~bash
>
> # 提交暫存區到倉庫區
> $ git commit -m [message]
>
> # 提交暫存區的指定文件到倉庫區
> $ git commit [file1] [file2] ... -m [message]
>
> # 提交工作區自上次commit之后的變化,直接到倉庫區
> $ git commit -a
>
> # 提交時顯示所有diff信息
> $ git commit -v
>
> # 使用一次新的commit,替代上一次提交
> # 如果代碼沒有任何新變化,則用來改寫上一次commit的提交信息
> $ git commit --amend -m [message]
>
> # 重做上一次commit,并包括指定文件的新變化
> $ git commit --amend [file1] [file2] ...
>
> ~~~
## 五、分支
> ~~~bash
>
> # 列出所有本地分支
> $ git branch
>
> # 列出所有遠程分支
> $ git branch -r
>
> # 列出所有本地分支和遠程分支
> $ git branch -a
>
> # 新建一個分支,但依然停留在當前分支
> $ git branch [branch-name]
>
> # 新建一個分支,并切換到該分支
> $ git checkout -b [branch]
>
> # 新建一個分支,指向指定commit
> $ git branch [branch] [commit]
>
> # 新建一個分支,與指定的遠程分支建立追蹤關系
> $ git branch --track [branch] [remote-branch]
>
> # 切換到指定分支,并更新工作區
> $ git checkout [branch-name]
>
> # 切換到上一個分支
> $ git checkout -
>
> # 建立追蹤關系,在現有分支與指定的遠程分支之間
> $ git branch --set-upstream [branch] [remote-branch]
>
> # 合并指定分支到當前分支
> $ git merge [branch]
>
> # 選擇一個commit,合并進當前分支
> $ git cherry-pick [commit]
>
> # 刪除分支
> $ git branch -d [branch-name]
>
> # 刪除遠程分支
> $ git push origin --delete [branch-name]
> $ git branch -dr [remote/branch]
>
> ~~~
## 六、標簽
> ~~~bash
>
> # 列出所有tag
> $ git tag
>
> # 新建一個tag在當前commit
> $ git tag [tag]
>
> # 新建一個tag在指定commit
> $ git tag [tag] [commit]
>
> # 刪除本地tag
> $ git tag -d [tag]
>
> # 刪除遠程tag
> $ git push origin :refs/tags/[tagName]
>
> # 查看tag信息
> $ git show [tag]
>
> # 提交指定tag
> $ git push [remote] [tag]
>
> # 提交所有tag
> $ git push [remote] --tags
>
> # 新建一個分支,指向某個tag
> $ git checkout -b [branch] [tag]
>
> ~~~
## 七、查看信息
> ~~~bash
>
> # 顯示有變更的文件
> $ git status
>
> # 顯示當前分支的版本歷史
> $ git log
>
> # 顯示commit歷史,以及每次commit發生變更的文件
> $ git log --stat
>
> # 搜索提交歷史,根據關鍵詞
> $ git log -S [keyword]
>
> # 顯示某個commit之后的所有變動,每個commit占據一行
> $ git log [tag] HEAD --pretty=format:%s
>
> # 顯示某個commit之后的所有變動,其"提交說明"必須符合搜索條件
> $ git log [tag] HEAD --grep feature
>
> # 顯示某個文件的版本歷史,包括文件改名
> $ git log --follow [file]
> $ git whatchanged [file]
>
> # 顯示指定文件相關的每一次diff
> $ git log -p [file]
>
> # 顯示過去5次提交
> $ git log -5 --pretty --oneline
>
> # 顯示所有提交過的用戶,按提交次數排序
> $ git shortlog -sn
>
> # 顯示指定文件是什么人在什么時間修改過
> $ git blame [file]
>
> # 顯示暫存區和工作區的差異
> $ git diff
>
> # 顯示暫存區和上一個commit的差異
> $ git diff --cached [file]
>
> # 顯示工作區與當前分支最新commit之間的差異
> $ git diff HEAD
>
> # 顯示兩次提交之間的差異
> $ git diff [first-branch]...[second-branch]
>
> # 顯示今天你寫了多少行代碼
> $ git diff --shortstat "@{0 day ago}"
>
> # 顯示某次提交的元數據和內容變化
> $ git show [commit]
>
> # 顯示某次提交發生變化的文件
> $ git show --name-only [commit]
>
> # 顯示某次提交時,某個文件的內容
> $ git show [commit]:[filename]
>
> # 顯示當前分支的最近幾次提交
> $ git reflog
>
> ~~~
## 八、遠程同步
> ~~~bash
>
> # 下載遠程倉庫的所有變動
> $ git fetch [remote]
>
> # 顯示所有遠程倉庫
> $ git remote -v
>
> # 顯示某個遠程倉庫的信息
> $ git remote show [remote]
>
> # 增加一個新的遠程倉庫,并命名
> $ git remote add [shortname] [url]
>
> # 取回遠程倉庫的變化,并與本地分支合并
> $ git pull [remote] [branch]
>
> # 上傳本地指定分支到遠程倉庫
> $ git push [remote] [branch]
>
> # 強行推送當前分支到遠程倉庫,即使有沖突
> $ git push [remote] --force
>
> # 推送所有分支到遠程倉庫
> $ git push [remote] --all
>
> ~~~
## 九、撤銷
> ~~~bash
>
> # 恢復暫存區的指定文件到工作區
> $ git checkout [file]
>
> # 恢復某個commit的指定文件到暫存區和工作區
> $ git checkout [commit] [file]
>
> # 恢復暫存區的所有文件到工作區
> $ git checkout .
>
> # 重置暫存區的指定文件,與上一次commit保持一致,但工作區不變
> $ git reset [file]
>
> # 重置暫存區與工作區,與上一次commit保持一致
> $ git reset --hard
>
> # 重置當前分支的指針為指定commit,同時重置暫存區,但工作區不變
> $ git reset [commit]
>
> # 重置當前分支的HEAD為指定commit,同時重置暫存區和工作區,與指定commit一致
> $ git reset --hard [commit]
>
> # 重置當前HEAD為指定commit,但保持暫存區和工作區不變
> $ git reset --keep [commit]
>
> # 新建一個commit,用來撤銷指定commit
> # 后者的所有變化都將被前者抵消,并且應用到當前分支
> $ git revert [commit]
>
> # 暫時將未提交的變化移除,稍后再移入
> $ git stash
> $ git stash pop
>
> ~~~
## 十、其他
> ~~~bash
>
> # 生成一個可供發布的壓縮包
> $ git archive
> ~~~
- 文檔說明
- 開始
- linux
- 常用命令
- ps -ef
- lsof
- netstat
- 解壓縮
- 復制
- 權限
- 其他
- lnmp集成安裝
- supervisor
- 安裝
- supervisor進程管理
- nginx
- 域名映射
- 負載均衡配置
- lnmp集成環境安裝
- nginx源碼安裝
- location匹配
- 限流配置
- 日志配置
- 重定向配置
- 壓縮策略
- nginx 正/反向代理
- HTTPS配置
- mysql
- navicat創建索引
- 設置外網鏈接mysql
- navicat破解
- sql語句學習
- 新建mysql用戶并賦予權限
- php
- opcache
- 設計模式
- 在CentOS下安裝crontab服務
- composer
- 基礎
- 常用的包
- guzzle
- 二維碼
- 公共方法
- 敏感詞過濾
- IP訪問頻次限制
- CURL
- 支付
- 常用遞歸
- 數據排序
- 圖片相關操作
- 權重分配
- 毫秒時間戳
- base64<=>圖片
- 身份證號分析
- 手機號相關操作
- 項目搭建 公共處理函數
- JWT
- 系統函數
- json_encode / json_decode 相關
- 數字計算
- 數組排序
- php8
- jit特性
- php8源碼編譯安裝
- laravel框架
- 常用artisan命令
- 常用查詢
- 模型關聯
- 創建公共方法
- 圖片上傳
- 中間件
- 路由配置
- jwt
- 隊列
- 定時任務
- 日志模塊
- laravel+swoole基本使用
- 拓展庫
- 請求接口log
- laravel_octane
- 微信開發
- token配置驗證
- easywechart 獲取用戶信息
- 三方包
- webman
- win下熱更新代碼
- 使用laravel db listen 監聽sql語句
- guzzle
- 使用workman的httpCLient
- 修改隊列后代碼不生效
- workman
- 安裝與使用
- websocket
- eleticsearch
- php-es 安裝配置
- hyperf
- 熱更新
- 安裝報錯
- swoole
- 安裝
- win安裝swoole-cli
- google登錄
- golang
- 文檔地址
- 標準庫
- time
- 數據類型
- 基本數據類型
- 復合數據類型
- 協程&管道
- 協程基本使用
- 讀寫鎖 RWMutex
- 互斥鎖Mutex
- 管道的基本使用
- 管道select多路復用
- 協程加管道
- beego
- gin
- 安裝
- 熱更新
- 路由
- 中間件
- 控制器
- 模型
- 配置文件/conf
- gorm
- 初始化
- 控制器 模型查詢封裝
- 添加
- 修改
- 刪除
- 聯表查詢
- 環境搭建
- Windows
- linux
- 全局異常捕捉
- javascript
- 常用函數
- vue
- vue-cli
- 生產環境 開發環境配置
- 組件通信
- 組件之間通信
- 父傳子
- 子傳父
- provide->inject (非父子)
- 引用元素和組件
- vue-原始寫法
- template基本用法
- vue3+ts項目搭建
- vue3引入element-plus
- axios 封裝網絡請求
- computed 計算屬性
- watch 監聽
- 使用@符 代替文件引入路徑
- vue開發中常用的插件
- vue 富文本編輯
- nuxt
- 學習筆記
- 新建項目踩坑整理
- css
- flex布局
- flex PC端基本布局
- flex 移動端基本布局
- 常用css屬性
- 盒子模型與定位
- 小說分屏顯示
- git
- 基本命令
- fetch
- 常用命令
- 每次都需要驗證
- git pull 有沖突時
- .gitignore 修改后不生效
- 原理解析
- tcp與udp詳解
- TCP三次握手四次揮手
- 緩存雪崩 穿透 更新詳解
- 內存泄漏-內存溢出
- php_fpm fast_cgi cig
- redis
- 相關三方文章
- API對外接口文檔示范
- elaticsearch
- 全文檢索
- 簡介
- 安裝
- kibana
- 核心概念 索引 映射 文檔
- 高級查詢 Query DSL
- 索引原理
- 分詞器
- 過濾查詢
- 聚合查詢
- 整合應用
- 集群
- docker
- docker 簡介
- docker 安裝
- docker 常用命令
- image 鏡像命令
- Contrainer 容器命令
- docker-compose
- redis 相關
- 客戶端安裝
- Linux 環境下安裝
- uni
- http請求封裝
- ios打包
- 視頻縱向播放
- 日記
- 工作日記
- 情感日志
- 壓測
- ab
- ui
- thorui
- 開發規范
- 前端
- 后端
- 狀態碼
- 開發小組未來規劃