Microsoft put out some great products, no really, they do. There are any number of applications and tools available for you to be able to do pretty much anything. One thing gaining popularity recently is System Center Configuration Manager (SCCM) which can be used to provide patch management, software distribution, inventory management, server provisioning and more.
Freddy & SCCM – a nightmare double feature
SCCM is great for businesses that are growing and need to maintain control over the devices used and maintain compliance across the enterprise.
This is all great. Businesses use it, businesses need it. SCCM has been designed to provide a relatively straightforward deployment that does not require any strong level of expertise. This is where SCCM falls down for me, as a DBA.
What is the problem?
SCCM does its own database management. It is a set it and forget it kind of thing. This is done so that an enterprise without SQL Server DBAs can go ahead and perform the deployment and management with any specialist knowledge.
This is all good and well, except when you do have a SQL Server DBA on staff; you have multiple deployments of SQL; and you like to perform consolidate servers wherever possible.
SCCM does some things which go completely against my wishes as a production DBA:
- Requires sysadmin on SQL Server to both install and run the application
- Requires Windows admin rights on the SQL Server
- Installs software on Windows to perform backups of SQL Server
- Adjusts SQL Server configuration settings (CLR & max text repl size)
- Enables the TRUSTWORTHY option for the SCCM database
- Sets the database recovery model to SIMPLE
Fortunately I found a lot of this information up front and decided that there was no way I was going to try and consolidate this database with any other in my environment. The security model is lacking in the worst fashion, and there is not much worse than taking all control away from a DBA.
I was glad that I made this choice as the SCCM decided to restart SQL as a part of the installation process. That would have caused a production outage if I had attempt to co-locate it with other low used databases.
Short recommendation
Being brief….if your sysadmins are looking to deploy SCCM in your environment, ask for a dedicated VM for SQL Server. Any attempt to consolidate this database will leave you open to massive security holes and production outages.