葡京娱乐棋牌官网哪些用Docker计划Rails应用

近年在运转界有2个新生技巧docker越发火,在看了有关的牵线之后果断决定尝试一下用docker安顿1台服务器。进程中记录了弹指间全副操作的经过及连锁安插文件,分享给各位也爱追求才具风尚的次序猿们。

适用条件

服务器:阿里云 (双核 + 2GB 内存) Ubuntu 14.04
应用的stack: nginx + unicorn + mongodb

在Ali云上安装dockerengine

主干依照官方网站上的装置指南来做的。作者刚开端选取的是ubuntu管理的安装包,docker.io,
版本是 一.0.一,发现bug太多,后来重新安装了最新的本子
1.四.1。官方网址的安装包如同被墙了,用了网页最上面包车型地铁Yandex的镜像才把docker安装好。

启动docker的daemon程序

例行的情事下只供给实行上面包车型大巴授命就足以运维docker

$ sudo service docker start

只是在Ali云的ECS上报出无闲置IP的不当,百度了弹指间才找到消除方案,操作步骤如下:

打开/etc/network/interfaces,注释掉以下配置

# route del -net 172.16.0.0 netmask 255.240.0.0 dev eth0 

双重起动networking

$ sudo service networking restart

再一次开动docker

$ sudo service docker restart

测试一下docker是不是正规运转

$ docker info
Containers: 33
Images: 176
Storage Driver: aufs
 Root Dir: /var/lib/docker/aufs
 Dirs: 242
Execution Driver: native-0.2
Kernel Version: 3.13.0-32-generic
Operating System: Ubuntu 14.04.1 LTS
CPUs: 2
Total Memory: 3.859 GiB
Name: iZ256yal27dZ
ID: BQ3A:ZJIY:5EOM:JOTY:EROQ:7UI6:SB6P:QVBC:3FM5:DEMB:WBY2:ZDH6
WARNING: No swap limit support

启动nginx的container

在Ali云的机械上塑造以下文件夹,并创办相应的文本

dockers
└── nginx
    ├── Dockerfile
    └── config
        └── nginx-app.conf

注意:大家一时半刻先将与rails app有关的配备文件注释了

# Dockerfile for installing and running Nginx

# Select ubuntu as the base image
From registry.mirrors.aliyuncs.com/library/ubuntu:14.04

# Install nginx
RUN apt-get update
RUN apt-get install -y nginx
RUN echo "daemon off;" >> /etc/nginx/nginx.conf
# ADD config/nginx-app.conf /etc/nginx/sites-enabled/default

# Publish port 80
EXPOSE 80

# Start nginx when container starts
ENTRYPOINT /usr/sbin/nginx

# nginx-app.conf

# this can be any application server, not just Unicorn/Rainbows!
upstream rails-app {
  server app:8080 fail_timeout=0;
}

server {
  listen 80 default deferred; # for Linux

  client_max_body_size 4G;
  server_name _;

  keepalive_timeout 5;

  # path for static files
  root /webapps/app/public;

  try_files $uri/index.html $uri.html $uri @unicorn;

  location @unicorn {
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_redirect off;
    proxy_pass http://rails-app;
  }

  # Rails error pages
  error_page 500 502 503 504 /500.html;
  location = /500.html {
    root /webapps/app/public;
  }
}

下一场在nginx文件夹下,生成新的docker image,并运维nginx的container

$ docker build -t junhao/nginx .
$ docker run --name web -d -p 80:80 junhao/nginx

运行docker ps来检查一下container的运市价况

$ docker ps
CONTAINER ID        IMAGE                  COMMAND                CREATED             STATUS              PORTS                    NAMES
87ae87c89a78        junhao/nginx:latest    "/bin/sh -c /usr/sbi   5 days ago          Up 5 days           0.0.0.0:80->80/tcp       web

开垦浏览器,输入你的Ali云VM地点,应该就能看出“Welcome to
Nginx”的页面。阶段性成功,yay!

启动unicorn的container

先把rails
app上传到服务器上,在选拔根目录下创办那样多少个文本,Dockerfile,
.dockerignore, scripts/start-server.sh

# Dockerfile for a Rails application using Nginx and Unicorn

# Select ubuntu as the base image
From registry.mirrors.aliyuncs.com/library/ubuntu:14.04

RUN apt-get update -q
RUN apt-get install -qy curl

# Install rvm, ruby, bundler
RUN curl -sSL https://get.rvm.io | bash -s stable
RUN /bin/bash -l -c "rvm requirements"
RUN /bin/bash -l -c "rvm install 2.1.5"
RUN /bin/bash -l -c "gem install bundler --no-ri --no-rdoc"

# Copy the Gemfile and Gemfile.lock into the image. 
# Temporarily set the working directory to where they are. 
WORKDIR /tmp 
ADD ./Gemfile Gemfile
ADD ./Gemfile.lock Gemfile.lock
RUN /bin/bash -l -c "bundle install"

# Add rails project to project directory
ADD ./ /webapps/app

# set WORKDIR
WORKDIR /webapps/app

# bundle install
# RUN /bin/bash -l -c "bundle install"

# Add configuration files in repository to filesystem
ADD scripts/start-server.sh /usr/bin/start-server
RUN chmod +x /usr/bin/start-server

# Publish port 80
EXPOSE 8080

# Startup commands
ENTRYPOINT /usr/bin/start-server

# .dockerignore

# Ignore bundler config.
/.bundle

# Ignore the default SQLite database.
/db

# Ignore all logfiles and tempfiles.
/log
/tmp

# Gemfile.lock

# Redis
dump.rdb

注意:小编有二个unicorn的配置文件在config文件夹下,未有用配备文件的急需修改start-server.sh的最后一行命令

#!/bin/bash

cd /webapps/app
source /etc/profile.d/rvm.sh
mkdir -p /webapps/shared/pids
mkdir -p /webapps/shared/log
cat /webapps/shared/pids/unicorn.pid
kill -QUIT `cat /webapps/shared/pids/unicorn.pid`
bundle exec unicorn -c config/unicorn.rb -E production -p 8080

下一场创造unicorn的docker image,并运维container

$ cd /webapps/app
$ docker build -t junhao/app .
$ docker run --name app -d -p 8080:8080 junhao/app

跟着,大家要对nginx的container做一些转移:把和rails
app相关的安顿加上回来,并再一次创设、运维nginx的container。

打开dockers/nginx/conf/nginx-app.conf,把下部那行设置加多回来

# ADD config/nginx-app.conf /etc/nginx/sites-enabled/default

下一场结束现行反革命的container,玉石俱焚建container。

$ cd dockers/nginx
$ docker stop web
$ docker build -t junhao/web .

下一步就是重启,在重启的时候我们要用到1个叫container
linking的技艺花招。仔细看一下nginx-app.conf,里面有那般1段代码:

upstream rails-app {
  server app:8080 fail_timeout=0;
}

这里的app:8080中的app指的是大家创制的unicorn
container。那么在nginx的container中,app表示的骨子里是unicorn
container在本机的地址映射。这些是索要大家在运维nginx
container的时候做特殊处理的,不然nginx
container无法获得相关音信。--link app:app纵然把app
container的音信传送给了web container。

$ docker run --name web --link app:app -d -p 80:80 junhao/nginx

现今开垦浏览器,试试张开三个不供给拜访数据库的页面。

配置MongodDB

本身用了MongoDB官方的配备服务MMS来保管MongoDB,所以并没有用docker。我们也得以品尝不一致的格局。在本机安装完MongoDB之后,在config/mongoid.yml中修改hosts的地址:- dockerhost:27000。这里的dockerhost指的是container运行的VM的地址。
这些地方大家能够在container运行时定义,由于从前运营时未尝定义这么些值,大家须要重启app
container。

$ docker stop app
$ docker build -t junhao/app .
$ docker run --name app --add-host=dockerhost:<enter your host address here> -d -p 8080:8080 junhao/app

然后重启一下web container

$ docker stop web
$ docker run --name web --link app:app -d -p 80:80 junhao/nginx

这么就马到功成啦!

发表评论

电子邮件地址不会被公开。 必填项已用*标注