Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Welcome to Software Development on Codidact!

Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.

Comments on Best practices in setting up a development & production environments

Parent

Best practices in setting up a development & production environments

+6
−1

I am developing a web app that is tied to a database. My codebase is stored on a private GitLab instance. I would like to set up a workflow that would look something like this:

  1. I have a development environment where I am free to do anything with the app or the database. Once I made changes, I commit them to the GitLab instance.
  2. GitLab builds and tests the app as well as executes all necessary migrations for the database. Ideally this is first done in a test environment.
  3. If step 2 is successful, the code is deployed to the production server.

I would like to host this app on my local network, so no hosting solutions like AWS. I can get a reasonably powerful tower to act as the server.

However, when looking into it I found differing opinions on what this setup should look like, especially the differences between development and production databases. Therefore, I am curious if there are some general "best practices" that I can apply to this system.

Question

  • What would be a good way to set up a development database in a way that is still resembles the production one, but at the same time is easy to configure and work with?
History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.
Why should this post be closed?

3 comment threads

About step 3. I would definitely not have that as an automatic step. (1 comment)
Create the test DB based on the production one (1 comment)
Well, the difference is that the databases will be separate databases. Can you clarify what you mean ... (3 comments)
Post
+3
−0

As a baseline, here's what we did in my last company:

This approach

  • allows rapid evolution of the database schema during development (simply change your entity classes and restart)
  • requires no external database for development, which means you can develop without access to the company network, such as from home or on the train
  • each dev effectively gets their own database, allowing features can be developed in parallel without interference
  • since customer data is not used during development, development data need not be protected, allowing easy access without risking customer privacy
  • requires data generation logic to be written, but since this can be reused in unit tests, the added effort seemed low

It remained technically possible to load a dump of the production database into a development database instance, but we only used this if we really needed production data (for instance, to diagnose issues, run load tests, test schema migrations, and the like)

This approach was mandated by our data protection officer, and met initial resistance because people were used to work with dumps of production databases, but the ease of working with in-memory databases, and developing without network access (home office! yay!) soon won everyone over.

We did not go the full continuous delivery route because we did not trust our test coverage to automatically ensure the quality of deployments, and therefore wanted to give customers the opportunity to test the new version before deploying it to production. That said, it would have been easy to instruct our build server to create a docker image and tell kubernetes to update the deployment, and then flyway would have automatically applied the migration (if we hadn't used kubernetes, a little shell scripting would likely have done the job, too)

Of course, applying database migrations to live systems (some of which may not have updated yet) poses its own challenges. Alas, since our customers did not need that capability, I have little relevant experience to advise you in this, but I hear that breaking schema changes can often be split into backward-compatible increments.

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.

1 comment thread

Using InMemory database for testing - concerns (1 comment)
Using InMemory database for testing - concerns
Alexei‭ wrote almost 2 years ago

This is an interesting approach. I can't tell for Java, but for .NET (ASP.NET Core mostly) using an in-memory provider is not fashionable anymore due to various limitations and quirks. References include a Jimmy Bogard's article and the fact that MS is not adding features to the in-memory provider.

I am wondering if the Spring Boot ecosystem has similar drawbacks or if the in-memory database is more reliable.