다른 테이블에 깨진 레코드가있는 레거시 데이터베이스에 Rails 3.2 앱을 구축하고 있습니다. 가장 골치 아픈 문제 중 하나는 잘못된 날짜가 포함되어 있다는 것입니다.정상적으로 "Mysql2 :: Error : 잘못된 날짜"를 ActiveRecord에서 처리하는 방법은 무엇입니까?
나는 코드를 작동시키기 위해 수동으로 한 번 수정 한 샌드 박스를 설정했습니다. 이제 배포시기입니다. 이러한 이유 때문에 매일 밤 샌드 박스가 다시 설정되고 실제 데이터베이스에서 복사되고 흰 족제비 색인이 다시 작성되며 마이그레이션이 다시 적용됩니다. 실시간 설치에 배포하기 전에 마지막 수정 사항을 얻기 위해 샌드 박스에 자주 배포하려고합니다.
레거시 PHP 응용 프로그램과이 새로운 Rails 응용 프로그램을 몇 주에서 몇 달 동안 병렬로 실행해야하므로 날짜를 한 번만 수정하면됩니다 (업데이트 :). 동시에 같은 데이터베이스). 이 작업을 자동화하는 방법이 필요합니다. 아마도 마이그레이션이나 레이크 작업을해야 할 것입니다.
하지만 문제는 ActiveRecord가 이러한 레코드를로드 할 때 질식하므로 레코드를 조사하고 날짜를 수정하는 방법이 없습니다.
두 번째 문제는 PHP 코드가 트랜잭션을 사용하지 않고 일부 코드 경로가 손상되어 고아와 깨진 테이블 제약 조건이 남아 있기 때문에 레거시 데이터베이스에 불일치가 있다는 것입니다. 나는 그것들을 처리 할 것이고, 그들 대부분은 이미 모델에서 돌보고있다. 첫 번째 문제는 날짜와 관련이 있습니다.
대체 어떻게 해결할 예정입니까? 어쩌면 예외를 가로 채고 일부 try-to-fix 코드를 실행하여 깨진 레코드가있는 레거시 데이터베이스를 마이그레이션 할 수있는 마법의 보석 일 수도 있습니다 ...
마이그레이션 경로는 MySQL과 3 개의 프로덕션 환경 (라이브 데이터베이스 , 동일한 데이터베이스로 스테이징, 매일 밤 데이터베이스 복제본을 재설정하는 샌드 박스). 우리는 하나의 단계에서 전체 레거시 애플리케이션을 대체 할 수 없기 때문에 일회성 데이터 매핑/마이그레이션을하지 않기로 결정했습니다 (약 50000 개의 기사가 담긴 CMS, 수 백 개의 주제, 이미지 및 다운로드가 포함 된 거대한 파일 데이터베이스, 약 10 개의 웹 사이트 지원 , 약 12 년간의 데이터 및 작업, 다양한 프로그래밍 기술의 까다로운 PHP 코드, 다른 마이그레이션 단계의 코드 중복, 파트너 사이트의 RSS 콘텐츠 가져 오기 등이 포함 된 기사/게시물을 해당 애플리케이션의 주제 기사 타임 라인으로 가져오고 훨씬 더 재미있는 것들 ...
첫 번째 단계는 일관된 관리자 및 게시 인터페이스를 얻기 위해 백엔드 응용 프로그램을 마이그레이션하는 것입니다. 레거시 프론트 엔드 응용 프로그램은 여전히 데이터베이스에 작성해야합니다 (방문자가 작성한 주석 및 기타 컨텐츠). 데이터베이스를 수정하는 프로세스는 정기적으로 무인으로 실행할 수 있어야합니다. .
우리는 이미 belongs_to 및 has_many에서 손상된 모델 종속성을 정상적으로 처리하는 수정 프로그램을 가지고 있습니다. Paperclip 통합은 모든 환상적인 파일 이름 매핑이 작동하도록 설계되었습니다. 그리고 airbrake gem은 redmine 설치시 모든 응용 프로그램 충돌을보고하므로 모든 왼쪽 변덕을 간략하게 살펴볼 수 있습니다.
레거시 응용 프로그램은 최신 MySQL 버전에서 작동하도록 이미 수정되었으며 현재 MySQL 데이터베이스 서버로 마이그레이션되었습니다.
아니, 실제로는되지 않습니다. Article.find (article_with_broken_date) 예외가 발생하므로 날짜를 수정하고 레코드를 다시 저장할 기회가 없습니다. – hurikhan77