git常用指令
版本控制
CVS
VSS ---- > 锁定模式
SVN -----> 合并模式
集中控制的版本系统 -----> 必须连接中央服务器
BitKeeper
2005 - Git -----> 分布式版本控制系统
1.在本机创建git仓库先创建一个空的文件夹:aaa,从shell通过cd指令进入到新建的空的文件夹aaa中;然后执行git init指令将文件夹aaa变成git仓库
创建成功后会多出一个.git隐藏文件夹,不能动
注意:git仓库中不能再创建其他git仓库
1.基本指令
git init
—— 新建git仓库
git add 文件/文件夹
—— 将文件添加到缓存区中
git add -A
— 添加所有内容到缓存区中
git status
——— 查看git状态
git commit -m ‘提交信息’
—— 将缓存区中的内容全部提交到git本地仓库中
git remote show origin
--显示远程仓库origin里的资源
git push origin master:hb-dev
--将本地库与服务器上的库进行关联
git remote show
- 查看远程库
git rm [file name]
--删除一个文件
git diff
--查看尚存暂存的更新
git rm a.a
-移除文件(从暂存区和工作区中删除)
git rm --cached a.a
---- 移除文件(只从暂存区中删除)
git log
——- 查看提交日志
git reset --hard
版本代码 回退版本
git reset -- hard HEAD
—— 让工作目录中的内容和仓库中的内容保持一致
git reset --hard HEAD^
—— 回到上一个版本
git reset -- hard 版本号
—— 回到指定的版本
git reflog
– 查看版本控制(未来)
git checkout 文件名
git restore 文件名 —— 从暂存区中恢复工作目录中的内容(让工作区中的指定文件,回到上次提交的时候的状态)
git clone <url>
- 将服务器上的项目(仓库)克隆 (使用https地址需要输入密码,使用ssh地址需要添加公钥)
2) 远程关联仓库相关命令
git remote -v
------查看远程仓库
git remote rm [name]
----- 删除远程仓库
git remote add origin 地址
----- 添加,关联远程仓库(只需要关联一次)
git remote set -url --push [name][newUrl]
----修改远程仓库
git push [-u] origin master
----- 提交(-u在第一次提交分支的时候才用)
git push
— 将本地仓库的内容提交到远程仓库master分支上
git push origin 分支名
— 将本地仓库的内容提交到远程仓库对应的分支上, 如果分支不存在会自动创建
git pull
— 将远程仓库中的内容更新到本地仓库和工作区中
**eg:**如果想把本地的某个分支test提交到远程仓库,并作为远程仓库的master分支,或者名叫test的分支,如下:
$git push origin test : master // 提交本地test分支作为远程的master分支
$git push origin test : test // 提交本地test分支作为远程的test分支
3) 版本(tag)相关操作命令
git tag
- 查看版本
git tag [name]
- 创建版本
git tag -r
- 查看远程版本
git pull origin --tag
- 合并远程仓库得tag到本地
git push origin --tag
上传本地的tag到远程仓库
2.分之管理
创建仓库会默认给我们创建一个master分之,这个分之一般作为提交和发布分之;开发一般会自己创建一个develop分之,用来开发和测试;多人协作的时候还可能根据不同的人或者(不同的功能)创建不同的分之,用来独立开发
常见分之: master(主要是合并develop), develop(主要合并下面的其他分支), 功能/人员分之(开发)
git branch [-a]
- 查看分之
git branch -r
- 查看远程分支
git branch 分之名
- 创建分之
git checkout 分支名
- 切换分之
git checkout -b 分之名
- 切换并创建新的分之
git branch -d 分支名
- 删除分支 ,–d 选项只能删除已经参与 了合并的分支,未合并的分支是无法删除 的,如果想强制删除一个分支,可以 使用 -D 选项
git diff 分之1 分之2
- 查看两个分之之间的差异
git merge 分之名
- 让当前分之和指定分之进行合并
git push oringin [name]
- 创建远程分支(本地分支push到远程)
注意: 切换分之、push、pull,这些操作前要保证工作区是clean
怎么避免冲突: 不要发生多个分之对同一个文件在同一个版本下进行修改(和同伴确认和商量)
配置SSH免密
打开用户主目录,进入到.ssh
文件夹中,
生成密钥文件(密钥对) ssh-keygen
或者 ssh-keygen -t rsa -b 2048 -C "youremail"
cat ~/.ssh/id_rsa.pub
----> 将公钥复制下来部署到需要设置免密登/
- 参照网上做法安装homebrew工具(macOS包管理工具)
- brew install mysql-connector-c
- echo
$PATH /usr/local/mysql/bin ---> PATH ---> mysql_config
sudo vim /usr/local/mysql/bin/mysql_config
搜索 —> libs
libs="$libs -lmysqlclient"
- pip3 install mysqlclient