- 安装Git应用
Windows系统:Git for Windows,下载并安装,所有选项使用默认。
类Unix系统:Git for Linux/Unix。 - 生成密钥
之所以需要生成密钥,是因为后期所有与Git服务器的交互都会使用公钥来进行免密码登陆,这样既便捷又安全。Git本身支持多种协议,http协议、git协议、ssh协议等,我们这里将使用ssh协议。
Windows系统下打开Git Bash终端(可以在右击菜单中找到),类Unix系统下打开终端,输入
ssh-keygen -f yourname // yourname 推荐使用邮箱名去掉后缀,比如yxu@xxx.com,yourname就是yxu
出现提示的时候按回车就可以。这样就会在你的用户目录下(Windows系统是:C:\Users\当前用户名.ssh,类Unix系统是:/home/当前用户名/.ssh)生成yourname.pub公钥和yourname私钥。由于可可能会有多个公钥和私钥对,因此我们需要配置用于连接Git服务器的公钥和私钥对。在.ssh目录下新建config文件:
host hostname // hostname可以任意指定,比如yxu
user git // 远程Git服务器的用户名
hostname 192.168.1.95 // 远程Git服务器的IP地址
port 22 // SSH协议默认使用端口
identityfile C:\Users\当前用户名\.ssh\yxu //公钥存放位置
最后需要将yourname.pub文件通过邮件发送给Git服务器的管理人员。
- 初始化Git参数
Git是可以通过键值对的形式进行配置的,对应的指令是git config
,有三种形式:
git config --system // 全局参数设置,范围最广,优先级最低
git config --global // 全局参数设置,范围次广, 优先级中等
git config // 当前仓库参数设置,范围最小,优先级最高
Windows下的参数设置:
git config --global user.name yourname // 替换yourname
git config --global user.email yourname@xxx.com
git config --global push.default simple
git config --global core.autocrlf true
类Unix下的参数设置:
git config --global user.name yourname // 替换yourname
git config --global user.email yourname@xxx.com
git config --global push.default simple
git config --global core.autocrlf input
git config --global core.editor vim
- 同步远程仓库
假设已经将公钥提交给管理员,且管理员已经开通了用户对远程版本库remote-repository(根据实际项目命名)的操作权限。
a. 开发新项目
git clone hostname: remote-repository // hostname是之前config配置文件中的名称
然后进入本地仓库remote-repository开发新项目。
b. 无本地仓库,但已有源文件
由于有些文件是不需要最终加入到仓库中去的,比如编译出来的中间文件,因此需要在本地新建一个.gitignore文件,在这里面过滤不需要加入到仓库的文件,具体规则请自行查阅(诸如visual studio等工程的.gitignore文件在github或stackoverflow中有很多推荐)。下面的指令是新建本地仓库,并同步到远程仓库:
git init // 初始化仓库
git add -A // 将所有文件添加到暂存区
git commit -m "first commit" // 提交到仓库,-m指令是添加本次提交的说明
git remote add origin host:remote-repository // 远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,host是之前config文件中的名称
git push -u origin master
// origin就是上一步的名称,master是需要提交到远程库的本地分支,-u使用来关联本地分支和远程库中对应的分支,以后提交就不需要该参数了
c. 已有本地仓库
git remote add origin hostname: remote-repository
git push -u origin master
- 创建分支
Git的主分支默认名字是master,无论如何都应该保证主分支的提交一定是经过仔细检查并测试的。一般拿到一个新的需求时,需要新建一个dev分支,然后在该分支上进行开发,当开发完毕的时候再将dev分支的内容合并到主分支。新建分支的命令如下:
//确认当前在master分支,可以使用git branch命令查看。*号标注的就是当前所在分支,
git branch dev // 新建分支
git checkout dev // 切换到dev分支