Skip to main content
Solved

Multiple Tenants having Separate Databases


Forum|alt.badge.img+2

Is there any possibility to have one instance (one URL) that has two different tenants which have separate databases.

Requirements include,

1) Ability of having different databases for different tenants

2) We have created one sandbox with two tenants. In this license we can have 100 concurrent users. We need to create an additional instance in this same sandbox environment for development work.

Attached below is the structure of the configured sandbox,

 

 

If there are any workarounds to this issue, or if you could give an explanation on how data is kept separate and identified in two different tenants that would be greatly appreciated.

Best answer by Naveen Boga

Hi @TharidhiP, I concur with @praveenpo 

 To store the 2 different tenants data 2 databases are NOT required.
In Acumatica already providing inbuild feature that, each tenant will have unique ID, and based on this data will be stored in respective table with respective Company ID. Please find the screenshot for reference.

 

Hope this helps!!

View original
Did this topic help you find an answer to your question?

5 replies

praveenpo
Semi-Pro II
Forum|alt.badge.img+3
  • Semi-Pro II
  • 92 replies
  • July 19, 2021

@TharidhiP

Data is stored based on the Tenant.
CompanyID is the column in Database which indicates the Tenant ID.
 


 

 


Naveen Boga
Captain II
Forum|alt.badge.img+19
  • Captain II
  • 3377 replies
  • Answer
  • July 19, 2021

Hi @TharidhiP, I concur with @praveenpo 

 To store the 2 different tenants data 2 databases are NOT required.
In Acumatica already providing inbuild feature that, each tenant will have unique ID, and based on this data will be stored in respective table with respective Company ID. Please find the screenshot for reference.

 

Hope this helps!!


Forum|alt.badge.img+2
  • Author
  • Semi-Pro II
  • 95 replies
  • July 20, 2021

Thank you for your feedback!

 


Forum|alt.badge.img+9
  • Semi-Pro I
  • 714 replies
  • July 20, 2021

Hi @TharidhiP You can have 2 databases only when you have to separate site.

Thanks


Forum|alt.badge.img+4

Just supplementing good comments already made...

TABLES / COMPANYID

It is worth mentioning that not all tables have to include a CompanyID, although they almost always do.  If a table does not have a CompanyID, the data will be shared globally as there will be no CompanyID or CompanyMask to isolate the data or control how the data is shared.  This can be an asset or liability to customizations, so serious consideration is required when choosing to exclude this field and bypass the intended data isolation by tenant in the standard Acumatica design.

An example of this is SM.Version.  The DAC provides access to the Acumatica Version, but there is no CompanyID field in the database so the data can be seen by any tenant.

 

DEVELOPMENT

You reference sandbox for development and concerns about licensing.  If you ran both production and development on the same instance to share a license, customization projects by default drop DLL’s into the bin folder of the instance (shared by all tenants).  You run the risk of a developer overwriting tested production-ready code with a buggy development DLL.  Clearly, this would be bad!

You ALWAYS should do your development on an instance isolated from production, which means a different instance (and by extension a different tenant).  I’ve created endless loops a few times, and you do NOT want that hitting your production server.  I also prefer to keep my development database isolated from production. This allows for a simple rebuild of development if I start making a lot of database schema changes and decide I don’t like them.  We have instances for Dev, QA (where our sys admin works on permissions, business events, etc.) and Test (for our testing and documentation as well as pre-rollout training.)  The non-production instances share a database instance, but separate databases.  I’ve accidentally been in the wrong database more than once when manually cleaning out development tables and fields.  Likewise, you don’t want every developer to have direct access to production data as some of it may be sensitive according to the user’s position with the company, and a developer could query it for all sorts of info that is none of his/her business.  Just be mindful that a snapshot of production will contain all that data, so you must decide if you want the development instance(s) populated with all that data for a developer to snoop around.

The unlicensed install gives 2 concurrent users, so developers can work in their own development instances and use tools like GitHub to check-out code for changes or just merge their work manually with that of other developers.  In my case, we have our development instance running on a separate server, and I connect a drive letter to access the code but compile with visual studio on my PC.  This keeps me out of production data and significantly reduces my ability to affect the production environment accidentally.  I don’t share my development instance with anyone, so this simple approach works for me and ensures the production environment stays backed up even if I take my tablet home at night.


Reply


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings