git版本管理工具使用
初始化
建立仓库:在选中磁盘下或文件目录下新建文件夹命名为git
mkdir git
cd git
初始化仓库
git init
编写文件或修改代码,其中可以使用vim命令编辑
vi test.txt (打开一个名为test的txt类型文件)
i (插入,可以书写和修改文件内容)
按下Esc键
:wq (即为write and quit)退出
添加暂存区并提交
git add -A,将全部修改过的文件添加至暂存区
git commit -m ‘message’,将暂存区文件提交到分支中,参数message为本次提交内容描述
git log,可以查看提交的日志操作
git diff,可以查看提交内容的冲突部分(即为与上次合并的不同内容)
远程github库
git remote add user git@github.com:user/库名.git,将本地添加到远程github上的git库
git push -u origin master,将本地的修改推送到远程的github主分支上
git pull origin master,如果远程分支有改动的情况下,需要先拉取远程库中的修改合并之后再使用git push推送
关于分支
git branch origin username,创建远程副分支,因为主分支都为master,所以修改内容尽量不要在主分支进行,以避免和其他同伴提交发生冲突和不可逆的修改
git branch username,创建本地分支
git checkout username,切换到副分支,username改为master,即为切换到主分支
git merge master,每次commit之后,都需要merge下,使分支与主分支保持一致,如果发生警告,需要解决冲突,merge前需pull,merge后需push
关于踩坑
git本地仓库与github远程仓库建立连接时,有两个坑:
每次提交都需登陆,此时需要查看下git库使用的是https协议还是ssh协议,使用https协议需要每次进行身份验证,一般情况下都会使用ssh协议,既可以避免重复的身份验证,又会更安全,性能更好
git remote -v,查看使用的是https还是ssh
git remote remove master,如果是https协议想改成ssh协议需要删除原先的库后重建
权限问题:如果git push的时候发生无法推送,绝大部分的原因是权限问题,因为github相当于远程公共仓库,具有一个公共密钥,每台电脑每台分机都有一个私钥,将两个连接起来才可以访问仓库
1、cd .ssh,一般在本地C盘
2、ssh-keygen -t rsa -C “user@github.com”,这里的邮箱为github注册使用的邮箱,rsa生成密钥
3、ls,查看会有两个文件,id_rsa和id_rsa.pub,这两个文件即为私钥和公钥
4、cat id_rsa.pub,查看文件内容,将看到的字符串复制,粘贴到github帐户setting中的SSH and GPG keys中,新建一个key,并粘贴到key中
5、github中设置ssh私钥的key
6、正在使用中的key