Renderにデプロイしたい
ここに実現したいことを箇条書きで書いてください。
- エラーを解消し、デプロイする
前提
ruby 2.6.5
Rails 6.0.6.1
オリジナルアプリを作っています。
deviseでユーザ管理して外出、帰宅時にチェックして動向確認する機能を実装中に以下のエラーメッセージが発生しました。
途中何度かデプロイし成功していましたが、急にできなくなってしまいました。
ローカル環境では、問題なく動いています。
発生している問題・エラーメッセージ
rake aborted! StandardError: An error has occurred, this and all later migrations canceled: PG::DuplicateTable: ERROR: relation "users" already exists
bin/rails
#!/usr/bin/env ruby
begin
load File.expand_path('../spring', FILE)
rescue LoadError => e
raise unless e.message.include?('spring')
end
APP_PATH = File.expand_path('../config/application', dir)
require_relative '../config/boot'
require 'rails/commands'
20230719171121_create_genres.rb
class CreateGenres < ActiveRecord::Migration[6.0]
def change
create_table :genres do |t|
t.timestamps end
end
end
20230712053718_create_situations.rb
class CreateSituations < ActiveRecord::Migration[6.0]
def change
create_table :situations do |t|
t.timestamps #t.boolean :out, null: false, default: false t.string :purpose t.integer :genre_id, null: false t.references :user, null: false , foreign_key: true end
end
end
20230711033212_devise_create_users.rb
frozen_string_literal: true
class DeviseCreateUsers < ActiveRecord::Migration[6.0]
def change
create_table :users do |t|
## Database authenticatable
t.string :email, null: false, default: ""
t.string :encrypted_password, null: false, default: ""
t.string :nickname, null: false ## Recoverable t.string :reset_password_token t.datetime :reset_password_sent_at ## Rememberable t.datetime :remember_created_at ## Trackable # t.integer :sign_in_count, default: 0, null: false # t.datetime :current_sign_in_at # t.datetime :last_sign_in_at # t.string :current_sign_in_ip # t.string :last_sign_in_ip ## Confirmable # t.string :confirmation_token # t.datetime :confirmed_at # t.datetime :confirmation_sent_at # t.string :unconfirmed_email # Only if using reconfirmable ## Lockable # t.integer :failed_attempts, default: 0, null: false # Only if lock strategy is :failed_attempts # t.string :unlock_token # Only if unlock strategy is :email or :both # t.datetime :locked_at t.timestamps null: false end add_index :users, :email, unique: true add_index :users, :reset_password_token, unique: true # add_index :users, :confirmation_token, unique: true # add_index :users, :unlock_token, unique: true
end
end
Gemfile
ruby
1source 'https://rubygems.org' 2git_source(:github) { |repo| "https://github.com/#{repo}.git" } 3 4ruby '2.6.5' 5 6# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' 7gem 'rails', '~> 6.0.0' 8# Use mysql as the database for Active Record 9gem 'mysql2', '>= 0.5.3' 10# Use Puma as the app server 11gem 'puma', '~> 3.11' 12# Use SCSS for stylesheets 13gem 'sass-rails', '~> 5' 14# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker 15gem 'webpacker', '~> 4.0' 16# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks 17gem 'turbolinks', '~> 5' 18# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder 19gem 'jbuilder', '~> 2.7' 20# Use Redis adapter to run Action Cable in production 21# gem 'redis', '~> 4.0' 22# Use Active Model has_secure_password 23# gem 'bcrypt', '~> 3.1.7' 24 25# Use Active Storage variant 26# gem 'image_processing', '~> 1.2' 27 28# Reduces boot times through caching; required in config/boot.rb 29gem 'bootsnap', '>= 1.4.2', require: false 30 31group :development, :test do 32 # Call 'byebug' anywhere in the code to stop execution and get a debugger console 33 gem 'byebug', platforms: [:mri, :mingw, :x64_mingw] 34 gem 'rspec-rails' 35 gem 'factory_bot_rails' 36 gem 'faker' 37end 38 39group :development do 40 # Access an interactive console on exception pages or by calling 'console' anywhere in the code. 41 gem 'web-console', '>= 3.3.0' 42 gem 'listen', '>= 3.0.5', '< 3.2' 43 # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring 44 gem 'spring' 45 gem 'spring-watcher-listen', '~> 2.0.0' 46 gem 'rubocop', require: false 47end 48 49group :test do 50 # Adds support for Capybara system testing and selenium driver 51 gem 'capybara', '>= 2.15' 52 gem 'selenium-webdriver' 53 # Easy installation and use of web drivers to run system tests with browsers 54 gem 'webdrivers' 55end 56 57# Windows does not include zoneinfo files, so bundle the tzinfo-data gem 58gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] 59 60gem 'pry-rails' 61 62# 本番環境(Render)のデータベース(PostgreSQL)を使用できるようGemを追加(このGemはデータベースがPostgreSQLの際に必要なGem) 63group :production do 64 gem 'pg' 65end 66 67gem 'devise' 68gem 'active_hash' 69 70gem 'net-http'
試したこと
上記エラー文は、usersというテーブルが既にあるのに、再度生成しようとしているために表示されるとのことから、まずはデータベースを確認しまそたが、一つしかなく重複してはいませんでした。念の為、
ruby
1rails db:migrate:reset
で作成し直しましたが、エラーは解消できませんでした。
上記手順で間違いなくuserテーブルは一つしかなくうまくいかないのは別の問題があるのかもと思いました。そこで、マイグレーションファイルを何度も修正(破棄、カラムの追加、訂正等)し、デプロイが成功したいた時のブランチとは違うブランチで実行しようとしているからエラーが出ると仮説を立てて、PostgreSQLに入って削除後にマイグレーションを実行しようとしましたが、コマンド
ruby
1DROP TABLE IF EXISTS users
を入力しても改行しかされずできませんでした。
必要となる資料があれば、教えていただければありがたいです。
大変わかりづらい説明で申し訳ありませんが、よろしくお願いします。

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。