Apostrophe CMS db migrations

user1689933

What is the right way to deploy db from dev to prod, and to pull it back after some changes made in prod? Now I just keep the mongo dump in the repository, but I think there should be a more correct method.

Tom Boutell

Copying databases isn't an official built-in feature but I understand the workflow you are talking about. Around the time you hand the site over to your customer or make it live for the public, you'll usually want to push an existing database up to your production server. And later, you will often want to copy it down to your development computer.

There are sync-up and sync-down scripts here:

https://github.com/apostrophecms/apostrophe-boilerplate/tree/master/scripts

These scripts assume that you're using our Stagecoach deployment system, and that mongodb is running directly on the production server and will accept connections from itself (from localhost) without a password. These assumptions may not hold for you, so you may need to adapt these scripts to your needs.

The essential answer though, as you'll see in these short scripts, is (for this story I'm using the "sync down from production to development" use case):

  • Use mongodump to make a portable copy of the database on the remote, production server. rsync it down and use mongorestore to restore it.

    ssh $remoteSSH mongodump -d $dbName -o /tmp/mongodump.$dbName &&

    rsync -av $rsyncDestination:/tmp/mongodump.$dbName/ /tmp/mongodump.$dbName &&

    ssh $remoteSSH rm -rf /tmp/mongodump.$dbName &&

    mongorestore --noIndexRestore --drop -d $dbName /tmp/mongodump.$dbName/$dbName

    • Use rsync to copy public/uploads down as well.

    rsync -av --delete $rsyncDestination:/opt/stagecoach/apps/$projectName/uploads/ ./public/uploads

See the script for how the variables are initialized.

If you are hosting your production content in S3 then you could use the AWS CLI, in particular the aws s3 sync command.

Hope this is helpful!

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

TOP Ranking

  1. 1

    Failed to listen on localhost:8000 (reason: Cannot assign requested address)

  2. 2

    Loopback Error: connect ECONNREFUSED 127.0.0.1:3306 (MAMP)

  3. 3

    How to import an asset in swift using Bundle.main.path() in a react-native native module

  4. 4

    pump.io port in URL

  5. 5

    Compiler error CS0246 (type or namespace not found) on using Ninject in ASP.NET vNext

  6. 6

    BigQuery - concatenate ignoring NULL

  7. 7

    ngClass error (Can't bind ngClass since it isn't a known property of div) in Angular 11.0.3

  8. 8

    ggplotly no applicable method for 'plotly_build' applied to an object of class "NULL" if statements

  9. 9

    Spring Boot JPA PostgreSQL Web App - Internal Authentication Error

  10. 10

    How to remove the extra space from right in a webview?

  11. 11

    java.lang.NullPointerException: Cannot read the array length because "<local3>" is null

  12. 12

    Jquery different data trapped from direct mousedown event and simulation via $(this).trigger('mousedown');

  13. 13

    flutter: dropdown item programmatically unselect problem

  14. 14

    How to use merge windows unallocated space into Ubuntu using GParted?

  15. 15

    Change dd-mm-yyyy date format of dataframe date column to yyyy-mm-dd

  16. 16

    Nuget add packages gives access denied errors

  17. 17

    Svchost high CPU from Microsoft.BingWeather app errors

  18. 18

    Can't pre-populate phone number and message body in SMS link on iPhones when SMS app is not running in the background

  19. 19

    12.04.3--- Dconf Editor won't show com>canonical>unity option

  20. 20

    Any way to remove trailing whitespace *FOR EDITED* lines in Eclipse [for Java]?

  21. 21

    maven-jaxb2-plugin cannot generate classes due to two declarations cause a collision in ObjectFactory class

HotTag

Archive