Multitenant

 

Multitenant Hosting

One datacenter might want to host databases for multiple EZ2000 Plus Dental customers.  These databases may be on the same physical machine if care is taken to isolate the customers from having access to each other's data. With EZ2000 Plus Dental, it may be more accurate to refer to this as multi-instance rather than multi-tenant since different customers will never share the same database.

Virtual Machine
The current recommendation is for each customer to have a separate virtual machine (VM) with its own instance of MySQL and its own A to Z folders.  This setup will require purchasing a license of Microsoft Windows Server 2012 for each customer.  There can be some economies of scale compared to a traditional server because multiple customers can share the same hardware.  There are also some advantages in disaster recovery because a VM can be easily moved to a different physical server.

Connection Security
When clients connect to the server over the internet, the data must be encrypted.  The current recommendation is for the VM to be connected to the physical office by VPN.  There might be other options that we will list here in the future as we become aware of them.

Workstation Connections
As explained in Multiple Locations, the three workstation connection options are direct, RDP, or Middle Tier.  This still applies to multitenant scenarios, so the workstation connections must be considered as part of the complete solution.

Multiple Databases on One Server
This can be done. 

Store Images in Db
You would probably switch to Storing Images in Db instead of in the A to Z folders.  This is not strictly required, but prevents an obvious security problem.  If A to Z folders are used, they must be shared with everyone.  Storing images in the database eliminates this requirement and the complexity of managing those folders and permissions.  But be sure to carefully review the features that are not supported in that mode.

MySQL Security
This is actually quite simple to do for experienced database administrators.  A different MySQL User will need to be set up for each customer. If, for example, a customer database is called od_springfield_4932, then you must set up the MySQL user for that customer to have full access to od_springfield_4932*.  Notice the * wildcard character.  This allows EZ2000 Plus Dental to make backups of the database during the Update process.  The MySQL user must also have full privileges, including create table and drop table.

HL7 Service
For example, if the customers are bridging to eCW using HL7, multiple instances of the HL7 service will need to be set up, each with a different service name, exe folder, FreeDentalConfig.xml file, and database connection.  Different customers may be on different versions of EZ2000 Plus Dental.  Each HL7 service can be shut down independently as needed.

Prior to Version 12.4, the OD HL7 service could not run multiple instances, nor could it support multiple customers.  In spite of this known limitation, some datacenters attempted to set up multiple customers on a single server. In every single case, the HL7 folders were set up without enough attention to detail, and data between different customers was repeatedly mingled and databases were repeatedly corrupted.  This was obviously completely unacceptable, and this was our main objection to using a single server.

HL7 TCP/IP
You would probably use HL7 TCP/IP ports instead of HL7 folders.  This will eliminate any issues with sharing the HL7 folders.  This is functional, but should be considered a beta feature.

 

  EZ2000 Plus Dental Software 800-273-5033