学习git(一)
一、自动化运维
1、网络层(接入层、汇聚层、核心层);
1 LB+HA(L4、L7);
2 服务层(reverse proxy cache、应用层、web层、SOA层、分布式层、DAL);
3 数据层(分布式缓存、NoSQL、DB);
4 系统层(环境初始化)
5 基础设施(IDC托管、设备上下架);
2、自动化实现:
1 网络层(SDN,softwaredefinition network);
2 LB+HA(平台开发、IaaS);
3 服务层(PaaS or docker(自动化调度、自动化开发、自动化发现(服务发现、服务注册));reverse proxy cache(第三方平台开发);应用层(自定义开发);web层、SOA层、分布式层、DAL(saltstack,saltcloud,有docker模块、消息));
4 数据层(DAL);
5 基础设备、系统层(IaaS,openstack);
3、安全:
1 网络层(firewall);
2 LB+HA、服务层(WAF,web application firewall)
3 数据层(如DB权限);
4 系统层(tcp wrapper);
5 基础设施(物理安全);
4、备份:
1 网络层(HSRP、VRRP);
2 LB+HA(VRRP);
3 数据层(DB备份);
4 服务层中的web层(saltstack);
5 核心层(网关设备(outside、inside)、防火墙、router);
6 汇聚层(三层交换;动态路由、静态路由、EC、端口汇聚);
7 接入层(二层交换;VTP、SPF、trunk、port安全);
8 L4(LVS、F5's BigIP、Citrix's Netscaler、A10);
9 L7(haproxy、nginx);
10 DAL、专业团队做(taobao'sTDDL、360);
11 分布式层(分布式存储(glusterfs、moosefs、fastDFS);分布式MQ(rabbitMQ、QPID、zeroMQ));
12 SOA层、服务化(应用服务层duddo、基于restfull api开发);
13 web层(httpd、nginx、tomcat、jboss、resin);
14 应用层、应用变更ittle(php、java、python、C、C++);
15 reverse proxy cache(ATS、squid、varnish;CDN(配置同步;流量统计;预缓存;缓存更新;日志分析;智能DNS));
16 DB(MySQL、Oracle、postgre SQL、SQLserver、access);
17 NoSQL(mongodb、redis、couchbase、elasticsearch);
18 分布式缓存(memcached、redis);
19 环境初始化(性能优化;监控agent;自动化管理saltstack minion;内部DNS;limit(例如tcp wrapper限制仅跳板机ssh到server);
20 设备上下架(网络配置;标签;自检(配货单与实物对比);raid;iDrac|ILO|IMM;OS安装;资产录入(分层设计)——合同管理(采购方-采购时间-采购人-联系信息)——保修时间——地点——配置详情——MDB配置项(OS类型-IPv4,RIP,VIP,IPMI,hostname)——服务层面);
21 IDC托管(熟悉各大IDC厂商;根据业务类型选择;网络测试;谈价格、走合同;设备采购(需求分析、采购、上下架));
5、运维标准化(版本、路径、服务、OS……);
6、运维边界:
1 运维边界模糊化(掌握尽可能多的知识点);
2 运维开发(后端>前端,重点在后端);
7、自动化运维发展阶段:
1 标准化、工具化(标准化运维;运维标准化、操作工具化、变更流程化);
2 web化、平台化(web化运维;操作web化、权限控制、弱化流程、统计分析、统一调度);
3 服务化、api化(DNS服务、LB服务、监控服务、分布式缓存服务、分布式存储服务、CMDB);
4 智能化;
8、服务器生命周期:
服务器上架-->网络配置-->raid配置-->IPMI
服务器上架-->环境部署-->运维变更-->(服务更新-->代码更新-->服务扩容&缩容);(服务下线,服务器下线)
环境部署(OS安装(cobbler);服务部署(saltstack);应用代码部署(saltstack&shell);监控配置(zabbix);加入运行集群(LVS&haproxy))
9、持续集成、持续部署:
二、git简介
分布式的版本控制系统;
diff(2002年之前)-->bitkeeper(2002年)-->git(不要逼我);
集中式;
分布式(中央服务器用于交换代码);
https://www.git-scm.com/
注:不要拿git与svn相对比,git只能管理文本文件,不能管理picture;
https://github.com/jowinchaitest,github源码托管,开源项目,代码管理,控制工具;
三、安装部署
yum install git #安装git
git config –global user.name “tom” #配置git用户
git config –global user.email “tom@qq.com” #配置git邮箱
git config –global color.ui true #配置颜色
git config –list #查看配置信息
四、git常用命令
add #添加文件内容至索引
bisect #通过二分查找定位引入 bug 的变更
branch #列出、创建或删除分支
checkout #检出一个分支或路径到工作区
clone #克隆一个版本库到一个新目录
commit #记录变更到版本库
diff #显示提交之间、提交和工作区之间等的差异
fetch #从另外一个版本库下载对象和引用
grep #输出和模式匹配的行
init #创建一个空的 Git 版本库或重新初始化一个已存在的版本库
log #显示提交日志
merge #合并两个或更多开发历史
mv #移动或重命名一个文件、目录或符号链接
pull #获取并合并另外的版本库或一个本地分支
push #更新远程引用和相关的对象
rebase #本地提交转移至更新后的上游分支中
reset #重置当前HEAD到指定状态
rm #从工作区和索引中删除文件
show #显示各种类型的对象
status #显示工作区状态
tag #创建、列出、删除或校验一个GPG签名的 tag 对象
五、git基本操作
1、git提交数据
mkdir tom
cd tom
git init #初始为git工作目录
echo 111 > readme.txt
git status #查看git状态
git add readme.txt #git添加文件至暂存区
git status #再次查看状态
git commit -m “this is 1 commit” #git cmmit提交暂存取文件至git版本仓库
2、git移除数据
touch aa.txt
git add aa.txt #添加文件至暂存区
git status
git rm –cached aa.txt #将文件从git暂存区域的追踪列表移除(不会删除文件的数据)
git status
将文件数据从git暂存区和工作目录一起删除
git add aa.txt
git rm –f aa.txt #强制删除-f参数
ls
git status
3、git移动数据
方法一:
git mv readme.txt test.txt #修改文件名称
git status
git commit -m “changed name”
方法二:
mv test.txt readme.txt #先修改名称
git rm test.txt #然后删除git版本仓库内的文件快照
git add readme.txt #最后再将新的文件添加进入
git commit -m “changed name” #提交至git版本仓库
4、git历史记录
git log #查看提交历史记录
git log -2 #查看最近几条记录
git log -p -1 #-p显示每次提交的内容差异,例如仅查看最近一次差异
git log –stat -2 #–stat简要显示数据增改行数,这样能够看到提交中修改过的内容,
对文件添加或移动的行数,并在最后列出所有增减行的概要信息
git log –pretty=oneline #–pretty根据不同的格式展示提交的历史信息
git log –pretty=fuller -2 #以更详细的模式输出提交的历史记录
git log –pretty=fomat:”%h %cn” #查看当前所有提交记录的简短SHA-1哈希字串与提交着的姓名
还可以使用format参数来指定具体的输出格式,这样非常便于后期编程的提取分析哦,常用的格式有:
%s 提交说明。
%cd 提交日期。
%an 作者的名字。
%cn 提交者的姓名。
%ce 提交者的电子邮件。
%H 提交对象的完整SHA-1哈希字串。
%h 提交对象的简短SHA-1哈希字串。
%T 树对象的完整SHA-1哈希字串。
%t 树对象的简短SHA-1哈希字串。
%P 父对象的完整SHA-1哈希字串。
%p 父对象的简短SHA-1哈希字串。
%ad 作者的修订时间。
5、git还原数据
echo “hello word” >> readme.txt #追加一段话
git add readme.txt #添加至暂存区
git commit -m “test” #提交至git版本仓库
git log –pretty=oneline #查看提交的历史信息
git reset –hard HEAD^ #还原历史提交版本上一次
cat readme.txt #查看文件内容(已经还原)
git log –pretty=oneline
git reflog #查看未来历史更新点
git reset –hard 4bf5b29 #找到还原点的SHA-1值,就可以还原(值不写全,系统会自动匹配) echo “hello tom” >> readme.txt
git checkout — readme.txt #还原某个文件
cat readme.txt
规则:如果暂存区中有该文件,则直接从暂存区恢复。如果没有该文件,将还原成最近一次提交的快照。
六、git管理分支结构
1、创建分支
git branch linux #创建分支
git checkout linux #切换分支
git branch #查看当前分支情况,标示为*号 echo “Create new branch” >> readme.txt #我们对文件追加一行字符串
git add readme.txt #提交到暂存区
git commit -m “new branch” #提交到git版本仓库 git checkout master #切回master分支
cat readme.txt #查看文件内容,并没有新追加的字符串
分支可以理解为:目录、数据库
2、合并分支
git branch #查看是否在master分支
git merge linux #合并Linux分支至master
cat readme.txt #查看合并后的readme文件
git branch -d linux #确认合并完成后,删除Linux分支
git branch #查看分支
3、分支冲突
git checkout -b linux #创建并切换到该分支
echo “1 hello” >> readme.txt #追加一行内容
git add readme.txt #在Linux分支添加readme至暂存区
git commit -m “create two” #在Linux分支提交readme
git checkout master #切换到master分支
echo "2 tom" >> readme.txt #在master分支上追加同一行内容
git add readme.txt #添加至暂存区
git commit -m ‘to master’ #提交至Git版本仓库
git merge linux #合并Linux分支(冲突)
cat readme.txt #冲突内容
git status #可获取冲突原因
解决冲突:手动编辑好,add到缓存区,再commit,最后合并两分支
vim readme.txt
git add readme.txt #再次添加至暂存区
git commit -m ‘config’ #提交至git版本仓库
git merge linux #合并Linux分支
七、git管理标签
cd tom/ #进入git版本控制系统
git tag v1.0 #当前分支打一个标签(方便快速回滚)
git tag #查看当前所有的标签
git show v1.0 #查看当前1.0版本的详细信息
git tag v1.2 -m “v1.2” #创建带有说明的标签,-a指定标签名字,-m指定说明文字
git tag -d v1.0 #删除之前的v1.0
git tag #再次查看,v1.0已经被删除
八、持续集成
markdown编辑器(是一种可以使用普通文本编辑器编写的标记语言) 标题:
#表示一级标题,##、###、####、#####、######,共支持6级标题 列表:
列表分有序列表和无序列表,无序列表用*或-;只有空格或tab的就是一个空行; 引用:
> hello,word
[ ]( ) #(链接,网页引用,广告链接)
![ ]( ) #(图片引用,图片广告) 代码框:
例1:
<TAB>while true:
<TAB><TAB>do echo nimei;
<TAB>done 例2:
'yum -y install lrzsz' 'echo nimei'
*的使用:
*我变斜了* #(文字两边各1个*,把文字倾斜)
**我变粗了** #(文字两边用2个*,把文字变粗)
*** #(一行中仅有3个*,表示分割线)
九、GitLab安装部署
Gitlab是一个用Ruby onRails开发的开源项目管理程序,可以通过WEB界面进行访问公开的或者私人项目。它和Github有类似的功能,能够浏览源代码,管理缺陷和注释
1、安装gitlab的依赖
yum install -y curl openssh-server openssh-clients postfix cronie policycoreutils-python
2、启动postfix,并设置为开机启动
service postfix start
chkconfig on postfix
3、获取gitlab的rpm包
清华开源镜像站
wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el6/gitlab-ce-10.0.2-ce.0.el6.x86_64.rpm
4、安装gitlab
rpm -ivh gitlab-ce-10.0.2-ce.0.el6.x86_64.rpm
基本操作
gitlab-ctl reconfigure #重新编译配置
gitlab-ctl status #查看状态
gitlab-ctl stop #停止服务
gitlab-ctl start #启动服务
gitlab-ctl tail #查看日志、
gitlab-ctl tail nginx #查看nginx日志
gitlab-ctl help #查看帮助
汉化
1、查看gitlab版本
head -1 /opt/gitlab/version-manifest.txt
2、停止服务
gitlab-ctl stop
3、下载汉化包
v7-v8.8:https://gitlab.com/larryli/gitlab
v8.9:https://gitlab.com/xhang/gitlab
4、更新汉化包
\cp -rf /tmp/gitlab/* /opt/gitlab/embedded/service/gitlab-rails/
5、重新编译并启动服务
gitlab-ctl reconfigure
gitlab-ctl start
6、报错排除思路
查看报错日志,排除报错
vim /etc/gitlab/gitlab.rb
external_url = 'http://192.168.4.19' 不加=会出现问题 删除/opt/gitlab/embedded/service/gitlab-rails/public/uploads
删除/opt/gitlab/embedded/service/gitlab-rails/tmp
删除/opt/gitlab/embedded/service/gitlab-rails/log 权限设置
chown -R git:git /var/opt/gitlab/gitlab-rails/tmp/cache
chown -R git:root /opt/gitlab/embedded/service/gitlab-rails/
修改后台密码
gitlab-rails console production
user = User.where(id: 1).first #id为1的是超级管理员
user.password = '12345678' #密码必须至少8个字符
user.save! #如没有问题 返回true
exit
十、自动化部署上线
获取代码-->编译(可选)-->配置文件-->打包-->copy到对应服务器(对应目录)-->部署节点、移除集群-->解压、copy差异文件-->创建软链接-->重启-->自动化测试-->加入集群-->列出回滚版本-->执行回滚-->删除软链接-->重新创建软链接-->重启(可选)
---------------------script start------------------ #!/bin/bash # DATE=`date "+%Y-%m-%d"` TIME=`date "+%Y-%m-%d-%H-%M"` CODE_DIR=/ane/test/demo CONFIG_DIR=/ane/test/config TAR_DIR=/ane/tar TMP_DIR=/ane/tmp usage() { echo$"Usage: $0 [deploy|rollback-list|rollback-pro VERSION]" } git_pro() { echo "git pull" cd $CODE_DIR && git pull API_VERL=`gitshow | grep commit | cut -d' ' -f2` API_VER=`echo${API_VERL:0:6}` /bin/cp -r $CODE_DIR $TMP_DIR } config_pro() { echo "add pro config" /bin/cp $CONFIG_DIR/* $TMP_DIR/demo TAR_VER=$API_VER-$TIME cd $TMP_DIR && mv demo pro_demo_"$TAR_VER" } tar_pro() { echo "tar_pro" cd $TMP_DIR && tar zcf pro_demo_"$TAR_VER".tar.gz pro_demo_"$TAR_VER" echo "tar end" } scp_pro() { echo "begin scp" /bin/cp$TMP_DIR/pro_demo_"$TMP_VER".tar.gz /tmp/ } deploy_pro() { echo "begin deploy" cd /tmp && tar zxf pro_demo_"$TAR_VER".tar.gz rm -f /var/www/html/demo ln -s /tmp/pro_demo_"$TAR_VER" /var/www/html/demo } test_pro() { echo "test begin" echo "test ok" } rollback_list() { ls -l /tmp/*.tar.gz } rollback_pro() { rm -f /var/www/html/demo ln -s /tmp/$1 /var/www/html/demo } main() { case $1 in deploy) git_pro; config_pro; tar_pro; scp_pro; deploy_pro; test_pro; ;; rollback-list) rollback_list; ;; rollback-pro) rollback_pro$2; ;; *) usage; esac } main $1 $2 ---------------------scriptend-----------------
pro-deploy.sh
sh -x pro-deploy.sh deploy
sh -x pro-deploy.sh rollback-list
sh -x pro-deploy.sh rollback-pro
十一、其他应用
git clone git@github.com:test/demo #把github上面的仓库克隆到本地
git push -u origin master #将本地的Git仓库同步到远程Github服务器上
git remote #查看本机列表
学习git(一)的更多相关文章
- 学习 git基础命令
缘起 年后到了新公司,由于个人意愿到了一个海外的项目组,除了自己从Java技术栈转了C#技术栈外,很多技术都是第一次使用,学习压力不小啊. 自己也就先从常用的技术开始学起,比如C#,AngularJS ...
- 学习Git的总结与体会
学习Git的总结 blog 第一次学习Git是完全按照廖雪峰老师的教程学习的,学的过程中基本上没有遇到什么问题,但是自己实际操作就问题不断了. 首先,还是按照惯例,来膜拜一下廖雪峰老师精简的教程知识吧 ...
- 深入理解学习Git工作流
http://blog.csdn.net/hongchangfirst/article/list/3 //可以看看 http://blog.csdn.net/hongchangfirst/articl ...
- [转]深入理解学习GIT工作流
深入理解学习Git工作流 字数13437 阅读2761 评论3 喜欢70 个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心 ...
- 记录我开始学习 Git的路程
工作半年多了,总觉得没学到什么东西,于是乎找了个Git学习一下,感觉还蛮厉害的样子.为此记录下我的路程 2015,11,26 更新 前面的路都挺艰难的,在官网下载msysgit网速几乎为0(心情千万只 ...
- 推荐一个可视化的学习Git的好网站:LearnGitBranching
博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:推荐一个可视化的学习Git的好网站:LearnGitBranching.
- 发现一个不错的学习git的地方
Git入门:http://rogerdudler.github.io/git-guide/index.zh.html 简洁.实用.高效的学习git基本操作的方式
- 深入理解学习Git工作流(转)
个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心中的困惑迎刃而解,于是我将这部分资料进行整理放到了github上,欢迎st ...
- [少数派]如何学习Git
用玩游戏的方式学习 Git 目录 为什么要学习 Git 怎么学习 Git Learn Git Branching 其他学习资源 用游戏的方式来学习,是一种有趣而高效的方式. 从刚接触电脑时的打字练习软 ...
- 深入理解学习Git工作流(git-workflow-tutorial)
转载:https://segmentfault.com/a/1190000002918123#articleHeader11 人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协 ...
随机推荐
- Pytorch AdaptivePooing操作转Pooling操作
Pytorch AdaptivePooing操作转Pooling操作 多数的前向推理框架不支持AdaptivePooing操作,此时需要将AdaptivePooing操作转换为普通的Pooling操作 ...
- 如何用zabbix监控mysql多实例
agent上起了多了 mysql实例,占用不同的端口,agent 仅在初始状况下,塞入脚本和 键配置,然后重启. 以后维护的时候(mysql端口变动),要做到 不能 动agent,力争 只在 web端 ...
- 【C# .Net GC】自动内存管理
原文:https://docs.microsoft.com/zh-cn/dotnet/standard/automatic-memory-management 自动内存管理是公共语言运行时在托管执行过 ...
- $_SERVER["QUERY_STRING"],$_SERVER["REQUEST_URI"],$_SERVER["SCRIPT_NAME"] 和$_SERVER["PHP_SELF"]
$_SERVER["QUERY_STRING"],$_SERVER["REQUEST_URI"],$_SERVER["SCRIPT_NAME" ...
- JSP文件的上传
JSP 文件上传 JSP 可以与 HTML form 标签一起使用,来允许用户上传文件到服务器.上传的文件可以是文本文件或图像文件或任何文档. 本章节我们使用 Servlet 来处理文件上传,使用到的 ...
- 哈工大 信息安全 实验 Snort与单台防火墙联动实验
XX大学XX学院 <网络攻击与防御> 实验报告 实验报告撰写要求 实验操作是教学过程中理论联系实际的重要环节,而实验报告的撰写又是知识系统化的吸收和升华过程,因此,实验报告应该体现完整性. ...
- js实现密码输入框对开启键盘大写锁定的提示(IE浏览器下有自动识别提示则不执行(用IE自带效果即可))
代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <tit ...
- django-admin常用总结
django-admin常用总结 1.modelAdmin 1.1 list_display:显示列表. 1.2 search_fields:可被搜索的字段. 1.3 list_per_page:显示 ...
- Dubbo服务框架和spring-cloud架构的优缺点
Dubbo一.dubbo简介 Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的RPC实现服务的输出和输入功能,可以和Spring框架无缝集成. Dubbo是一款高性能.轻 ...
- 二级py--day1
1.py基础篇 解释:因为在python语言中存在一个不确定尾数问题. 因为浮点数是以二进制形式储存在计算机内部的,受限于宽度,二进制数并不完全等于其浮点数本身,只能说接近.所以0.1+0.2==0. ...