rails 部署 nginx + passenger

转自 http://segmentfault.com/a/1190000002911605

使用passenger在Centos7部署nginx+Ruby on Rails

gameFu 372 6月16日 发布

  • 1 推荐
  • 4 收藏,929 浏览

passenger

passenger是一个能快速搭建web环境的工具,它能快速的将nginxpassenger部署到你的服务器中,是部署ruby环境就如同php环境那样简单快速,让人愉悦。下面我将使用这个工具将一个几乎空白的web服务器打造成一个高效的ruby服务器

centos7

centos7是最新的centos版本带来了一系列新特性,包括对Docker的支持和性能的提高,centos 6和 centos 7性能对比

安装ruby环境

首先下载rvm(ruby虚拟机)

curl -L get.rvm.io | bash -s stable

安装rvm

source /etc/profile.d/rvm.sh

安装ruby(请选择官网上最新的版本,使用ruby就要一直坚定的使用其最新版本)

rvm install 2.2.1

安装完成后只要运行ruby -v有显示版本号就证明已经安装成功了

安装Passenger 和 Nginx

首先使用gem安装passenger

gem install passenger

由于nginx不支持动态的模块载入,所以要使用passenger来进行编译安装由passenger修改过的nginx

接下来安装nginx+passenger

passenger-install-nginx-module

运行了这个命令后,按照提示一步步安装

1.Yes: download, compile and install Nginx for me. (recommended)
The easiest way to get started. A stock Nginx 1.0.10 with Passenger
support, but with no other additional third party modules, will be
installed for you to a directory of your choice.

2.No: I want to customize my Nginx installation. (for advanced users)
Choose this if you want to compile Nginx with more third party modules
besides Passenger, or if you need to pass additional options to Nginx‘s
‘configure‘ script. This installer will 1) ask you for the location of
the Nginx source code, 2) run the ‘configure‘ script according to your
instructions, and 3) run ‘make install‘.
Whichever you choose, if you already have an existing Nginx configuration file,
then it will be preserved.

Enter your choice (1 or 2) or press Ctrl-C to abort:

当遇到这个选择时,建议选择1,1代表自动完整安装并配置nginx,2是代表根据自己需求定制nginx.

安装完成后系统会提示,nginx安装的目录,在centos7下默认是安装在/opt/nginx下,配置文件是默认在/opt/nginx/conf/nginx.conf

打开nginx.conf我们可以看到,passenger已经在nginx的配置文件上做了一点小配置

passenger_root /usr/local/rvm/gems/ruby-2.2.1/gems/passenger-5.0.10;
passenger_ruby /usr/local/rvm/gems/ruby-2.2.1/wrappers/ruby;

安装rails并初始化一个rails项目

使用gem安装rails

gem install rails

初始化一个rails项目

rails new sample_app

第一次初始化rails时一般会报出缺少gem的警告,此时只需要将rails的镜像改为淘宝镜像,详见http://ruby.taobao.org,然后执行

bundle install

当执行完毕后,一个rails项目的初始化就完成了

配置nginx

打开配置文件

vim /opt/nginx/conf/nginx.conf

这里给出一份最简单能运行的nginx.conf(注意:rails项目的目录是/opt/www)

{
  worker_processes  1;

  events {
      worker_connections  1024;
  }

  http {
      passenger_root /usr/local/rvm/gems/ruby-2.2.1/gems/passenger-5.0.10;
      passenger_ruby /usr/local/rvm/gems/ruby-2.2.1/wrappers/ruby;

      include       mime.types;
      default_type  application/octet-stream;

      sendfile        on;
      keepalive_timeout  65;
      server {
          #监听的端口
          listen       8080;
          server_name  127.0.0.1;
          #web根目录,一定是rails项目下的public
          root /var/www/sample_app/public/;
          #一定要记得将这个选项设置为on
          passenger_enabled on;
      }
  }

运行

sbin/nginx -t

如果没有报错,那说明配置成功了。那么已经万事大吉了吗?并没有!!

配置Centos7防火墙

Centos7后已经废弃了原来的iptables,改而使用firewall,默认情况下centos7系统不允许任何外来访问,就算你把firewall关了也没用,所以必须配置firewall

firewall-cmd --zone=public --add-port=8080/tcp --permanent

这个命令表示,允许外部访问8080端口,重载一下firewall的配置,就外部就能访问服务器的8080端口了

配置Rails的生产环境

配置完Centos7的防火墙后,访问rails程序时就会报出一个403的forbidden错误,仔细查看日志后,发现了问题了的原因

App 6361 stderr: [ 2015-06-16 11:27:24.1412 6376/0x00000001d35760(Worker 1) utils.rb:85 ]: *** Exception RuntimeError in Rack application object (Missing `secret_token` and `secret_key_base` for ‘production‘ environment, set these values in `config/secrets.yml`) (process 6376, thread 0x00000001d35760(Worker 1)):

这个错误表示Rails生产环境下的密钥没有配置。在nginx上跑rails一般只有在生产环境下才会使用,因而passenger默认下就是rails环境设置为生产环境,而rails初始化时默认没有对生产环境进行密钥配置。这时就需要我们自己去配置rails的密钥了

railsGemfile中加入

gem ‘dotenv-rails‘

然后运行

bundle install

安装完这个gem后就可以配置我们的生产环境密钥了

首先在sample_app目录下建立一个.env文件

然后运行

rake secret

这个命令会随机生成一个安全密钥,将这个密钥复制下来,然后在.env中添加

SECRET_KEY_BASE = 你的密钥

最后修改sample_app目录下的config/secrets.yml

development:
  secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>

test:
   secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>

production:
  secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>

这样一来密钥配置就完成了,重启nginx就能成功访问到rails项目了

分享

本文由 gameFu 创作,采用 知识共享署名 3.0 中国大陆许可协议 进行许可。
可自由转载、引用,但需署名作者且注明文章出处。

你可能感兴趣的文章

讨论区

简介清晰而实用,非常感谢!

#1 luke_lew · 8月19日 · 回复

时间: 2024-10-06 20:00:34

rails 部署 nginx + passenger的相关文章

使用Nginx+Passenger部署Ruby on Rails环境

本文介绍如何使用Nginx+Passenger来部署Ruby on Rails环境 本文使用的操作系统版本是CentOS6.5 1.安装ruby wget http://cache.ruby-lang.org/pub/ruby/ruby-2.0.0-p594.tar.gz mkdir -p /data/app_platform/ruby tar -zxvf ruby-2.0.0-p594.tar.gz cd ruby-2.0.0-p594 ./configure --prefix=/data/a

rails nginx passenger postgre 在ubuntu部署

rails 部署服务器 安装rvm 和 ruby sudo apt-get update sudo apt-get install curl \curl -sSL https://get.rvm.io | bash rvm use --install --default 2.1.2 安装postgreSQL sudo apt-get install postgresql libpq-dev postgresql-contrib sudo gem install pg --no-ri --no-r

nginx中error_page没有生效(nginx+passenger+rails)

应用部署方式为 nginx + passenger + rails 当我想要用nginx来默认处理400以上状态时,发现在rails返回respose之后,nginx不会再次执行error_page(官方介绍该directive在proxy返回response依然会执行),原因在于需要配置 passenger_intercept_errors on ; nginx.conf 中 server 配置: server { listen 3443 ssl; server_name XXX; ssl_c

Centos7 下面安装docker 部署Nginx

实验 环境 Centos 7 操作系统 安装docker yum install docker -y 查看docker 是否安装成功 docker -v Docker version 1.12.6, build 3a094bd/1.12.6 启动docker systemctl start docker 部署Nginx 获取基础镜像 docker pull nginx:1.10.3 查看 镜像 1.直接启动容器 docker run -d -p 8080:80 nginx:1.10.3 解释:

实战Puppet 集中配置管理系统(3)——Puppet dashboard与nginx+passenger安装配置

     本次实验内容紧接前两次实验,第一节内容主要介绍PUPPET的安装认证与资源定义,第二节主要写apache与nginx模块的应用,本次介绍Puppet dashboard与nginx+passenger 的安装,Puppet dashboard 是用以 web 方式管理 puppet.puppet 默认使用基于 Ruby 的WEBRickHTTP 来处理 HTTPS 请求,单个服务器使用Apache/Nginx+Passenger 替换掉 WEBRickHTTP,Passenger 是用

在Docker下部署Nginx

在Docker下部署Nginx 在Docker下部署Nginx,包括: 部署一个最简单的Nginx,可以通过80端口访问默认的网站 设置记录访问和错误日志的路径 设置静态网站的路径 通过proxy_pass将HTTP请求反向代理到nodejs Web App 设置HTTPS 如果你还没有安装Docker环境,可参考在Docker中运行Node.js的Web应用. 最简单的命令,让Nginx跑起来 命令如下: 1 $ sudo docker run -it -p 80:80 dockerfile/

linux企业常用服务---部署NGINX虚拟主机

部署前准备: 光盘配置本地yum源,修改yum配置文件 防火墙和selinux不做设置,关掉 IP地址设置为192.168.100.222 nginx已安装完成 1.安装安装并配置dns: 安装dns: [[email protected] ~]# yum install bind-utils bind bind-chroot 配置: [[email protected] ~]# cd /var/named/chroot/etc/ 配置主文件: [[email protected] etc]#

salt部署nginx

尝试使用saltstack部署nginx 搭建环境: master:192.168.25.135    centos 7 master:192.168.25.133    centos 7 master端目录:在/etc/salt/x下新建nginx目录用来存放源码包和配置文件,将源码包下载到这个目录, #mkdir  //etc/salt/nginx 查看目录: 编写salt 入口文件top.sls #cat top.sls base:  '*':    - nginx.install    

实战:ansible自动化部署nginx+keepalived+mysql负载均衡集群

一.目的 使用ansible自动化部署nginx+keepalived+mysql负载均衡集群. 二.拓扑规划 三.详细步骤 1.环境的搭建 (1).安装ansible,同时配置私钥免密码进行通信 [[email protected] ~]# ssh-keygen  -t rsa #-t表示使用的加密类型,其中rsa1表示version1版本,rsa.dsa.ecdsa的加密对于的是version2版本 Generating public/private rsa key pair. #这里询问你