首先可以通過官網(wǎng)下載 https://git-scm.com/downloads
或者安裝過Git的可以直接使用git clone https://github.com/git/git 獲取最新版本
安裝好后
mkdir 目錄名(創(chuàng)建版本庫)
進(jìn)入該目錄
git init
初始化本地git版本庫(創(chuàng)建新倉庫)
git config --global user.name "xxx"(注意 中文狀態(tài)下的雙引號)
配置用戶名(注意 github 用戶名)
git config --global user.email "xxx@xxx.com"(注意 中文狀態(tài)下的雙引號)
配置郵件(注意 github 郵箱)
git config --list
查看當(dāng)前配置列表
市面上有名的Git托管系統(tǒng) :
GitHub [https://github.com/]
開源中國 [https://git.oschina.net/]
碼市 [https://Coding.net/]
開源中國 生成SSH密鑰
1). 本地打開git bash ,cd切換到用戶的家目錄
2). 使用pwd來查看目錄是否正確
3). 使用 ssh-keygen.exe -t rsa 來生成SHA256的SSH密鑰(按回車確認(rèn)即可)
4). cd .ssh/切換至ssh目錄
5). ls 查看目錄下文件
6). cat id_rsa.pub 查看生成的密鑰,并復(fù)制
7). 打開git@osc開源中國,登錄自己的賬戶.點選個人資料
8). 選擇SSH公鑰
9). 在添加公鑰界面,將剛剛復(fù)制好的密鑰粘貼進(jìn)來,再自己取一個該密鑰的名字,以便于區(qū)分管理
10). 本地新建一個目錄,用于拉取遠(yuǎn)端版本庫
11). 使用 git init初始化該目錄
12). 使用git remote add origin <SSH地址> 來添加遠(yuǎn)程版本庫
13). 使用git remote -v 來查看遠(yuǎn)程版本庫信息
14). 使用git pull origin marster 來拉取版本庫及代碼
github 添加SSH key
1). 運行 git Bash 客戶端,輸入如下代碼:$ cd ~/.ssh $ ls 這兩個命令就是檢查是否已經(jīng)存在 id_rsa.pub 或 id_dsa.pub 文件,如果文件已經(jīng)存在一罩,那么你可以跳過步驟2撇簿,直接進(jìn)入步驟3
2). 創(chuàng)建一個 SSH key $ ssh-keygen -t rsa -C "your_email@example.com"
代碼參數(shù)含義:-t 指定密鑰類型,默認(rèn)是 rsa 汉嗽,可以省略找蜜。-C 設(shè)置注釋文字,比如郵箱弓叛。-f 指定密鑰文件存儲文件名撰筷。
3). 添加你的 SSH key 到 github上面去$ cat ~/.ssh/id_rsa.pub
4). 測試一下該SSH key 在git Bash 中輸入以下代碼$ ssh -T git@github.com
顯示類似如下,表示成功:Hi username! You've successfully authenticated
5). git clone 遠(yuǎn)程git倉庫地址
coding 添加SSH key
同理也是一樣 文檔地址 https://coding.net/help/doc/git/repository.html
主要步驟git config --list 里面的user.name user.email 要正確
其次 輸入ssh-keygen -t rsa -C “username@example.com”,( 注冊的郵箱),接下來點擊enter鍵即可(也可以輸入密碼)
舉例 "用戶名:密碼@example.com"
在 Coding.net 添加公鑰
本地打開 id_rsa.pub 文件(或執(zhí)行 $cat id_rsa.pub )抬闯,復(fù)制其中全部內(nèi)容溶握,添加到賬戶“SSH 公鑰”頁面 中平委,公鑰名稱可以隨意起名字。
- 常用命令
修改肉微、提交蜡塌、刪除
git add index.php
# 添加index.php文件到緩存區(qū)
git add .
# 添加所有改動過的文件到緩存區(qū)
git add --all
# 添加所有文件到緩存區(qū)
git commit
# 提交緩存區(qū)內(nèi)的文件(回車后需要鍵入描述:wq保存退出)
git commit -m "描述"
# 提交緩存區(qū)內(nèi)的文件,并提供描述
git commit -am '描述'
# 將add和commit合為一步
git commit --amend -m 'xxx'
# 合并最后一次提交(用于反復(fù)修改)
git rm index.php
# 刪除index.php文件
git rm --cached index.php
# 將index.php文件移出緩存區(qū),但不刪除( -r * 遞歸目錄)
git rm -f 1.html
# 將緩存區(qū)中的1.html文件移出并刪除
查看
git status
# 查看當(dāng)前版本狀態(tài)(是否修改)
git diff
# 查看所有添加到緩存區(qū)的變更(工作區(qū)與版本庫的區(qū)別)
git diff index.php
# 查看工作區(qū)文件和庫文件區(qū)別
git diff --cached
# 查看所有已添加到緩存區(qū),但還未commit的變更(緩存區(qū)與版本庫的區(qū)別)
git log
# 查看提交歷史
git log --oneline
# 以簡短的方式查看提交日志
git reflog
# 行為日志,顯示所有提交,回滾等..
git ls-files
# 顯示緩存區(qū)的所有文件
回退 與 撤銷
git reset --hard HEAD
# 將當(dāng)前版本重置為HEAD(通常用于merge失敗回退)
git reset --hard HEAD^ # 回退上一個版本
git reset --hard HEAD^^ # 回退上兩個版本
git reset --hard HEAD~n # 回退上n個版本
git reset --hard <commitid>
# 回退指定版本劳曹,commitid根據(jù)log獲取
git checkout --filename
# 在工作區(qū)撤銷文件的修改
git checkout HEAD [filename]
# 撤回添加至緩存區(qū)的修改,不指定filename則撤回所有
分支操作
git pull origin master
# 獲取遠(yuǎn)程分支master并merge到當(dāng)前分支
git branch
# 顯示本地分支
git branch -a
# 顯示所有分支
git checkout 分支名/標(biāo)簽名
# 切換到指定分支或標(biāo)簽
git branch 分支名
# 新建分支
git branch -d 分支名
# 刪除本地分支 -D 強(qiáng)制刪除
遠(yuǎn)程協(xié)作
git remote add <remote> <url>
# 添加遠(yuǎn)程版本庫
git remote -v
# 查看遠(yuǎn)程版本庫信息
git remote show <remote>
# 查看指定遠(yuǎn)程版本庫信息
git remote remove <remote>
# 刪除遠(yuǎn)程remote鏈接
git remote rename <old> <new>
# 重命名遠(yuǎn)程鏈接名
git pull <remote> <branch>
# 下載代碼及快速合并
git push <remote> <branch>
# 上傳代碼及快速合并
git merge origin master
# 將本地的遠(yuǎn)端庫合并
git fetch origin
# 將遠(yuǎn)端庫獲取本地但不合并