标签(空格分隔): 翻译
原文地址: Continuous Delivery - Automating the Release Process
对于很多开发者来说,发布版本的那天都会陷入巨大的压力。发布过程中总是有些风险,比如出现某些莫名其妙的问题,或者是产品里又被发现了某个bug。在我上一家公司,我们采取的是手动发布版本,过程基本都是人工去做的,因此,特别容易出现问题。在发布当天,DevOps(译者:看百度百科是怎么描述 DevOps 的职责)部门会加载二进制的运行文件,然后做用户验收测试。如果所有的测试都成功,软件就会复制到服务器上,进行冒烟测,一般来说,还会进行一次前一版本的用户验收测试。下面列举出通常都会遇到的问题:
简单的说,手动和没有固定的发布流程绝不是好的选择,发布那天总会承受很大的压力。在我们的案子里,如果发布不是很频繁,团队也还不够成熟时,这样的方式是可以接受的。为了改进和自动化发布流程,有一种软件工程的方法叫持续交付。
持续交付使得发布新的功能更快更稳定。同时可以让开发者更及时的收到反馈 。我们开发一套软件,可以在任何时候自动安全的部署到产品上。这就确保了发布里的每一次改动,都会发布到类似真实产品环境上,并且可以运行大量的自动化测试。按照 Martin Fowler 的理论,如果你做到以下的了,那么就称得上是持续交付:
持续交付,是持续集成(CI)的一个重要的先决条件。持续集成要求任何新的改动都可以快速的集成到主分支上, 整个项目一直都处于开发状态中 。通常来说,它是这么工作的:一旦有改动发布到github上,就会重新编译部署。整个应用都会按照所要求的配置去编译, 一系列单元以及集成测试都会重新运行 。如果测试失败,团队会停止工作直到修复了问题。没有了持续集成,集成很容易就变成梦魇。当我启动一个新的项目的时候,如何持续集成会是我考虑的首要事情。
我看到过很多的案例,整个团队都不想关注那些出了问题的编译。这通常都发生在持续集成过程已经变成了巨大多毛的怪兽的时候。这也有违持续集成的首要目标: 出了问题的版本决不能被忽视,团队的首要任务就应该是去修它们 。为了确保这件事,持续集成的过程应该尽可能的短,好使,简单。如果测试的运行会占用过多的时间,不可靠也不能帮助定位问题,那么团队就会不去尝试修改问题版本,甚至互相推诿责任,说是别的团队弄坏了版本。
持续集成主要是在关注开发团队。 持续集成里也可能会有手动去发布版本的过程 。在我们做过的案例里,也有手动的拷贝二进制文件和对应的配置文件到演示和生产环境里的。与之相反的是,持续交付会将整个发布流程自动化。为了达到这一目标,我们使用了一条流水线,这条流水线有非常清晰的阶段和对应的过程。
一条持续交付的流水线是让你的新版本发布出去的流程的集中体现。按照 Martin Fowler的理论:
一个典型的持续交付过程如下:
决定这条持续交付流水线成功与否的部分就是验收测试,验收测试位于这条流水线的较靠后的阶段,也就是“更多靠摸索”的阶段。他们确定软件能满足用户的需求和指标。验收测试不应暴露内部系统的细节,应该就像对待黑盒一样对待。我们的验收测试会由模拟一个真正的用户会输入的内容,接受并验证系统的输出并验证这些输出是否符合预期。
在持续交付的流水线上,从一个阶段转到下一个阶段可以使手动,也可以是自动的。手动并不意味着把内容拷贝复制到下一个流程中。它只是意味着, *** 作人员需要标记一下,表示现在的阶段已经完成,可以转交到下一个阶段了,而这个过程通常会需要手动的按一下按钮。
持续交付的流水线能在确定了交付流程之后被定型下来。没有所谓的标准答案:一个流程总会和另一个看上不太一样。举个例子,在一个有很多独立组件的SOA项目里,我们觉得一个为所有的组件制定一个流程是最好的方案。而另一个项目要求给每一个组件都制定独立的流程,而整合到一起之后的流程,可以参考下图。
实现一个好的持续交付流程是一个让人沮丧的任务,但是一旦完成好了,会产生巨大的好处。在我看来,最好的方式就是仔细研究你的部署过程,理解所有的依赖关系,从一些比较小而且简单的地方开始入手。
持续交付中,总需要有人最终去确定把产品部署到生产环境中。一个典型就是,发布的软件发生了一些变动之后或者是在固定的日子。
而持续部署比持续交付则更进一步:每一次改变,只要通过了自动化测试就会自动的部署到生产环境。持续部署可能不适用于所有的项目,即使理论上听上去很棒,但是我可以肯定,我目前还没有在商业项目里尝试过这种方式。Yassal Sundman的博客上有一副图,是比较持续交付和持续部署的过程:
对于持续交付的工具我没有特别的个人偏好。最近我开始在使用AWS的CodePipeline(和AWS的CodeDeply类似)去自动化AWS云上的交付流程,我对此这个工具非常满意。
DNS 即Domain Name System(域名系统)的缩写,它是一种将ip地址转换成对应的主机名或将主机名转换成与之相对应ip地址的一种机制。其中通过域名解析出ip地址的叫做正向解析,通过ip地址解析出域名的叫做反向解析。下面对DNS的工作流程及原理进行简要说明
DNS的查询流程:需要解析服务的Client先查看本机的/etc/hosts;若无结果,则client查看本地的DNS缓存服务器;若无结果,则查找所属域的首选DNS服务器;若此时本地首选DNS服务器仍无法解析,则会想根域名服务器进行查询或选择转发解析请求。
DNS的查询规则:递归式查询,即client向支持递归查询的DNS Server发出解析请求,则自DNS服务器不论是自身直接解析还是无法解析想根发出请求,总会由其向client返回一个结果;迭代式查询,即接收client解析请求的DNS Server,若其能够解析则直接返回结果,若其不能解析将把解析请求交给其他DNS服务器,而不是自己亲自将解析过程完成。
所谓的“根”服务器:根服务器主要用来管理互联网的主目录,全世界只有13台。1个为主根服务器,放置在美国。其余12个均为辅根服务器,其中9个放置在美国,欧洲2个,位于英国和瑞典,亚洲1个,位于日本。所有根服务器均由美国政府授权的互联网域名与号码分配机构ICANN统一管理,负责全球互联网域名根服务器、域名体系和IP地址等的管理。
DNS记录的类型:
A:Address 域名向ip地址转换的记录;
PTR:Printer ip地址向域名转换的记录;
NS:代表域内的dns服务器;
MX:代表域内的邮件服务器;
CNAME:域名的别名;
SOA:start of authority用于标示域内主DNS服务器。
提供DNS服务的软件:BIND即Berkeley Internet Name Domain有加州大学伯克利分校研发是当今提供dns服务应用最广的软件。
下面让我们进入正题,以下内容包括:DNS的缓存服务器、主/从服务器、子域授权、转发以及视图的配置步骤。
DNS缓存服务器
Ps:为了更好的体会和理解dns的配置文件和域解析文件,作者在此只安装bind包,以手动编辑的方式生成这几个必须的文件。
1安装bind包
yum install bind
2创建住配置文件/etc/namedconf
options {
directory "/var/named"; #告知工作目录
};
zone “” IN {
type hint; #声明根域
file "namedca"; #根信息存放文件
};
zone "localhost" IN { #本地正解定义
type master; #类型为master
file "localhostzone"; #正解文件名
};
zone "00127in-addrarpa" IN { #本地反解定义
type master;
file "namedlocal"; #反解文件名
};
chown :named /etc/namedconf
#修改属组给named
3创建3个解析文件
namedca
dig -t NS > /var/named/namedca
#向跟服务器发起查询并重定向到目标文件
localhostzone
vim localhost zone
$TTL 86400
#默认的ttl值
@ IN SOA localhost adminlocalhost (
#主DNS服务器localhost
2011081601
#时间+序列号01
1H
#刷新时间:每隔多久来master查询更新
10M
#重试时间间隔
7D
&n
开发流程第一步:需求调研分析1相关系统分析员向用户初步了解需求,然后用word列出要开发的系统的大功能模块,每个大功能模块有哪些小功能模块,对于有些需求比较明确相关的界面时,在这一步里面可以初步定义好少量的界面
2系统分析员深入了解和分析需求,根据自己的经验和需求用WORD或相关的工具再做出一份文档系统的功能需求文档
这次的文档会清楚列出系统大致的大功能模块,大功能模块有哪些小功能模块,并且还列出相关的界面和界面功能
3系统分析员向用户再次确认需求
第二步:概要设计首先,开发者需要对软件系统进行概要设计,即系统设计
概要设计需要对软件系统的设计进行考虑,包括系统的基本处理流程、系统的组织结构、模块划分、功能分配、接口设计、运行设计、数据结构设计和出错处理设计等,为软件的详细设计提供基础
第三步:详细设计在概要设计的基础上,开发者需要进行软件系统的详细设计
在详细设计中,描述实现具体模块所涉及到的主要算法、数据结构、类的层次结构及调用关系,需要说明软件系统各个层次中的每一个程序(每个模块或子程序)的设计考虑,以便进行编码和测试
应当保证软件的需求完全分配给整个软件
详细设计应当足够详细,能够根据详细设计报告进行编码
第四步:编码在软件编码阶段,开发者根据《软件系统详细设计报告》中对数据结构、算法分析和模块实现等方面的设计要求,开始具体的编写程序工作,分别实现各模块的功能,从而实现对目标系统的功能、性能、接口、界面等方面的要求
在规范化的研发流程中,编码工作在整个项目流程里最多不会超过1/2,通常在1/3的时间,所谓磨刀不误砍柴功,设计过程完成的好,编码效率就会极大提高,编码时不同模块之间的进度协调和协作是最需要小心的,也许一个小模块的问题就可能影响了整体进度,让很多程序员因此被迫停下工作等待,这种问题在很多研发过程中都出现过
编码时的相互沟通和应急的解决手段都是相当重要的,对于程序员而言,bug永远存在,你必须永远面对这个问题,大名鼎鼎的微软,可曾有连续三个月不发补丁的时候吗?从来没有!第六步:软件交付准备在软件测试证明软件达到要求后,软件开发者应向用户提交开发的目标安装程序、数据库的数据字典、《用户安装手册》、《用户使用指南》、需求报告、设计报告、测试报告等双方合同约定的产物
《用户安装手册》应详细介绍安装软件对运行环境的要求、安装软件的定义和内容、在客户端、服务器端及中间件的具体安装步骤、安装后的系统配置
《用户使用指南》应包括软件各项功能的使用流程、 *** 作步骤、相应业务介绍、特殊提示和注意事项等方面的内容,在需要时还应举例说明
第七步:验收用户验收
软件维护1、软件数据库管理2、用户跟踪培训3、故障分析解决软件升级需求调整分析软件功能拓展优化系统报废处理软件不能适应业务发展新软件项目立项企业数据信息备份附注:软件工程师学习内容首先让我们来看一下软件工程师考试(高级)要求:(1)理解软件工程管理的概念和任务;(2)理解软件生存期过程;(3)理解软件工程标准;(4)掌握需求分析、测试、维护基本技术;(5)掌握软件度量、软件配置管理方法;(6)理解软件复用概念;(7)理解软件质量保证的手段;(8)理解软件项目对人员的需求;(9)理解软件知识产权的基本知识
配置SERV_U,搭建服务器FTP,基本步骤如下:
一:系统:服务器快云VPS,配置双核70G盘,4M独享带宽,自带云数据库。
二:环境和软件版本,windows 2003 server ,serv-u 6404
三:详细配置SERV_U步骤如下:
运行SERV_U程序,出现初始界面
2新建一个域:右键单击“域”,选择“新建域”
3设定域的IP地址:填上当前服务器的IP地址
4设置域的用户名:自己填写
5设置FTP的端口:一般都是21
6选择域存放位置:一般的数据量不是很大的话选择ini文件中,以上 *** 作就完成了建域 *** 作。完成如下图
四:开设FTP帐号
1右建“用户”,选择“新用户”
2输入用户名,输入密码
4设定文件存放位置
5设定用户的访问权限:根据实际需要要来控制,一般都是锁定用户在主目录,然后给予用户文件的“读取”“写入”“追加”“删除”和目录的“列表”“创建”“移除”权限等即可完成用户设置,FTP服务器架设完成。
一般网站需求的话租用服务器空间比较划算,你已经买了服务器的话系统基本上用WIN2003版本。另外加上一些软件楼上的介绍的还可以!
域名绑定的话在你申请域名后基本有个域名解析工具的,在你申请的网站上应该有,把该名的解析地址填上你服务器的IP来进行绑定目前国际域名的DNS必须在国际域名注册商处注册,国内域名的DNS必须在CNNIC注册,注册支持解析英文域名和中文域名的dns要分别注册:
(1)步骤:选择做为DNS后缀的域名-创建dns服务器---选择是在国际注册还是国内注册-申请--交付费用
(2)费用:约75元/个(一次性)
(3)条件:如果注册国际DNS服务器的,dns服务器的名称必须是在具有条件的公司注册的国际英文域名才能注册,有独立IP地址,DNS服务器域名前的前缀最好是dnsns等
提供DNS的是计算机,是安装了DNS服务器端软件的计算机。服务器端软件即可以是基于类Unix *** 作系统,也可以是基于Windows *** 作系统的。装好DNS服务器软件后,您就可以在您指定的位置创建区域文件了,所谓区域文件就是包含了此域中名字到IP地址解析记录的一个文件(如文件名可能是seebodcom这个文件的内容是这样的:
primary name server = dns2100okcom (主服务器的主机名是 dns2100okcom)
serial = 2007042913 (当前序列号是2007042913。这个序列号的作用是当辅域名服务器来copy时候这个文件时,如果号码增加了就copy)
refresh = 10800 (3 hours) (辅域名服务器每隔3小时查询一个主服务器)
retry = 3600 (1 hour) (当辅域名服务试图在主服务器上查询更时,而连接失败了,辅域名服务器每隔1小时访问主域名服务器)
expire = 604800 (7 days) (辅域名服务器在向主服务更新失败后,7天后删除seebodcom中的记录。)
default TTL = 3600 (1 hour) (缓存服务器保存记录的时间是1小时。也就是告诉202962095保存seebodcom域的解析记录为1小时)
>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)