Gabriel Sobrinho
2012-Jun-01 18:56 UTC
Transaction during all migrations instead of each migrations
Hey, What you think about using a transaction during the entire db:migrate instead of each migration? Currently if we deploy 10 migrations and the latest fails, the application may be down because the database was changed but one of these migrations have failed. Think worse, one of these migrations can''t be rollbacked so we can''t rollback the application to a good state without a human interaction. Using just one transaction will make rails more "high available" during deploys because the migrations only will be committed if everything is ok. Note that will apply only to postgresql because mysql do not support ddl transactions. What you think, guys? Cheers, Gabriel Sobrinho -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.
Prem Sichanugrist
2012-Jun-01 18:57 UTC
Re: Transaction during all migrations instead of each migrations
AFAIK I think Rails already has that enabled by default on Postgresql. I think MySQL doesn''t support DDL migration, so it''s not enabled. Aaron, amirite? -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.
Rodrigo Rosenfeld Rosas
2012-Jun-01 18:58 UTC
Re: Transaction during all migrations instead of each migrations
Em 01-06-2012 15:56, Gabriel Sobrinho escreveu:> Hey, > > What you think about using a transaction during the entire db:migrate instead of each migration?+1 -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.
Carlos Antonio da Silva
2012-Jun-18 12:46 UTC
Re: Transaction during all migrations instead of each migrations
Hello guys, just want to add that a new pull request was made adding this feature for supported databases: https://github.com/rails/rails/pull/6768 Please feel free to comment there. Cheers. On Fri, Jun 1, 2012 at 3:58 PM, Rodrigo Rosenfeld Rosas <rr.rosas@gmail.com>wrote:> Em 01-06-2012 15:56, Gabriel Sobrinho escreveu: > > Hey, >> >> What you think about using a transaction during the entire db:migrate >> instead of each migration? >> > > +1 > > > -- > You received this message because you are subscribed to the Google Groups > "Ruby on Rails: Core" group. > To post to this group, send email to rubyonrails-core@googlegroups.**com<rubyonrails-core@googlegroups.com> > . > To unsubscribe from this group, send email to > rubyonrails-core+unsubscribe@**googlegroups.com<rubyonrails-core%2Bunsubscribe@googlegroups.com> > . > For more options, visit this group at http://groups.google.com/** > group/rubyonrails-core?hl=en<http://groups.google.com/group/rubyonrails-core?hl=en> > . > >-- At. Carlos Antonio -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.
Simon de Boer
2012-Jun-19 16:15 UTC
Re: Transaction during all migrations instead of each migrations
I would be -1 on this sort of change. Changing the schema of a RDBS and deploying the dependent code should be performed with great care, the basic concept of each migration being "whole" change keeps things tidy. Giving any impression to a developer that enclosing a bunch of migrations as a transaction creates a highly-available deploy would be a disservice. There are so many other factors that go into making HA happen. Very few sites actually require anything close to HA, those that do are going to be putting all sorts of tools around their deploy process. The suggested code/schema upgrade should go this way, hopefully in as short a period as possible, with some sanity checks between each step: - Disable website - Dump current database - Migrate database - Update code - Re-enable website Lets say there were 10 migrations to do and #5 failed, being in the state that 1-4 have run is where you want to be. Now you can look at why #5 failed, fix it (check it in), and continue. This becomes particularly important if one of 1-4 were very long running statements, large import, index updating, etc. In these cases it becomes even more important that the website be shut down because the DB is going to be pinning its CPU and the user experience is going to suffer dramatically. If the change was implemented I would suggest that it be off by default in development, where the situation of wanting the first few migrations to take and then to begin debugging is the much more normal behaviour. Simon On Friday, 1 June 2012 14:56:32 UTC-4, Gabriel Sobrinho wrote:> > Hey, > > What you think about using a transaction during the entire db:migrate > instead of each migration? > > > Currently if we deploy 10 migrations and the latest fails, the application > may be down because the database was changed but one of these migrations > have failed. > > Think worse, one of these migrations can''t be rollbacked so we can''t > rollback the application to a good state without a human interaction. > > > Using just one transaction will make rails more "high available" during > deploys because the migrations only will be committed if everything is ok. > > Note that will apply only to postgresql because mysql do not support ddl > transactions. > > > What you think, guys? > > Cheers, > > Gabriel Sobrinho > >-- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To view this discussion on the web visit https://groups.google.com/d/msg/rubyonrails-core/-/B65FEZnJn9EJ. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.
Carlos Antonio da Silva
2012-Jun-19 16:22 UTC
Re: Re: Transaction during all migrations instead of each migrations
Hey Simon, thanks for your comments. Would you mind "copying & pasting" them to the issue I linked before? This way others can see it there while checking the related pull request, to decide whether or not the feature should be in. Thanks! -- At. Carlos Antonio On Tuesday, June 19, 2012 at 1:15 PM, Simon de Boer wrote:> I would be -1 on this sort of change. > > Changing the schema of a RDBS and deploying the dependent code should be performed with great care, the basic concept of each migration being "whole" change keeps things tidy. Giving any impression to a developer that enclosing a bunch of migrations as a transaction creates a highly-available deploy would be a disservice. There are so many other factors that go into making HA happen. Very few sites actually require anything close to HA, those that do are going to be putting all sorts of tools around their deploy process. > > The suggested code/schema upgrade should go this way, hopefully in as short a period as possible, with some sanity checks between each step: > Disable website > Dump current database > Migrate database > Update code > Re-enable website > > > > Lets say there were 10 migrations to do and #5 failed, being in the state that 1-4 have run is where you want to be. Now you can look at why #5 failed, fix it (check it in), and continue. > > This becomes particularly important if one of 1-4 were very long running statements, large import, index updating, etc. In these cases it becomes even more important that the website be shut down because the DB is going to be pinning its CPU and the user experience is going to suffer dramatically. > > If the change was implemented I would suggest that it be off by default in development, where the situation of wanting the first few migrations to take and then to begin debugging is the much more normal behaviour. > > Simon > > > On Friday, 1 June 2012 14:56:32 UTC-4, Gabriel Sobrinho wrote: > > Hey, > > > > What you think about using a transaction during the entire db:migrate instead of each migration? > > > > > > Currently if we deploy 10 migrations and the latest fails, the application may be down because the database was changed but one of these migrations have failed. > > > > Think worse, one of these migrations can''t be rollbacked so we can''t rollback the application to a good state without a human interaction. > > > > > > Using just one transaction will make rails more "high available" during deploys because the migrations only will be committed if everything is ok. > > > > Note that will apply only to postgresql because mysql do not support ddl transactions. > > > > > > What you think, guys? > > > > Cheers, > > > > Gabriel Sobrinho > > > -- > You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. > To view this discussion on the web visit https://groups.google.com/d/msg/rubyonrails-core/-/B65FEZnJn9EJ. > To post to this group, send email to rubyonrails-core@googlegroups.com (mailto:rubyonrails-core@googlegroups.com). > To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com (mailto:rubyonrails-core+unsubscribe@googlegroups.com). > For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.-- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Core" group. To post to this group, send email to rubyonrails-core@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-core+unsubscribe@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-core?hl=en.