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

本文涉及的产品
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 本系列的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团队正在努力改进,相信不久的将来,更加如丝般顺滑的编译/测试功能将呈现在大家面前!

相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
目录
相关文章
|
6月前
|
Ruby
|
6月前
|
Ruby
|
6月前
|
JSON 数据格式 Ruby
|
6月前
|
调度 Ruby
|
6月前
|
存储 JSON 数据格式
|
6月前
|
Ruby
|
6月前
|
Ruby
|
6月前
|
人工智能 BI 计算机视觉
|
6月前
|
JSON Ubuntu Linux
|
6月前
|
调度 Ruby