Otto开发初探——微服务依赖管理新利器

【编者按】时下,Vagrant被DevOps软件开发商广泛作为开发阶段的本地软件开发环境,而在本文,CERT Division高级研究员介绍的Otto则是Vagrant开发团队Hashicorp的又一力作,由OneAPM工程师翻译。

以下为译文

在搭建运行在笔记本之上的开发环境时,Vagrant的表现非常优秀。不过在将程序迁往生产环境之时,在Vagrant的配置文件中所存储的配置环境Vagrantfile就不能直接用在生产服务器之上了。Otto在Vagrant基础上进行了有效的拓展,允许使用单个配置文件对开发与生产环境进行定义、配置与部署。

Otto在管理基于微服务的应用时,解决了服务依赖关系上的重大挑战。在微服务架构中,系统被拆分为许多独立可展开的部件,而不是作为单个庞大的应用。也就是说,我们必须部署许多小型应用,而不是单个的大型应用,这样一来管理复杂性也增加了。图一展示了有多个依赖的应用。要加速本地开发环境,开发人员必须了解所有的依赖,并配置相应的Vagrant环境。通过遍历依赖层次结构,构建适应所有依赖关系的Vagrant环境,Otto简化了基础设置配置。如果程序所依赖的服务有依赖,Otto会自动解决、获取与构建这些依赖。

图一:自动探测非相邻的依赖关系,并与Otto合并

扩展Otto以解支撑代理

Otto的入门指南包括工具的安装,构建简单Ruby web应用的开发环境,配置与部署AWS环境的方法。Otto底层使用了Vagrant,自动生成用来配置本地开发环境的Vagrantfile。生成的Vagrantfile是一个运行时构件,用户无法修改。只有创建自定义程序,并与主要的Vagrantfile合并,用户才能对Vagrantfile的生成产生影响。

根据入门指南,在配置本地开发环境时,由于所有出站流量必须通过公司的代理服务器,这里遭遇了瓶颈。所有在开发VM上的apt-get安装都失败了。根据下面这些步骤,可以设法利用Otto所产生的Vagrantfile来解决代理配置。

第一步:首先,创建一个名为otto-proxy的目录,包括定义vagrant-proxyconf 配置的Vagrantfile片段,参见图二。

if Vagrant.has_plugin?("vagrant-proxyconf")
   config.proxy.http     = "http://proxy.cmu.edu:8080"
   config.proxy.https    = "http://proxy.cmu.edu:8080"
   config.proxy.ftp      = "http://proxy.cmu.edu:8080"
   config.proxy.no_proxy = "localhost,127.0.0.1,localaddress"
end

图二:Vagrantfile片段的内容定义了vagrant-proxyconf 配置。

第二步:接下来,我创建了定义自定义程序的Otto Appfile,如图三所示,自定义部分定义了一个可合并的Vagrantfile片段。

application {
               name = "otto-proxy"
               type = "custom"
}
customization "dev-dep" {
    vagrantfile = "./Vagrantfile"
}

图三:这个appfile定义了一个简单的自定义程序,简单指出了配置开发环境时需要合并的Vagrantfile。

第三步:最终,修改了Otto入门指南中样例项目的appfile。修改后的appfile见图四。增加的代码以【】标出。

application {
               name = "otto-getting-started"
               type = "ruby"
  【dependency {
               source = "../otto-proxy"
  }】
}


project {
  name = "otto-getting-started"
  infrastructure = "otto-getting-started"
}


infrastructure "otto-getting-started" {
  type = "aws"
  flavor = "simple"

图四:修改后的otto-getting-started appfile,包括otto-proxy应用。

目前,在运行otto开发命令来配置本地开发环境时,Vagrant虚拟机上的软件包管理器通过公司代理服务器搭建了出站连接。

点击这里查看otto-proxy项目的源代码,点击这里查看修改后的otto-getting-started项目。

需要注意的是:Otto在现有的infrastructure-as-code工具之上增加了新一层抽象。但是通过appfile中自定义的依赖关系与自定义标签,如果必要的话,开发者可以控制底层工具的运作方式。Otto还处于初始阶段,目前是0.1版本,除了特殊情况,一般可能无法满足生产环境使用,不过很有希望成为自动化环境配置与部署的一线工具。

原文链接:Developing with Otto: A First Look(责编/仲浩 )

原文发布于微信公众号 - CSDN技术头条(CSDN_Tech)

原文发表时间:2015-10-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏MessageQueue

Apache Pulsar简介

"Pulsar is a distributed pub-sub messaging platform with a very flexible messagi...

5221
来自专栏Golang语言社区

Go的单元测试技巧

本文为社区粉丝原创投稿,再次感谢作者DrmagicE的分享,欢迎大家在评论区留言和作者讨论,同时也欢迎大家踊跃投稿,分享您的golang语言学习经验!投稿邮箱地...

1283
来自专栏玩转JavaEE

Git概述

一直以来想出一个Git的教程,去年写过一篇,后来没了下文,烂尾了。最近忙里偷闲,还是想把这个Git系列写一遍,这次争取写完。 本文我主要想先简单介绍下Git,然...

3595
来自专栏依乐祝

.NET Core实战项目之CMS 第四章 入门篇-Git的快速入门及实战演练

上篇文章我带着大家通过分析了一遍ASP.NET Core的源码了解了它的启动过程,然后又带着大家熟悉了一遍配置文件的加载方式,最后引出了依赖注入以及控制反转的概...

1100
来自专栏数据和云

122Architecture 全面解读 - 第一篇 全局解析+ADG+IM模块

Oracle自发布12.1之后,就一直声称要全面转云,在之后的三四年里,一直杳无音信,大家都在猜测,Oracle又在憋什么大招,果然,2017阳春三月,大招来了...

3759
来自专栏张绍文的专栏

Android N 混合编译与对热补丁影响解析

尽管当前Tinker还没有开启内测,我们会尽力在开源前做的更好。让Tinker无论在Dalvik还是Art上,都有着最好的表现,同时也恳请大家继续耐心等候我们。

1.1K1
来自专栏Golang语言社区

go实现西瓜视频花椒直播等平台智能答题

本文源码 https://github.com/Chain-Zhang/answer_ai 介绍 最近出了很多答题平分奖金的直播,只要能够连续答对12道题,就能...

41911
来自专栏A周立SpringCloud

微服务部署:蓝绿部署、滚动部署、灰度发布等部署方案对比与总结

在项目迭代的过程中,不可避免需要”上线“。上线对应着部署,或者重新部署;部署对应着修改;修改则意味着风险。 目前有很多用于部署的技术,有的简单,有的复杂;有的得...

7969
来自专栏北京马哥教育

推荐!国外程序员整理的系统管理员资源大全(一)

备份软件 Amanda -客户端-服务器模型备份工具 Bacula - 另一个客户端-服务器模型备份工具 Backupninja -轻量级,可扩展的元数据备份系...

50510
来自专栏FreeBuf

搭建dvwa环境学习从MySql注入到GetShell

是啊,在项目上的系统每周每个月经过几十遍的过滤,平时看到提交参数的地方也就sqlmap跑一跑,对于最基础的手工注入都没有扎实的学会,于是我决定要知道如何搭建环境...

1743

扫码关注云+社区

领取腾讯云代金券