One of the biggest challenges for development teams is having good visibility into production deployments. It is nearly impossible to track down application problems without access to critical data. Developers need access to a range of things, including application performance reporting, configurations, log files and more.
DevOps typically refers to topics around application deployment, server provisioning, and application monitoring. All three of these topics have potential security implications.
One of the best things about using continuous integration and deployment tools is their ability to create a repeatable and dependable way to deploy your application. How you deploy your application is scripted out and works the same way every single time.
From a DevOps security perspective, I see this as a huge upgrade over someone manually pushing code. It allows you to implement controls and security policies into your release process.
We are also starting to see new ways to add security scanning and testing into the build process. Products like Contrast Security are very interesting.
I’m sure you have heard of infrastructure as code. Similar to scripting application deployments, scripting server deployments allows you to document and control the process.
By scripting out server configurations, you can also easily implement specific company policies. Things like what ports are open, automatic updates, and more.
Deploying to the cloud also changes everything. At Stackify, how we deploy to Azure is part of our application itself. We don’t even think about server provisioning or server configurations. Microsoft Azure takes care of securing our servers, Windows Updates, and other common issues.
Scripting server configurations enable security experts to have better visibility and be part of the security conversations throughout the process.
When it comes to monitoring, and troubleshooting application problems, a DevOps approach solves a lot of security problems. The goal of DevOps is to create collaboration and improve the working relationships between development and operations. Monitoring is a perfect example of where a company can gain efficiency and even security with a DevOps mentality.
By giving developers access to the tools and more data, they no longer need administrator level access to production. You can also get more developers involved in the supporting their applications.
In the past, many organizations were forced to give developers administrator level permissions so they could support their apps. It was the only way for them to see if their apps were running, the health of them, and access basic things like log files. This, of course, causes a lot of security concerns.
What developers really need is access to lots of data. Having to log in to servers one by one is not a good solution if your app runs on multiple servers.
What developers really need to support their apps:
Developers need tools to aggregate this data together across multiple servers. Traditionally, developers have used multiple monitoring type tools. APM solutions, like Retrace, can help solve this by combining all the data into one place.
Providing your entire development team access to this data fits into the DevOps mentality and solves some security challenges.
By leveraging DevOps best practices, companies can increase the velocity at which they do releases while improving security. DevOps and security issues related to it will continue to be big topics.
Scripting out how you do deployments and configure servers gives you the ability to review and audit the configurations.
By giving developers access to the data and monitoring tools that they need, you can also limit administrator level access to production.
If you would like to be a guest contributor to the Stackify blog please reach out to [email protected]