美文网首页
2019-04-18

2019-04-18

作者: 点亮生活501 | 来源:发表于2019-04-18 16:34 被阅读0次

    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.emaillizhenya@mail.com” # 配置git使用邮箱
      [root@git‐git ~]# git config –‐global color.ui true # 语法高亮

    03 .Git常规使用

    image.png
    1. git init 初始化空的 Git 版本库于
    2. git status 查看仓库状态 保持仓库始终是干净的
    3. git add 添加文件到暂存区
    4. git rm --cached <file> 撤出暂存区(文件未提交到本地仓库)
    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 git@10.0.0.200: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


    image.png

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

    5 gitlab使用

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

    image.png
    设置组名称、描述等创建群组
    image.png
    image.png
    image.png
    4、把用户添加到组里面 管理区域-选择创建的oldboy组进行添加用户、权限给开发人员-增加用户到群组
    image.png
    5、创建仓库 管理区域-创建仓
    image.png
    image.png

    6、登陆dev用户测试是否能看到空的git‐test仓库
    7、添加ssh‐keys到gitlab 注:一个服务器的key只能添加到一个gitlab服务器上,一个用户可以添加多个key ssh‐keygen ‐t rsa
    8、添加远程仓库、推送本地代码到远程仓库 git remote add origin git@10.0.0.203: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 git@10.0.0.203: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、设置保护主分支

    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 image.png

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

    git remote add origin git@10.0.0.200: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

          本文链接:https://www.haomeiwen.com/subject/ewutgqtx.html