2019-04-18

01.devops介绍

DevOps(Development和Operations的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

02.Git版本控制系统

SVN 集中式的版本控制系统,只有一个中央数据仓库,如果中央数据仓库挂了或者不可访问,所有的使用者无法使用SVN,无 法进行提交或备份文件.

Git(读音为/gɪt/。)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。

  1. 系统环境准备
    root@git‐git~]# cat /etc/redhat‐release #查看系统版本 CentOS Linux release 7.1.1503 (Core)
    [root@git‐git ~]# uname ‐r #查看内核版本 3.10.0‐229.el7.x86_64
    [root@git‐git ~]# getenforce
    确认Selinux关闭状态 Disabled
    [root@git‐git ~]# systemctl stop firewalld #关闭防火墙
  2. Git安装部署
    [root@git‐git ~]# yum install git
    安装Git [root@git ~]# git config ‐‐global
    使用全局配置文件 ‐‐system
    使用系统级配置文件 ‐‐local
    使用版本库级配置文件
    [root@git‐git ~]# git config –‐global user.name “lizhenya” # 配置git使用用户 [root@git‐git ~]# git config –‐global user.email “[email protected]” # 配置git使用邮箱
    [root@git‐git ~]# git config –‐global color.ui true # 语法高亮

03 .Git常规使用

2019-04-18_第1张图片
image.png
  1. git init 初始化空的 Git 版本库于
  2. git status 查看仓库状态 保持仓库始终是干净的
  3. git add 添加文件到暂存区
  4. git rm --cached 撤出暂存区(文件未提交到本地仓库)
  5. git add . 提交工作目录所有的文件到暂存区
  6. git config --list 查看配置的全局信息
  7. git log 查看日志
  8. git checkout -- a.txt 使暂存区内容覆盖工作目录 (已提交到仓库内的文件)
  9. git commit -am "del" 如果文件已经提交到本地仓库,可直接使用-am
  10. git rm -f c.txt 同时删除工作目录和暂存区内容
  11. git mv a.txt a ; git commit -am "mv a.tx a" git中重命名
  12. git diff 比对的是工作目录和暂存区的不同
  13. git diff --cached 比对暂存区和本地仓库的不同
  14. git log --oneline -1 -p 一行显示提交的信息 -p显示具体内容 -1 显示最近的一个提交
  15. git reset --hard b5310df 代码回滚到历史状态
  16. git reflog 查看所有的历史提交
  17. git log --oneline --decorate 查看HEAD指针指向哪个版本
  18. git branch dev 创建开发分支
  19. git checkout dev 切换到dev分支
  20. git checkout -b dev 创建并切换到分支dev
  21. git branch -d dev 删除分支
  22. git merge dev 合并dev分支到master
  23. git tag -a v1.0 -m "描述信息"
  24. git show v1.0 查看版本信息
  25. git reset --hard v2.0 代码回滚直接加版本号
  26. git tag -d v1.0 删除标签
  27. git remote 查看远程仓库
  28. git push -u origin master 推送本地仓库代码到远程仓库origin
  29. git remote remove origin
  30. git pull 拉取远程仓库的代码到本地仓库(拉取有更改的代码)
  31. git clone 拉取远程仓库的代码到本地仓库 (克隆完整的代码)
  32. gitlab-ctl status 查看gitlab状态
  33. gitlab-ctl start nginx 启动一个服务
  34. gitlab-ctl start 启动 stop 停止
  35. git remote add origin [email protected]:oldboy/git_data.git 添加远程仓库origin

04 gitlab 安装

GitLab简介 GitLab 是一个用于仓库管理系统的开源项目。使用Git作为代码管理工具,并在此基础上搭建起来的web服务。可 通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可 以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊 天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用。 常用的网站: 官网:https://about.gitlab.com/ 国内镜像:https://mirrors.tuna.tsinghua.edu.cn/gitlab‐ce/yum/ 安装环境:
1、 CentOS 6或者7 2、 2G内存(实验)生产(至少4G) 3、 安装包:gitlab‐ce‐10.2.2‐ce 4、 禁用防火墙,关闭selinux
1安装依赖
yum install -y curl policycoreutils-python openssh-server

2.安装软件包
gitlab-ce-10.2.2-ce.0.el7.x86_64 社区版本

3.更改配置文件

vim /etc/gitlab/gitlab.rb 更改本地ip地址


image.png

执行gitlab-ctl reconfigure重新配置

以上操作gitlab安装完成

通过浏览器输入IP地址进行访问gitlab 10.0.0.204


2019-04-18_第2张图片
image.png

默认root用户登陆。密码最少8位

5 gitlab使用

1、配置外观 管理区域‐外观
2、关闭自动注册‐可根据实际需求操作 管理区域‐设置‐关闭自动注册
3、创建组‐用户‐项目 创建组

2019-04-18_第3张图片
image.png

设置组名称、描述等创建群组
2019-04-18_第4张图片
image.png

2019-04-18_第5张图片
image.png

2019-04-18_第6张图片
image.png

4、把用户添加到组里面 管理区域-选择创建的oldboy组进行添加用户、权限给开发人员-增加用户到群组
2019-04-18_第7张图片
image.png

5、创建仓库 管理区域-创建仓
2019-04-18_第8张图片
image.png

2019-04-18_第9张图片
image.png

6、登陆dev用户测试是否能看到空的git‐test仓库
7、添加ssh‐keys到gitlab 注:一个服务器的key只能添加到一个gitlab服务器上,一个用户可以添加多个key ssh‐keygen ‐t rsa
8、添加远程仓库、推送本地代码到远程仓库 git remote add origin [email protected]:oldboy/get_test.git # 添加远程仓库 git remote rename origin old‐origin
远程 origin 如果已经存在则重新命名或者新添加仓库名 称不同 git push ‐u origin ‐‐all # 推送代码到远程仓库
8、克隆代码到另外一台主机 如果不做认证会让输入gitlab的密码、我们使用key进行认证 ssh‐keygen ‐t rsa 把公钥复制到dev用户下进行测试 然后在克隆代码 git clone [email protected]:oldboy/get_test.git 测试推送代码到dev下 git branch dev git checkout dev touch dev
git add . git commit ‐m "add dev" git push ‐u origin dev
推送dev分支到远程仓库 提交合并请求进行分支合并到master主分支 合并后在gitlab服务端master上没有dev、要先进行pull cd /root/git_data git pull
9、设置保护主分支

2019-04-18_第10张图片
image.png

测试dev分支推送代码则显示为拒绝,如果还是可以推送请查看配置保护分支选项 [root@web01 get_test]# git checkout master [root@web01 get_test]# git merge dev [root@web01 get_test]# git push ‐u origin master
10、返回master端测试推送,由于其他分支进行推送,和master端内容不一致,所以无法进行推送,使用git pull把代码拉取到本地,或者git fetch 把代码拉取到本地仓库后进行合并(注意:git pull = git tetch+git merge)
分发公钥信息,没有需要创建公钥

ssh-keygen -t rsa 创建公钥

image.png

2019-04-18_第11张图片
image.png

6.添加远程仓库 origin (gitlab服务器操作)

git remote add origin [email protected]:oldboy/git_data.git

git push -u origin master 推送

  1. gitlab备份
    对gitlab进行备份将会创建一个包含所有库和附件的归档文件。对备份的恢复只能恢复到与备份时的gitlab相同的 版本。将gitlab迁移到另一台服务器上的最佳方法就是通过备份和还原。 gitlab提供了一个简单的命令行来备份整个gitlab,并且能灵活的满足需求。 备份文件将保存在配置文件中定义的backup_path中,文件名为TIMESTAMP_gitlab_backup.tar,TIMESTAMP为备 份时的时间戳。TIMESTAMP的格式为:EPOCH_YYYY_MM_DD_Gitlab‐version。 如果自定义备份目录需要赋予git权限 配置文件中加入 gitlab_rails['backup_path'] = '/data/backup/gitlab' gitlab_rails['backup_keep_time'] = 604800 备份保留的时间(以秒为单位,这个是七天默认值), mkdir /data/backup/gitlab chown ‐R git.git /data/backup/gitlab 完成后执行gitlab‐ctl reconfigure

你可能感兴趣的:(2019-04-18)