当前位置: 首页 > 编程笔记 >

Linux系统上配置Nginx+Ruby on Rails+MySQL超攻略

殳俊
2023-03-14
本文向大家介绍Linux系统上配置Nginx+Ruby on Rails+MySQL超攻略,包括了Linux系统上配置Nginx+Ruby on Rails+MySQL超攻略的使用技巧和注意事项,需要的朋友参考一下

安装 RVM

通常使用 RVM 或 rbenv 来安装 Ruby,这里选用 RVM。

$ curl -sSL https://get.rvm.io | bash -s stable

载入 RVM :

$ source /home/libuchao/.rvm/scripts/rvm
$ rvm -v
rvm 1.25.12 (stable) by Wayne E. Seguin <wayneeseguin@gmail.com> ......

再执行以下命令:

$ type rvm
rvm is a function
......

说明 RVM 安装正确。
安装 Ruby

用 RVM 安装 Ruby

$ rvm install 2.1.0
$ rvm use 2.1.0 --default
$ ruby -v
ruby 2.1.0p0

国内服务器推荐替换 RubyGems 的到淘宝镜像

$ gem sources -r https://rubygems.org/
$ gem sources -a http://ruby.taobao.org/

否则安装 Gem 可能会非常非常慢。
安装 Rails

其实 Rails 也是一个 Gem

$ gem install rails --no-ri --no-rdoc -V
......
$ rails -v
Rails 4.0.2

至此,Rails 环境已经安装完成。
安装 MySQL

安装 Mysql 及相应的库文件:

$ sudo apt-get install mysql-server libmysqlclient-dev

然后进行一些安装方面的设置:

$ /usr/bin/mysql_secure_installation

创建相应的数据库,并为它新建一个权限小一些的用户:

mysql> CREATE DATABASE blix_production;
mysql> GRANT ALL PRIVILEGES ON blix_production.* TO blix@localhost IDENTIFIED BY "123456";
mysql> flush privileges;
mysql> exit

导入数据:

$ mysql -u blix -p blix_production < database.sql

安装 Nginx

Nginx 专门处理静态请求,并作为 Unicorn 的反向代理

编辑 /etc/apt/sources.list,末尾处添加以下两行

deb http://nginx.org/packages/ubuntu/ precise nginx
deb-src http://nginx.org/packages/ubuntu/ precise nginx

添加 Nginx 签名

$ wget http://nginx.org/keys/nginx_signing.key
$ sudo apt-key add nginx_signing.key

安装 Nginx

$ sudo apt-get update
$ sudo apt-get install nginx

安装完成后可以在浏览器中输入 http://server-ipaddress 查看是否安装正确。
配置 Unicorn

首先编译一下静态文件:

$ RAILS_ENV=production rake assets:clean
$ RAILS_ENV=production rake assets:precompile

Unicorn 配置参考:

worker_processes 2
timeout 30

APP_PATH = File.expand_path("../..", __FILE__)
working_directory APP_PATH

listen 8080, :tcp_nopush => true
listen "/tmp/unicorn.sock", :backlog => 64

stderr_path APP_PATH + "/log/unicorn.stderr.log"
stdout_path APP_PATH + "/log/unicorn.stdout.log"

pid APP_PATH + "/tmp/pids/unicorn.pid"

Unicorn 自启动脚本:

#!/bin/sh
set -e
# Example init script, this can be used with nginx, too,
# since nginx and unicorn accept the same signals

# Feel free to change any of the following variables for your app:
TIMEOUT=${TIMEOUT-60}
APP_ROOT=/home/libuchao/blix
APP_USER=libuchao
PID=$APP_ROOT/tmp/pids/unicorn.pid
CMD="unicorn_rails -D -E production -c $APP_ROOT/config/unicorn.rb"
action="$1"
set -u

old_pid="$PID.oldbin"

cd $APP_ROOT || exit 1

sig () {
    test -s "$PID" && kill -$1 `cat $PID`
}

oldsig () {
    test -s $old_pid && kill -$1 `cat $old_pid`
}

case $action in
start)
    sig 0 && echo >&2 "Already running" && exit 0
    su -c "$CMD" - $APP_USER
    ;;
stop)
    sig QUIT && exit 0
    echo >&2 "Not running"
    ;;
force-stop)
    sig TERM && exit 0
    echo >&2 "Not running"
    ;;
restart|reload)
    sig HUP && echo reloaded OK && exit 0
    echo >&2 "Couldn't reload, starting '$CMD' instead"
    su -c "$CMD" - $APP_USER
    ;;
upgrade)
    if sig USR2 && sleep 2 && sig 0 && oldsig QUIT
    then
        n=$TIMEOUT
        while test -s $old_pid && test $n -ge 0
        do
            printf '.' && sleep 1 && n=$(( $n - 1 ))
        done
        echo

        if test $n -lt 0 && test -s $old_pid
        then
            echo >&2 "$old_pid still exists after $TIMEOUT seconds"
            exit 1
        fi
        exit 0
    fi
    echo >&2 "Couldn't upgrade, starting '$CMD' instead"
    su -c "$CMD" - $APP_USER
    ;;
reopen-logs)
    sig USR1
    ;;
*)
    echo >&2 "Usage: $0 <start|stop|restart|upgrade|force-stop|reopen-logs>"
    exit 1
    ;;
esac

将这个 shell 在/etc/init.d/下做一个软连接,并使其开机自启动:

$ chmod +x /home/libuchao/blix/config/unicorn_init.sh
$ sudo ln -s /home/libuchao/blix/config/unicorn_init.sh /etc/init.d/unicorn
$ sudo update-rc.d unicorn defaults

启动 Unicorn:

$ service unicorn start

在浏览器中输入 http://server_ipaddress:8080 查看效果。
配置 Nginx

Nginx 配置参考:

upstream blix_backend {
  server unix:/tmp/unicorn.sock fail_timeout=0;
}

gzip on;
gzip_disable "msie6";
client_max_body_size 150m;

server {
  listen 80 default;
  return 403;
}

server {
  listen 80;
  server_name libuchao.com www.libuchao.com;

  root /home/libuchao/blix/public;

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

  location @httpapp {
    proxy_redirect   off;
    proxy_set_header  Host $host;
    proxy_set_header  X-Forwarded-Host $host;
    proxy_set_header  X-Forwarded-Server $host;
    proxy_set_header  X-Real-IP    $remote_addr;
    proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_buffering  on;

    proxy_pass http://blix_backend;
  }

  location ~ ^(/assets) {
    access_log off;
    expires   max;
  }
}

此时应该可以通过域名直接访问了。

 类似资料:
  • 本文向大家介绍在Mac系统上配置MySQL以及Squel Pro,包括了在Mac系统上配置MySQL以及Squel Pro的使用技巧和注意事项,需要的朋友参考一下 为了响应nodejs的大红大紫,最近应用其实现了一些server端的功能。数据库方面选择了老少咸宜的MySQL。今后肯定还会有相关应用需求。特此记录Mac系统下如何安装、配置MySQL及其管理工具Squel Pro。 为什么选择MYSQ

  • .NET 应用程序通常在 app.config(桌面应用程序)或 web.config(web应用程序)文件保存配置。 虽然,在 Web 应用程序用文件存储配置很普遍,但有时也需要在数据库表中存储一些配置,使其可用于网站群中的所有服务器,且只须在一个位置设置。 就像 IsolatedStorage 有应用程序(Application)、机器(Machine)、用户(User)等作用域,配置设置可能

  • 系统配置主要包括工单管理、系统、全局设置等内容。 日志审计 日志审计支持查看平台上的所有操作日志以及公有云的操作日志等。 工单 工单用于控制云联壹云平台资源的分配,支持对接第三方工单系统。 消息中心 云联壹云平台支持对接多种通知渠道接收系统消息等。 系统 用于查看消息中心和操作日志信息,并支持自定义企业信息、配置邮件短信服务器、设置公告以及常用系统等。 标签 标签用于标识虚拟机、裸金属、物理机等资

  • 输入输出路径,运行模式,部署模式等相关配置 配置项名称 默认值 配置项含义 action.type train Angel task的运行方式,目前主要有两种“train”和“predict”,分别表示模型训练和使用模型进行预测 angel.output.path.deleteonexist false 当输出路径存在时,是否直接覆盖 angel.train.data.path 无 训练数据所在路

  • 系统配置提供全局配置、子账号管理、事件告警、消息屏蔽、授权管理共5个维度的规则配置。 全局配置 子账号管理 事件告警 消息屏蔽 授权管理 全局配置 全局配置,用来配置IP黑名单、IP白名单、敏感词库、CDN服务器等对所有安装网防G01的服务器上的基础规则。 子账号管理 可对所管理的服务器进行分权、分级管理。创建不同权限的子账户对服务器进行管理,避免下级管理员权限不明确,分配职责不清的问题。 事件告

  • 本文向大家介绍linux系统中重置mysql的root密码,包括了linux系统中重置mysql的root密码的使用技巧和注意事项,需要的朋友参考一下 大家知道,我们经常在linux或者windows需要用到mysql数据库,但是我们经常会犯一种特别低级的小错误,小编也时常会犯的错误,突然就忘记了mysql的root的密码,之后就会带来一系列的麻烦,下面小编告诉大家怎么在linux操作系统重置ro