[Editor’s Note] I have been doing the basic work of the team for a long time, until recently, the results started to show, especially after reading the book “Continuous Delivery” last week, I summarized the work I had done and had some new insights.
【 3 days to burn brain type based on the actual combat training camp | CI/CD Docker Beijing station 】 this training around CI/CD of actual combat, based on the Docker concrete content includes: continuous integration and the continuous delivery (CI/CD) overview; Continuous integration system introduction; CI/CD practices on client and server side; Introducing CI and CD into the development process; Gitlab and CI and CD tools; The use of Gitlab CI and Drone and the sharing of practical experience.
In the past period of time, I have focused on some functions of Gitlab, from the most open code and application configuration management, then to CI system, improve code quality, and finally the complete continuous delivery process to improve team efficiency.
So I’m going to start with a book called Continuous Delivery.
Why continuous delivery
- Don’t release new features: You get the jitters every time you launch because you release too many features, don’t test them well, and the product is rushing to launch. In addition, according to past experience, the probability of problems from the release is the highest;
- Online accident treatment time is long: accident on each line, not positioning problem soon, if it is due to the colleagues online what to change, is more difficult to locate the problem, and after everyone may severely blamed the colleagues, in fact, he is innocent, there being no one to tell him what to do, what not to do, or what to do.
- The release cycle is too long: since every feature is released after it is fully developed, the release cycle can be too long if database changes or migrations are involved;
- Collaboration problems: For example, when a new employee joins the team, he or she is limited in all kinds of online permissions, especially the publishing permissions, which leads to a lot of difficulties in work. If he or she asks for help from other colleagues every time he or she posts, it will cause communication problems and further cause problems in collaboration. The other, often due to the habit of saying it’s going to be published and then being invisible to the rest of the world, is almost invisible to the rest of the world if something needs to be done online.
What can continuous delivery do
- Make the process of building, deploying, testing, and releasing software visible to all: so that people can learn the process, understand what others are doing, work in a disciplined process, and facilitate collaboration;
- Improve feedback and find problems earlier: In a complete pipeline, multiple “checkpoints” can be set up. In short, multiple testing sessions can be added to ensure code quality. The earlier problems are found, the lower the cost of fixing them.
- Deploy and release any version of software in any environment through a fully automated process: in Chen Hao Dashen’s article “From Gitlab mistakenly deleted database thought”, mentioned that: people control code, code control machine, in fact, continuous delivery can achieve this effect. And at the extreme end of the spectrum, if your cloud provider goes down, you can quickly rebuild your entire online system on another cloud provider (not that easy, of course).
Several principles of continuous delivery
- Create a repeatable and reliable process for software distribution: one-click release and rollback, so that if a release goes wrong, you’re almost sure it’s not the release script itself, because the script has been tested many times;
- Automate almost everything: manually publish and be long and unreliable, use automated scripts, save time, save effort;
- Put everything under version control: Use change management for easy auditing, keep all changes under control, and quickly locate problems.
- Commit and do the things that hurt you frequently: take small, fast steps to spread the pain and risk;
- Improve built in quality: The sooner you find a problem, the cheaper it is to fix it. When QA or users tell you there is a problem, the more expensive it is to fix it and the more work you don’t plan to do.
- “Done” means “released” : not a few percent is Done, which pushes you back to break up the task and release features into the build environment as quickly as possible, reducing product feedback time, improving competitiveness, and reducing risk;
- Delivery is the responsibility of each member: process standards, where everyone can participate in every part of the process, foster collaboration, and help newcomers adapt and improve;
- Continuous improvement: Evolving to improve the release process, which requires continuous improvement to increase throughput, production, and quality;
Practice of continuous delivery
In the current team continuous delivery process, our practices at each link are as follows:
- Submission: Unit test Mocha/AVA, and test coverage NYC;
- Compile and package: that is, package the Docker image and push it to Registry. Docker cluster has not been completely introduced at present, so the deployment process is omitted.
- Deployment documents: Use Ansible scripts to automatically deploy API documents and test coverage to a static web document server, this time you can directly branch the corresponding documents to the client development, but also directly check the test coverage, confirm and improve the unit test;
- Review: submit Merge Request, Code Review together;
- Deploy the application: after Review is approved, merge the code into the Master branch, and then manually click the button to deploy;
- Rollback: If the application has a problem, you can click the button to roll back;
It can be seen that the pre-release environment is mainly missing at present, which can only be achieved after the environment building script is perfected. At present, the company’s operation and maintenance team is separated from our development team, so we still need to make some efforts to achieve the desired effect.
So far I’ve managed the application configuration separately and the scripts for deployment have been implemented so that the continuous delivery process can get up and running very quickly. It can be said that application configuration management and automated deployment scripts are the prerequisite and foundation for a continuous delivery process.
The continuous delivery process, once perfected, can greatly improve the delivery ability of our development team and even force product and operations teams to increase their efficiency:
- For the product team, we can ask them to break down the requirements as finely as possible so that we can deploy them quickly once development is complete, so they can get feedback faster and improve the product’s trial-and-error capability.
- For the operations team, we have optimized the deployment process so that they can focus more on infrastructure maintenance and improvement, as well as facilitating collaboration and overall configuration management.
Reference
- about.gitlab.com/direction/
- About.gitlab.com/2016/08/26/…
- Github.com/everpeace/c…
- Docs.gitlab.com/ce/ci/envir…
- About.gitlab.com/2016/08/05/…
Original link:Practice and thinking of continuous delivery