What is DevOps?
DevOps is nothing but the combination of process and philosophies which contains four basic component culture, collaboration, tools, and practices. In return, this gives a good automated system and infrastructure which helps an organisation to deliver a quality and reliable build. The beauty of this culture is it enables a quality for organizations to better serve their customers and compete more effectively in the market and also add some promised benefits which include confidence and trust, faster software releases, ability to solve critical issues quickly, and better manage unplanned work.
DevOps is not a goal, but a never-ending process of continual improvement. -Jez Humble
Here are the key DevOps best practices that can help you for successful implementation of DevOps.
1. Understand Your Infrastructure need: Before building the infrastructure, spend some good time to understand the application and then align your goals to design your Infrastructure and this implementation of DevOps should be business-driven. While understanding infra, make sure you are capturing below components:
Cycle Time : Your software cycle needs to be defined in a generic way where you need to know the limitations, ability and if there is any down time then the exact time need to be noted.
Versioning Environments: While planning DevOps, always be ready for an alternative solution and versioning your environments helps you to roll out/back your plan. If you are having multiple module and tightly coupled then it requires a clean and neat plan to identify each and every patch and release.
- Infra as a code: When we say infra as a code it means a solution to addressing both needs – minimizing cycle time and versioning environments can be addressed by capturing and managing your Infrastructure as code. What you built should scalable for a long run.
2. Don’t jump start : There is no need to automate the complete cycle in one shot, always take a small entity and apply your philosophy and get this validated. Once you feel your POC is justified, start scaling up now and create a complete pipeline and define a process so anytime you can go back and check what all need to improve and where. All these small success will help you to get confidence internally in your team and builds a trust to stakeholder and your customers.
3. Continuous Integration and Continuous Deployment: If your team is not planning to implement this continuous integration and continuous delivery, then it is not fair with DevOps. Even I’ll say the beauty of DevOps is how frequently your team can deliver without disturbance and how much you are automated in this process. Let’s take a use case: You and your team members are working in an Agile team. In fact, there are multiple teams and multiple modules which are tightly coupled in which you are also involved. Every day you work on your stories and at the end of the day, you push your ‘private build’ of your work to verify if it builds and ‘deliver’ it to a team build server and same applies to other individuals. Which indicates you all ‘integrate’ your work in the common build area and do an ‘Integration Build’. Doing these integrations and builds to verify them on a regular, preferably daily basis, is what is known as Continuous Integration. Continuous Deployment doesn’t mean every change is deployed to production as soon as possible. It means every change is proven to be deployable at any time. What it takes is your all validated feature and build from CI and deploys them into the production environment. And here we can follow some of the practices. a) Maintain a Staging Environment that Emulates Production b) Always deploy in staging then move to production c) Automate Testing of Features and Nonfunctional Requirements d) Automatically fetch version-controlled development artifacts.
4. Define Performance and do benchmarking : Always do some performance testing and get a collective benchmarking report for the latest build shared by your team because this will only justify the quality of your build and the required infra as well.
5. Communicate and Collaborate : Collaboration and communication are the X-factors to help organisation grow and assess for DevOps. Collaboration with business and development team helps DevOps team to understand to design & define a culture. This helps to speed up the development, operations, and even other teams like marketing or sales, allowing all parts of the organization to align more closely with goals and projects.
6. Start Documenting : Document everything (All your work done) which you are spreading across the process and infrastructure and specially the reports, RCA’s (Root cause Analysis), change management. This helps you to go back and see if all issues we faced can be automated in the next cycle or other ways to handle them smoothly without interrupting your production environment.
7. Keep your eyes on cost burning: It has been experienced many time that if we don’t keep an eye on cloud bills it will keep increasing and will tend to be proportional to the growth of your business till the time you don’t look for optimization. Always do an audit in 2 months and evaluate your cloud computation to optimize. Do some experiment with infra because you should not spend not more than 5 to 10 % of cost for cloud infra if you are completely dependent. Tools you can try : Reoptimize, Cloudyn, Orbitera etc.
8. Secure your infra : If your team follows certain compliance from day 1 then there is very less chance to compromise with your data and this can be easily enabled by providing a setup where you can verify your vulnerabilities. Before moving your build to the production team you may need to follow the standard at an early stage of development by using configured tools like: SonarQube, VeraCode, Codacy, CodeClimate etc.
9. Tool Selection : Always select tools which all are compatible with rest of the tool chain you are planning to use. Why you should have to be so careful is because you have to capture each and every request capture. Once you are done with the tool selection, draft a tools metrics you are willing to capture or will be going to help you to debug. Start logging and monitoring them and have some clear definition for those logs so you can justify and determine that your processes are working as expected. Tools you can have a look : Nagios, Grafana, Pingdom, Monit, OpsGenie, Observium, Logstash etc.