#解決したいこと
AWSデプロイした際にアプリケーションを正常に表示させたい。
#現状
AWS EC2インスタンス生成、Elastic IPの紐付けOK
ssh接続、環境変数設定、ポート設定等終わり等終わりました。
最後にunicornを立ち上げた際に正常に立ち上がっているのに、
Elastic IPアドレスのところにいくと、 「このサイトにアクセスできません」と表示されます。
#エラー内容
1.「このサイトにアクセスできません」と表示
2.less log/unicorn.stderr.logでログを確認すると
I, [2020-02-12T07:39:52.192806 #29197] INFO -- : Refreshing Gem list I, [2020-02-12T07:39:54.028466 #29197] INFO -- : listening on addr=/var/www/portfolio/tmp/sockets/unicorn.sock fd=11 E, [2020-02-12T07:39:54.032871 #29197] ERROR -- : Access denied for user 'root'@'localhost' (using password: YES) (Mysql2::Error::ConnectionError) /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/mysql2-0.5.3/lib/mysql2/client.rb:90:in `connect' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/mysql2-0.5.3/lib/mysql2/client.rb:90:in `initialize' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/mysql2_adapter.rb:25:in `new' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/mysql2_adapter.rb:25:in `mysql2_connection' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/abstract/connection_pool.rb:729:in `new_connection' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/abstract/connection_pool.rb:773:in `checkout_new_connection' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/abstract/connection_pool.rb:752:in `try_to_checkout_new_connection' /home/ec2-user/.rbenv/versions/2.5.1/lib/ruby/gems/2.5.0/gems/activerecord-5.0.7.2/lib/active_record/connection_adapters/abstract/connection_pool.rb:713:in `acquire_connection'
表示されます。しかし、unicornは立ち上がります。
#該当コード
database.yml
default: &default adapter: mysql2 pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %> timeout: 5000 development: <<: *default database: portfolio_development # 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: portfolio_test production: <<: *default database: portfolio username: root password: <%= ENV['DATABASE_PASSWORD'] %> socket: /var/lib/mysql/mysql.sock
unicorn.rb
app_path = File.expand_path('../../', __FILE__) #アプリケーションサーバの性能を決定する worker_processes 1 #アプリケーションの設置されているディレクトリを指定 working_directory app_path #Unicornの起動に必要なファイルの設置場所を指定 pid "#{app_path}/tmp/pids/unicorn.pid" #ポート番号を指定 listen "#{app_path}/tmp/sockets/unicorn.sock" #エラーのログを記録するファイルを指定 stderr_path "#{app_path}/log/unicorn.stderr.log" #通常のログを記録するファイルを指定 stdout_path "#{app_path}/log/unicorn.stdout.log" #Railsアプリケーションの応答を待つ上限時間を設定 timeout 60 #以下は応用的な設定なので説明は割愛 preload_app true GC.respond_to?(:copy_on_write_friendly=) && GC.copy_on_write_friendly = true check_client_connection false run_once = true before_fork do |server, worker| defined?(ActiveRecord::Base) && ActiveRecord::Base.connection.disconnect! if run_once run_once = false # prevent from firing again end old_pid = "#{server.config[:pid]}.oldbin" if File.exist?(old_pid) && server.pid != old_pid begin sig = (worker.nr + 1) >= server.worker_processes ? :QUIT : :TTOU Process.kill(sig, File.read(old_pid).to_i) rescue Errno::ENOENT, Errno::ESRCH => e logger.error e end end end after_fork do |_server, _worker| defined?(ActiveRecord::Base) && ActiveRecord::Base.establish_connection end
#追記
tail -f log/production.log
[2020-02-12T09:08:47.643964 #31674] DEBUG -- : (2.6ms) COMMIT D, [2020-02-12T09:08:47.644259 #31674] DEBUG -- : (0.1ms) SELECT RELEASE_LOCK('5854187921895701850') D, [2020-02-12T11:00:35.430459 #32275] DEBUG -- : (0.1ms) SELECT DATABASE() as db D, [2020-02-12T11:00:35.430791 #32275] DEBUG -- : (0.1ms) SELECT GET_LOCK('5854187921895701850', 0); D, [2020-02-12T11:00:35.438893 #32275] DEBUG -- : ActiveRecord::SchemaMigration Load (0.2ms) SELECT `schema_migrations`.* FROM `schema_migrations` D, [2020-02-12T11:00:35.443755 #32275] DEBUG -- : ActiveRecord::InternalMetadata Load (0.2ms) SELECT `ar_internal_metadata`.* FROM `ar_internal_metadata` WHERE `ar_internal_metadata`.`key` = 'environment' LIMIT 1 D, [2020-02-12T11:00:35.448459 #32275] DEBUG -- : (0.1ms) BEGIN D, [2020-02-12T11:00:35.449405 #32275] DEBUG -- : (0.1ms) COMMIT D, [2020-02-12T11:00:35.449702 #32275] DEBUG -- : (0.1ms) SELECT RELEASE_LOCK('5854187921895701850')
#追記2
Nginxを使用しなければ、http://<Elastic IP>:3000/でアクセスはできています。
宜しくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。