赞
踩
目录
4.1、分支切换
git是一个分布式版本控制软件,最初由林纳斯·托瓦兹(Linus Torvalds)创作,于2005年以GPL发布。最初目的是为更好地管理Linux内核开发而设计。
Git 官方中文手册 Git - Book
自2002年开始,林纳斯·托瓦兹决定使用BitKeeper作为Linux内核主要的版本控制系统用以维护代码。因为BitKeeper为专有软件,这个决定在社区中长期遭受质疑。在Linux社区中,特别是理查德·斯托曼与自由软件基金会的成员,主张应该使用开放源代码的软件来作为Linux核心的版本控制系统。林纳斯·托瓦兹曾考虑过采用现成软件作为版本控制系统(例如Monotone),但这些软件都存在一些问题,特别是性能不佳。现成的方案,如CVS的架构,受到林纳斯·托瓦兹的批评。
2005年,安德鲁·垂鸠写了一个简单程序,可以连接BitKeeper的存储库,BitKeeper著作权拥有者拉里·麦沃伊认为安德鲁·垂鸠对BitKeeper内部使用的协议进行逆向工程,决定收回无偿使用BitKeeper的授权。Linux内核开发团队与BitMover公司进行蹉商,但无法解决他们之间的歧见。林纳斯·托瓦兹决定自行开发版本控制系统替代BitKeeper,以十天的时间,编写出第一个git版本。
- [root@git ~]# rpm -qa centos-release
- centos-release-7-4.1708.el7.centos.x86_64
- [root@git ~]# uname -a
- Linux gitlab 3.10.0-693.el7.x86_64 #1 SMP Tue Aug 22 21:09:27 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
- [root@git ~]# getenforce
- Disabled
- [root@git ~]# systemctl status firewalld.service
- ● firewalld.service - firewalld - dynamic firewall daemon
- Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)
- Active: inactive (dead)
- Docs: man:firewalld(1)
本文使用的linux系统均为该系统
[root@git ~]# yum install git -y
命令集
- git config --global user.name "username" #配置git使用用户
- git config --global user.email "email@mail.com" #配置git使用邮箱
- git config --global color.ui true #语法高亮
- git config --list # 查看全局配置
- [root@gitlab ~]# git config --global user.name "newrain" #配置git使用用户
- [root@gitlab ~]# git config --global user.email "newrain@aliyun.com" #配置git使用邮箱
- [root@gitlab ~]# git config --global color.ui true #语法高亮
- [root@gitlab ~]# git config --list # 查看全局配置
- user.name=newrain
- user.mail=newrain@aliyun.com
- color.ui=true
- [root@gitlab ~]# cd
- [root@gitlab ~]# cat .gitconfig
- [user]
- name = newrain
- email = newrain@aliyun.com
- [color]
- ui = true
git-help
git --help
man git
- [root@gitlab ~]# useradd git
- [root@gitlab ~]# passwd git
- [root@gitlab ~]# mkdir /git-root/
- [root@gitlab ~]# cd /git-root/
- [root@gitlab git-root]# git init --bare shell.git
- Initialized empty Git repository in /git-root/shell.git/
- [root@gitlab git-root]# chown -R git:git shell.git
- [root@gitlab opt]# ssh-keygen
- [root@gitlab opt]# ssh-copy-id git@192.168.249.156
- [root@gitlab opt]# git clone git@192.168.249.156:/git-root/shell.git
- [root@gitlab opt]# ls
- rh shell
- [root@gitlab opt]# cd shell/
- [root@gitlab shell]# vim test1.sh
- [root@gitlab shell]# git add test1.sh
- [root@gitlab shell]# git commit -m 'first commit'
- [master (root-commit) 33c5fbf] first commit
- 1 file changed, 2 insertions(+)
- create mode 100644 test1.sh
- [root@gitlab shell]# git push origin master
- Counting objects: 3, done.
- Writing objects: 100% (3/3), 230 bytes | 0 bytes/s, done.
- Total 3 (delta 0), reused 0 (delta 0)
- To git@192.168.1.102:/git-root/shell.git
- * [new branch] master -> master
- [root@gitlab shell]#
命令 | 命令说明 |
---|---|
#add | 添加文件内容至索引 |
bisect | 通过二分查找定位引入 bug 的变更 |
#branch | 列出、创建或删除分支 |
#checkout | 检出一个分支或路径到工作区 |
#clone | 克隆一个版本库到一个新目录 |
#commit | 记录变更到版本库 |
#diff | 显示提交之间、提交和工作区之间等的差异 |
fetch | 从另外一个版本库下载对象和引用 |
grep | 输出和模式匹配的行 |
#init | 创建一个空的 |
#log | 显示提交日志 |
#merge | 合并两个或更多开发历史 |
#mv | 移动或重命名一个文件、目录或符号链接 |
#pull | 获取并合并另外的版本库或一个本地分支 |
#push | 更新远程引用和相关的对象 |
rebase | 本地提交转移至更新后的上游分支中 |
#reset | 重置当前HEAD到指定状态 |
#rm | 从工作区和索引中删除文件 |
show | 显示各种类型的对象 |
#status | 显示工作区状态 |
#tag | 创建、列出、删除或校验一个GPG签名的 tag 对象 |
[root@gitlab git_data]# touch README
[root@gitlab git_data]# git add ./*
- [root@gitlab git_data]# git commit -m 'first commit'
- [master(根提交) bb963eb] first commit
- 1 file changed, 0 insertions(+), 0 deletions(-)
- create mode 100644 README
[root@gitlab git_data]# git status
- git add * 添加到暂存区域
- git commit 提交git仓库 -m 后面接上注释信息,内容关于本次提交的说明,方便自己或他人查看
- [root@gitlab git_data]# rm 123 -f
- [root@gitlab git_data]# ls
- README
在实际的项目开发中,尽量保证master分支稳定,仅用于发布新版本,平时不要随便直接修改里面的数据文件。
那在哪干活呢?干活都在dev分支上。每个人从dev分支创建自己个人分支,开发完合并到dev分支,最后dev分支合并到master分支。所以团队的合作分支看起来会像下图那样。
- [root@gitlab git_data]# git branch newrain
- [root@gitlab git_data]# git branch
- * master
- newrain
- [root@gitlab git_data]# git checkout newrain
- 切换到分支 'newrain'
- Switched to branch 'newrain'
- [root@gitlab git_data]# git branch
- master
- * newrain
- [root@gitlab git_data]# cat README
- This is git_data readme
- [root@gitlab git_data]# echo '1901' >> README
- [root@gitlab git_data]# git add .
- [root@gitlab git_data]# git commit -m '1901'
- [newrain 4310e7e] 1901
- 1 file changed, 1 insertion(+)
- [root@gitlab git_data]# git status
- # On branch newrain
- nothing to commit, working directory clean
- ---
- # 位于分支 newrain
- 无文件要提交,干净的工作区
- [root@gitlab git_data]# git checkout master
- Switched to branch 'master'
- 切换到分支 'master'
- [root@gitlab git_data]# cat README
- This is git_data readme
- [root@gitlab git_data]# git log -1
- commit f5b79552635a7dc60afc35c99c1170366d8c5f6b
- Author: newrain <newrain@aliyun.com>
- Date: Sat May 11 21:29:21 2019 -0700
-
- 456
- [root@gitlab git_data]# git merge newrain
- Updating f5b7955..4310e7e
- Fast-forward
- README | 1 +
- 1 file changed, 1 insertion(+)
- [root@gitlab git_data]# git status
- # On branch master
- nothing to commit, working directory clean
- # 位于分支 master
- 无文件要提交,干净的工作区
- [root@gitlab git_data]# cat README
- This is git_data readme
- 1901
因为之前已经合并了newrain分支,所以现在看到它在列表中。 在这个列表中分支名字前没有 * 号的分支通常可以使用 git branch -d 删除掉;你已经将它们的工作整合到了另一个分支,所以并不会失去任何东西。
查看所有包含未合并工作的分支,可以运行 git branch --no-merged**:
这里显示了其他分支。 因为它包含了还未合并的工作,尝试使用 git branch -d 命令删除它时会失败。
- git branch -d testing
- error: The branch 'testing' is not fully merged.
- If you are sure you want to delete it, run 'git branch -D testing'.
前面我们已经知道Git人人都是中心,那他们怎么交互数据呢?
yum安装
- # 安装依赖,并启动ssh、防火墙开启相应端口、postfix
- [root@gitlab ~]# yum install -y curl policycoreutils-python openssh-server perl
- # 安装完成后会直接启动
- [root@gitlab ~]# yum install gitlab-jh-16.0.3-jh.0.el7.x86_64.rpm
初始化
- # 以下两种方法都可以配置访问地址,第一种需要在yum安装前配置
- [root@gitlab ~]# export EXTERNAL_URL='http://192.168.249.156'
- 或
- [root@gitlab ~]# vim /etc/gitlab/gitlab.rb
- external_url 'http://192.168.249.156'
- [root@gitlab ~]# gitlab-ctl reconfigure
查看状态
- [root@gitlab ~]# gitlab-ctl status
- run: gitaly: (pid 4491) 48s; run: log: (pid 4087) 279s
- run: gitlab-monitor: (pid 4539) 44s; run: log: (pid 4251) 207s
- run: gitlab-workhorse: (pid 4501) 47s; run: log: (pid 4099) 273s
- run: logrotate: (pid 4125) 265s; run: log: (pid 4124) 265s
- run: nginx: (pid 4112) 271s; run: log: (pid 4111) 271s
- run: node-exporter: (pid 4175) 243s; run: log: (pid 4174) 243s
- run: postgres-exporter: (pid 4528) 45s; run: log: (pid 4223) 219s
- run: postgresql: (pid 3933) 343s; run: log: (pid 3932) 343s
- run: prometheus: (pid 4514) 46s; run: log: (pid 4156) 259s
- run: redis: (pid 3876) 355s; run: log: (pid 3875) 355s
- run: redis-exporter: (pid 4186) 237s; run: log: (pid 4185) 237s
- run: sidekiq: (pid 4078) 281s; run: log: (pid 4077) 281s
- run: unicorn: (pid 4047) 287s; run: log: (pid 4046) 287s
检查端口
- [root@gitlab ~]# netstat -lntup|grep 80
- tcp 0 0 127.0.0.1:8080 0.0.0.0:* LISTEN 4073/unicorn master
- tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 4112/nginx: master
- tcp 0 0 0.0.0.0:8060 0.0.0.0:* LISTEN 4112/nginx: master
http://192.168.18.150
注意:首次登录用户名是root 密码在 /etc/gitlab/initial_root_password文件里面。
注意:在这里创建好用户记得给他们设置密码,并且将他们邀请到群组里面。
创建目录前端和后端,里面写项目就可以了。
用http克隆代码
接下来我们打开vscode创建文件
创建分支master
接下来回到我们的git项目,创建合并请求即可。
这是我们刚才创建的master分支
合并分支
出现图中的信息,那么我们的分支就合并成功了。
Pro Git书籍 Git - Bookhttps://git-scm.com/book/zh/v2
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。