我要接管一个旧的Rails项目。这是大型公司努力重构公司中许多旧技术的一部分。在众多更改中,我们将MySQL从5.1升级到5.7,并获得了一个功能更强大的新服务器来充当数据库服务器。现在,我想将Rails应用程序指向新服务器。
在我进行开发的Mac上,我有一个数据库文件,如下所示:
# MySQL. Versions 5.0+ are recommended.
#
# Install the MYSQL driver
# gem install mysql2
#
# Ensure the MySQL gem is defined in your Gemfile
# gem 'mysql2'
#
# And be sure to use new-style password hashing:
# http://dev.mysql.com/doc/refman/5.0/en/old-client.html
#
default: &default
adapter: mysql2
encoding: utf8
pool: 5
socket: /var/lib/mysql/mysql.sock
development:
<<: *default
database: wawa_onset_development
username: root
password:
# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
<<: *default
database: wawa_onset_test
username: root
password:
staging:
<<: *default
database: wawa_onset_stage
username: onset_stage
password: <%= ENV['STAGE_DATABASE_PASSWORD'] %>
preview:
<<: *default
database: wawa_onset_preview
username: onset_preview
password: <%= ENV['PREVIEW_DATABASE_PASSWORD'] %>
production:
<<: *default
database: wawa
username: onset_prod
password: <%= ENV['PRODUCTION_DATABASE_PASSWORD'] %>
要将我的代码部署到登台,请执行以下操作:
vagrant up
vagrant ssh
cap staging deploy
部署过程将创建一个如下所示的database.yml文件:
staging:
adapter: mysql2
encoding: utf8
pool: 5
socket: /var/lib/mysql/mysql.sock
database: wawa_onset_stage
username: onset_stage
password: <%= ENV['STAGE_DATABASE_PASSWORD'] %>
host: localhost
我需要更改“主机”,“数据库”和“用户名”,但是我不知道在哪里更改这些内容。我们不在git repo中保留database.yml,所以我无法编辑文件并提交。我需要找到生成database.yml文件的模板。这通常存储在哪里?通常使用哪些gem来生成database.yml文件?
它可能不是宝石。我的猜测是它位于您应用程序的共享文件夹中。
标准的Capistrano部署的应用程序具有以下结构
shared/
repo/
current -> /path/to/releases/20160226153309
releases/
您的database.yml可能在shared/config
文件夹中
和您的deploy.rb可能有类似的东西
set :linked_files, %w{config/database.yml config/secrets.yml}
但是您的deploy.rb将具有在服务器上定位文件所需的信息。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句