首先可以通过官网下载 https://git-scm.com/downloads
或者安装过Git的可以直接使用git clone https://github.com/git/git 获取最新版本
安装好后
mkdir 目录名(创建版本库)
进入该目录
git init
初始化本地git版本库(创建新仓库)
git config --global user.name "xxx"(注意 中文状态下的双引号)
配置用户名(注意 github 用户名)
git config --global user.email "xxx@xxx.com"(注意 中文状态下的双引号)
配置邮件(注意 github 邮箱)
git config --list
查看当前配置列表
市面上有名的Git托管系统 :
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密钥(按回车确认即可)
4). cd .ssh/切换至ssh目录
5). ls 查看目录下文件
6). cat id_rsa.pub 查看生成的密钥,并复制
7). 打开git@osc开源中国,登录自己的账户.点选个人资料
8). 选择SSH公钥
9). 在添加公钥界面,将刚刚复制好的密钥粘贴进来,再自己取一个该密钥的名字,以便于区分管理
10). 本地新建一个目录,用于拉取远端版本库
11). 使用 git init初始化该目录
12). 使用git remote add origin <SSH地址> 来添加远程版本库
13). 使用git remote -v 来查看远程版本库信息
14). 使用git pull origin marster 来拉取版本库及代码
github 添加SSH key
1). 运行 git Bash 客户端,输入如下代码:$ cd ~/.ssh $ ls 这两个命令就是检查是否已经存在 id_rsa.pub 或 id_dsa.pub 文件,如果文件已经存在,那么你可以跳过步骤2,直接进入步骤3
2). 创建一个 SSH key $ ssh-keygen -t rsa -C "your_email@example.com"
代码参数含义:-t 指定密钥类型,默认是 rsa ,可以省略。-C 设置注释文字,比如邮箱。-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 远程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 文件(或执行 $cat id_rsa.pub ),复制其中全部内容,添加到账户“SSH 公钥”页面 中,公钥名称可以随意起名字。
- 常用命令
修改、提交、删除
git add index.php
# 添加index.php文件到缓存区
git add .
# 添加所有改动过的文件到缓存区
git add --all
# 添加所有文件到缓存区
git commit
# 提交缓存区内的文件(回车后需要键入描述:wq保存退出)
git commit -m "描述"
# 提交缓存区内的文件,并提供描述
git commit -am '描述'
# 将add和commit合为一步
git commit --amend -m 'xxx'
# 合并最后一次提交(用于反复修改)
git rm index.php
# 删除index.php文件
git rm --cached index.php
# 将index.php文件移出缓存区,但不删除( -r * 递归目录)
git rm -f 1.html
# 将缓存区中的1.html文件移出并删除
查看
git status
# 查看当前版本状态(是否修改)
git diff
# 查看所有添加到缓存区的变更(工作区与版本库的区别)
git diff index.php
# 查看工作区文件和库文件区别
git diff --cached
# 查看所有已添加到缓存区,但还未commit的变更(缓存区与版本库的区别)
git log
# 查看提交历史
git log --oneline
# 以简短的方式查看提交日志
git reflog
# 行为日志,显示所有提交,回滚等..
git ls-files
# 显示缓存区的所有文件
回退 与 撤销
git reset --hard HEAD
# 将当前版本重置为HEAD(通常用于merge失败回退)
git reset --hard HEAD^ # 回退上一个版本
git reset --hard HEAD^^ # 回退上两个版本
git reset --hard HEAD~n # 回退上n个版本
git reset --hard <commitid>
# 回退指定版本,commitid根据log获取
git checkout --filename
# 在工作区撤销文件的修改
git checkout HEAD [filename]
# 撤回添加至缓存区的修改,不指定filename则撤回所有
分支操作
git pull origin master
# 获取远程分支master并merge到当前分支
git branch
# 显示本地分支
git branch -a
# 显示所有分支
git checkout 分支名/标签名
# 切换到指定分支或标签
git branch 分支名
# 新建分支
git branch -d 分支名
# 删除本地分支 -D 强制删除
远程协作
git remote add <remote> <url>
# 添加远程版本库
git remote -v
# 查看远程版本库信息
git remote show <remote>
# 查看指定远程版本库信息
git remote remove <remote>
# 删除远程remote链接
git remote rename <old> <new>
# 重命名远程链接名
git pull <remote> <branch>
# 下载代码及快速合并
git push <remote> <branch>
# 上传代码及快速合并
git merge origin master
# 将本地的远端库合并
git fetch origin
# 将远端库获取本地但不合并