• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文会演示如何在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分钟



部署命令及相关配置

首先在部署的目标机器上装好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已经部署成功!






目前存在的问题

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


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
〖Ruby〗Ruby关键字发布时间:2022-07-14
下一篇:
DIYRubyCPU分析——PartI发布时间:2022-07-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap