Git/GitHub基本操作
Git是分布式版本控制工具,SVN是集中式版本控制,有单点故障的问题
GitHub是Git的代码托管中心,类似的国内有码云,是远程维护库
Git的优势
大部分操作在本地完成,不需要联网
完整性有保证
尽可能添加数据而不是删除或修改数据
分支操作非常流畅
与linux命令全面兼容
基本操作
1.查看工作区,暂存区状态
git status
2.添加操作,将新建或修改添加到暂存区
git add [file name]
3.提交操作,将暂存区的内容提交到本地库
git commit -m "commit message" [file name]
4.查看历史操作记录
git log全显示,翻页方式和vim一样
git log --pretty=oneline 每条日志以一行显示
git log --oneline
git reflog出现的head{移动到当前版本数}
5.操作版本,回到哪一个版本。
git reset. --hard 9a9ebd6
git reset --hard HEAD^根据head指针回到行
git reset --hard HEAD^^^回退三行
git reset --hard HEAD~3回退n步
7.删除文件并找回
删除:git rm filename
找回:git reset --hard[指针位置]
找回的前提是,删除前,文件存在时的状态已经提交到本地库
删除操作已经提交到本地库:指针位置指向历史记录
删除操作尚未提交到本地库:指针位置使用HEAD
8.工作区和暂存区的文件比较差异
git diff apple.txt
git diff HEAD apple.txt
不带文件名会比较多个文件
9.分支的好处
同时并行推进多个功能开发,提高开发效率
各分支在开发过程中,如果某个功能开发失败,不会对其他分支有任何影响
10.查看分支
git branch -v
11.创建分支
git branch [分支名]
12.切换到某个分支
git checkout [分支名]
git add filename分支增加修改文件和上面的一样
git commit -m "说明..." [分支名]
13.合并分支
git merge [被合并的分支名]
14.解决冲突
第一步:编辑冲突文件,删除特殊符号
第二步:把文件修改到满意的程度,保存退出
第三步:git add [文件名]
第四步:git commit -m "日志说名..."
注意:第四步后面不能跟文件名
git基本原理
git底层采用哈希SHA-1算法
git远程操作
git remote add [远程库别名] https://github.com/帐号/远程库名.git
8.将抓取下来的修改和本地库合并
10.解决冲突
如果不是基于GitHub远程库的最新版所做的修改,不能推送,必须先拉取
拉取下来后如果进入冲突状态,则按照"分支冲突解决"操作即可
Git工作流
1.集中式工作流(类似svn)
2.GitFlow工作流(最常用)
3.forking工作流(跨团队操作常用)
Gitlab服务器搭建过程
1.官网网址
首页:https://about.gitlab.com/
安装说明:https://about.gitlab.com/installation/
2.安装命令摘录
yum install -y curl policycoreutils-python openssh-server cronie
lokkit -s http -ssh
yum install postfix
server postfix start
chkconfig postfix on
curls https://packages.gitlab.com/install/repositories/gitlab-ee/script.rpm.sh | sudo bash
EXTERNAL_URL="http://gitlab.example.com" yum -y install gitlab-ee
yum安装 gitlab-ee(或社区版ce)时,需要联网下载几百M的安装文件,可以提前下载rpm安装包
下载地址:https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-10.8.2-ce.0.el7.x86_64.rpm
3.Gitlab服务操作
初始化配置Gitlab
gitlab-ctl reconfigure
启动Gitlab服务
gitlab-ctl start
停止Gitlab服务
gitlab-ctl stop
4.浏览器访问
先关闭防火墙
访问Linux服务器ip地址即可,如果想访问EXTERNAL_URL指定的域名还需要配置余名服务器和本地hosts文件
初次登陆时需要为Gitlab的root用户设置密码
创建库(和GitHub差不多的流程)
Git/GitHub基本操作的更多相关文章
- Git&Github基本操作与分支管理
Git的原理涉及快照流.链表.指针等,这里不作过多叙述. 1.基本操作 git init 创建一个 Git 仓库 git clone [url] 拷贝一个 Git 仓库到本地 git add [fil ...
- Git——github基本操作
基本概念 上一篇文章写到git共享仓库,但是有个局限性,就是这个仓库存在于本地,其他人无法从我们这个仓库拿到共享的内容 但是我们可以将这个共享仓库放入一个远程的服务器上,然后设置一些登录权限就能完美的 ...
- 【Git/GitHub学习笔记】基本操作——创建仓库,本地、远程同步等
近日想分享一些文件,但是用度盘又太麻烦了(速度也很恶心).所以突发奇想去研究了下GitHub的仓库,这篇文章也就是一个最最最基础的基本操作.基本实现了可以在GitHub上存储文本信息与代码. 由于我的 ...
- Github学习之路-小试牛刀,练习Git 的基本操作
一.下子windows客户端. Git 客户端下载地址:http://msysgit.github.io/ 二.打开Git Bash 命令行操作界面. 安装完成后,在开始菜单里找到“Git”-> ...
- git/github初级运用自如(zz)
----//git/github环境配置 一 . github上创建立一个项目 用户登录后系统,在github首页,点击页面右下角“New Repository” 填写项目信息: project n ...
- 【转载】git/github初级运用自如
之前了解过github,并在上面看了一些项目的源代码,于是自己也在github上创建了账户,希望以后有机会也把自己的项目托管在上面去.但是前提你要先了解git/github,下面的内容是从我的好基友虫 ...
- Git GUI基本操作
一.Git GUI基本操作 1.版本库初始化 gitpractise文件夹就变成了Git可以管理的仓库,目录下多了一个.git文件夹,此目录是Git用于管理版本库的,不要擅自改动里面的文件,这样会破坏 ...
- git/github初级运用自如(转自:虫师)
注:本文来源于 虫师博客(http://www.cnblogs.com/fnng/archive/2012/01/07/2315685.html) ,内容详尽,真实有用. 另:发一个github使用教 ...
- 【转】Git GUI基本操作
一.Git GUI基本操作 1.版本库初始化 gitpractise文件夹就变成了Git可以管理的仓库,目录下多了一个.git文件夹,此目录是Git用于管理版本库的,不要擅自改动里面的文件,这样会破坏 ...
随机推荐
- wvblk 把 xp、2003、win7(32位) 装入 VHD
关键1:是[预安装]阶段F6加载wvblk驱动: or 在还原ghost镜像后,导入wvblk驱动. 关键1.5:对于 win7(32位)来说,还可以在设备管理器内,通过添加“过时”硬件的方式导入wv ...
- 02工厂方法模式FactoryMethod
一.什么是工厂方法模式 工厂方法模式同样属于类的创建型模式又被称 为多态工厂模式 .工厂方法模式的意义是定义一个创建 产品对象的工厂接口,将实际创建工作推迟到子类当中. 核心工厂类不再负责产品的创建, ...
- AnalyticDB - 分析型数据库
https://yq.aliyun.com/teams/31?spm=5176.7937365.1120968.ee1.78505692UL9DhG 分析型数据库(AnalyticDB)是一种高并发低 ...
- Rsync实现多台Windows工作电脑文件同步
你要准备的软件有: 最新版 Rsync for windows 服务端:cwRsync_Server_2.1.5_Installer.zip 客户端:cwRsync_2.1.5_Installer.z ...
- 九、K3 WISE 开发插件《工业单据老单序时薄插件工具栏按钮开发实例》
=============================== 目录: 1.添加工具栏按钮 2.查询被添加工具栏按钮的业务单据的FMenuID和FID 3.添加工具栏按钮和业务单据的映射关系 4.工具 ...
- AutoFac记录
概念 Autofac是一个轻量级的依赖注入的框架,同类型的框架还有Spring.NET,Unity,Castle等: ContainerBuilder:将组件注册成服务的创建者. 组件:Lambda表 ...
- php reids 单机命令
一.Redis连接与认证 //连接参数:ip.端口.连接超时时间,连接成功返回true,否则返回false $ret = $redis->connect('127.0.0.1', 6379, 3 ...
- EF中的预先加载和延迟加载
延迟加载(Lazy Loading):当实体第一次被读取时,相关数据不会被获取,只会读取本身.延迟加载的数据不会一次性查出来,而是一条一条的查询,这样就会多次请求数据库进行查询. 预先加载<Ea ...
- Mongodb----整理
----------------------------------------------------------------------------------mongodb基本操作------- ...
- ul li 的 float:left;
如 ul li{float:left;} 出来的效果不仅是原本默认竖着排的元素变横排,还是往左边排,重点是元素是按顺序排的,如果float等于right,则不仅是往右排,且元素是倒着排的,如原来的a ...