开发者社区> billy.lb> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

云上持续交付实践系列5 --- Ruby 篇

简介: 本系列的ruby篇终于完成,欢迎ruby爱好者来使用我们的产品,同时欢迎拍砖!
+关注继续查看

本文会演示如何在CRP上编译并部署一个Ruby应用。

相关技术栈和用到的网站

本文将以ruby-china为例,使用CRP平台实现该项目的编译、测试和最终部署。

    1. Rails作为Web框架
    1. Postgres作为数据库存储
    1. Memcached作为分布式内存对象缓存系统
    1. Redis作为Key-Value数据库
    1. Elasticsearch则作为一个简单的搜索引擎

本次实践中为了更好地使用代码库服务,我们将ruby-china的代码迁移到了阿里云Code中,在Gemfile里面使用速度和稳定性更好的https://ruby.taobao.org代替了原官方源(国内使用,迫不得已,你懂的)。有兴趣的可以直接clone或者fork: 地址

部署环境

本例中,使用一台有公网IP且开放了22端口的ecs作为部署目标:

  • 120.xx.xx.137

CRP具备的能力和还需要做的准备工作

CRP在3月份针对不同的语言添加了相应的编译/测试插件,[CRP 3月产品更新日志]多语言持续交付的支持。针对ruby语言,CRP提供了2.1,2.2和2.3三个版本,并预装了rails框架。然而,对于Postgres、Memcached等,还需要我们手动安装。
CRP上配置工作流的基本操作,可以参考云上持续交付实践系列1 --- java 篇

编译/测试命令及相关配置

在编译/测试插件里面,我们将填入以下命令:

  • 安装所依赖的Postgres,Memcached,redis-server、elasticsearch(依赖于java)和nodejs(coffeejs需要)
apt-get update && apt-get install -y postgresql memcached redis-server
apt-get install -y openjdk-7-jre nodejs
curl -L -O https://download.elastic.co/elasticsearch/release/org/elasticsearch/distribution/tar/elasticsearch/2.3.2/elasticsearch-2.3.2.tar.gz
tar -xvf elasticsearch-2.3.2.tar.gz && ./elasticsearch-2.3.2/bin/elasticsearch -Des.insecure.allow.root=true -d
  • 后台运行刚刚安装的依赖
redis-server --daemonize yes
/etc/init.d/memcached start
/etc/init.d/elasticsearch start
sed -i 's/local   all             postgres                                peer/local   all             postgres                                trust/g' /etc/postgresql/9.3/main/pg_hba.conf
/etc/init.d/postgresql restart
  • 准备测试所需的数据库database及相应的配置文件
psql -c "CREATE USER \"root\" WITH CREATEDB PASSWORD 'root';" -U postgres
psql -c "create database \"ruby-china-test\" WITH OWNER=\"root\";" -U postgres
cp config/config.yml.default config/config.yml
cp config/database.yml.default config/database.yml
cp config/redis.yml.default config/redis.yml
cp config/elasticsearch.yml.default config/elasticsearch.yml
cp config/secrets.yml.default config/secrets.yml
sed -i "s/SETUP_REDIS_HOST/127.0.0.1/g" config/redis.yml
sed -i "s/SETUP_REDIS_PORT/6379/g" config/redis.yml
  • 安装项目依赖的库,执行数据库数据迁移,并执行测试
bundle install
RAILS_ENV=test bundle exec rake db:migrate
RAILS_ENV=test bundle exec rake

ruby-china作为相对成熟的ruby项目,其测试代码还是相当完备的,这也使得尽管我们采用了淘宝的ruby源,但编译/测试任务运行时间还是较长,实测时长为27分钟


_2016_05_05_8_21_55

部署命令及相关配置

首先在部署的目标机器上装好Ruby,Postgres等,同时创建出数据库并完成数据迁移。部署命令相对简单(因为本台机器已经安装了ruby 2.3.1,且用于其他场景,所以在启动前手动修改Gemfile中ruby 的版本):

cd /root/ruby-china
tar -xvf package.tgz
sed -i 's/2.3.0/2.3.1/g' Gemfile 
puma --daemon

最后我们可以看到ruby-china已经部署成功!


_2016_05_06_8_50_06


_2016_05_05_10_16_19

目前存在的问题

可以看到,因为目前提供的语言插件只是安装了语言相关的组建,跑集成测试需要的数据库、redis等都需要用户自主安装,一方面略显繁琐另一方面也延长了所需的时间。CRP团队正在努力改进,相信不久的将来,更加如丝般顺滑的编译/测试功能将呈现在大家面前!

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
开发新手最容易犯的50个 Ruby on Rails 错误(1)
本文最早发布与 JETRuby 博客,主要介绍了开发新手最容易犯的 Ruby 错误。文章系国内 ITOM 管理平台 OneAPM 编译呈现。
2730 0
Ruby On Rails学习笔记(3)——Rails程序由0到1
     正如Rails的理念一样,创建一个新的Rails应用程序的过程非常简单,下面就来看看如何从0到1建立一个全新的Rails应用程序。     1、启动InstantRails,打开其Rails应用程序管理器(Rails Application Manager):         2、创建...
697 0
Spring系列五:Spring怎么解决循环依赖
​  15.说说循环依赖? Spring循环依赖 Spring 循环依赖:简单说就是自己依赖自己,或者和别的Bean相互依赖。 鸡和蛋 只有单例的Bean才存在循环依赖的情况,原型(Prototype)情况下,Spring会直接抛出异常。原因很简单,AB循环依赖,A实例化的时候,发现依赖B,创建B实例,创建B的时候发现需要A,创建A1实例……无限套娃,直接把系统干垮。 Spring不支持基于构造器注入的循环依赖,但是假如AB循环依赖,如果一个是构造器注入,一个是setter注入呢? 看看几种情形: 循环依赖的几种情形 第四种可以而第五种不可以的原因是 Spring 在
44 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
基于 OpenResty 和 Node.js 的个推微服务实践
立即下载
个推微服务实践 基于OpenResty 和Node.js
立即下载
《基于阿里云的 Nodejs 稳定性实践》
立即下载