本文会演示如何在CRP上编译并部署一个Ruby应用。
相关技术栈和用到的网站
本文将以ruby-china为例,使用CRP平台实现该项目的编译、测试和最终部署。
-
- Rails作为Web框架
-
- Postgres作为数据库存储
-
- Memcached作为分布式内存对象缓存系统
-
- Redis作为Key-Value数据库
-
- 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团队正在努力改进,相信不久的将来,更加如丝般顺滑的编译/测试功能将呈现在大家面前!