我正在接管一个旧的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
我需要更改“主机”和“数据库”以及“用户名”,但我不知道在哪里更改这些内容。我们没有将database.yml保留在git repo中,因此我无法编辑该文件并进行提交。我需要找到生成database.yml文件的模板。这通常存储在哪里?什么gem通常用于生成database.yml文件?
答案 0 :(得分:1)
它可能不是宝石我的猜测是它在你app的共享文件夹中。
标准的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将拥有在服务器上找到该文件所需的信息。