Learn about microservices (part 1) : Learn about microservices
Learning microservices series (2) : Build services based on SpringBoot
Learning micro-service series (3) : Springboot + page front and back end separation and RESTFUL style interface writing
Learning microservice series (4) : Springboot service Gateway Gateway
Learning microservices series (5) : SpringBoot microservices use NACOS as the registry
Learning microservice series (vi) : SpringBoot microservice uses NACOS as the configuration center
Learning microservice series (7) : NacOS principle analysis
Learning microservices series (8) : Springboot services distributed transactions and solutions
Learning microservice series (nine) : Springboot service interface security authentication design
Learning microservice series (10) : Springboot microservice distributed asynchronous message communication
All Internet companies are now using quick steps to run the project iteration model of development, the project delivery speed, the update frequency is an important indicator to measure a firm’s ability to, if a traditional software companies to develop a system of six months or a year once faced in weeks or days of delivery for the unit that is likely to be eliminated. Such as a company to develop a software to begin with the market is very competitive, the product is also very advanced, but a year later software r&d just listed, so that have already lost the advantage, because the market hot spots have already changed, rival companies have already issued multiple versions and occupy the market. So we really need an agile and fast iterative process to help us quickly achieve feedback, validation, delivery and operation.
Then and now
Single architecture development online
Developers stay up late to make changes before traffic is restored. During this process, the developer must resist all kinds of pressures and concentrate on not miswriting a single line of command. The result can be unsatisfactory, with many failures. Developers blame o&M staff for writing wrong commands, o&M staff blame developers for leaving a lot of “pits”, testers blame testers for not testing enough, testers blame developers for “leaving pits” too much, time is too tight to find all.
- A lot of repetitive work is required
- Increased time to fix the problem
- Projects iterate slowly, often adding a small feature that requires an entire project to change
- Project quality is low
Here is a special image to show you:
Sustainable integrated development goes live
Service-oriented architecture + sustainable integration is like the whole car can be broken down into: chassis, body, cockpit, engine compartment, drive parts, etc. And each part is made up of many small pieces. The assembly process is also completed first: the chassis, body, cockpit, engine compartment, drive parts and so on are assembled, and then the whole vehicle is assembled with these large parts. The assembly of chassis, body, cockpit, engine compartment and drive part will not interfere with each other. Continuous integration process:
The benefits to us are as follows:
- Reduce lead times.
- Repetitive work in all phases of design, development, testing, release, operation and maintenance can be achieved through automated tools.
- Achieve standardization and normalization through tools to reduce the probability of error.
Traditional singleton versus distributed services
Continuous deployment pipeline
A deployment pipeline is defined in Continuous Delivery as an automated representation of the process by which software is transferred from a version control repository to the user’s hands. Every change to software goes through a complex process before it is released.
Cloud Native
Cloud Native is the best practice set of a series of architectures, R&D processes and team culture to support faster innovation speed, ultimate user experience, stable and reliable user service and efficient R&D efficiency. It requires a series of software and organizational, cultural, and technological changes. In fact, it can be understood that the collection supporting Cloud Native has three points.
From the perspective of r&d process, the automated R&D environment is the foundation of Cloud Native. Since the cloud is used as the infrastructure, it has the basic automation ability and can meet the requirements of self-service. The scale of communication personnel should be reduced as much as possible in the process, and the assistance of testing and operation and maintenance for development should be reduced as much as possible. It is better to have the full stack engineer complete the delivery alone and quickly. Containers make this easier by keeping environments consistent.
Micro service
Microservices architecture is an important part of Cloud Native. You can refer to the previous installments of this series for a detailed description of what microservices architecture benefits us and how we do it. I don’t want to say more about it here.
Self-service agile infrastructure
In fact, deployment, operations and maintenance are time – and energy-consuming and too important to go wrong. As mentioned earlier, the cornerstones of Cloud Native are microservices architecture, agile infrastructure, and common infrastructure services. What exactly does agile infrastructure offer us? Without operation and maintenance personnel, all automation, through container packaging environment, developers can directly package all software and dependencies directly into containers, packaged into images, production environment directly deployed images, through the container to achieve the consistency of development, testing, production environment. Let’s take a look at the related technologies mainly involved in Cloud Native:
- Container-based agile infrastructure. The significance of containers is that they provide us with a standardized operating environment that can encapsulate complex configurations in an image with little performance loss compared to physical machines. In the microservice architecture, in particular, there are a large number of services and frequent online services. To ensure high availability, lightweight isolation mechanisms are required. When traffic changes, fast scaling is required.
- Platformization based on common infrastructure services. Including monitoring service, cache service, message service, database service, load balancing, distributed coordination, distributed task scheduling and so on.
- Monitor alarm services. Monitoring alarms is always the most important topic in system o&M. To achieve fast delivery, efforts must be made on automated testing, grayscale publishing, alarm monitoring, fault location and repair. Among them, monitoring can make the system in a controllable situation. When a fault occurs, it can quickly find and alarm, which can effectively improve the availability.
- Distributed messaging middleware services. Decoupled through distributed messaging middleware. Synchronous invocation is a kind of strong dependency, while asynchronous invocation is a kind of weak dependency. In many scenarios, strong dependency will affect each other and decrease availability.
- Distributed cache services. We often use Redis as a cache middleware technology.
- Distributed task scheduling service. Distributed task scheduling is a common service, especially in large and complex distributed systems. The common distributed task scheduling framework in distributed architecture is xxL-Job.
It comes down to three things:
The ultimate goal achieved:
Continuous delivery gives us the following advantages:
- Reduced lead times
- Avoid repetitive tasks
- Reduce the probability of error
Achieving continuous integration requires the following:
- The code is subject to unified management
- Unit test coverage is high
- Automated functional and integration testing
- Code submission means inclusion in testing
- Function switch is realized through the configuration center
- Continuous integration tools for code detection, test coverage, code duplication, and more
Related technologies
- Code management (SCM) : GitHub, GitLab, BitBucket, SubVersion
- Build tools: Ant, Gradle, maven
- Automatic deployment: Capistrano and CodeDeploy
- Continuous integration (CI) : Bamboo, Hudson, Jenkins
- Configuration management: Ansible, Chef, Puppet, SaltStack, ScriptRock GuardRail
- Containers: Docker, LXC, third-party vendors such as AWS
- Choreography: Kubernetes, Core, Apache Mesos, DC/OS
- Service registration and discovery: Zookeeper, ETCD, Consul
- Scripting languages: Python, Ruby, shell
- Log management: ELK and Logentries
- System monitoring: Datadog, Graphite, Icinga, Nagios
- Performance monitoring: AppDynamics, New Relic, Splunk
- Pressure test: JMeter
- Message bus: ActiveMQ, SQS
- Application server: Tomcat and JBoss
- Web server: Apache, Nginx, IIS
- Database: MySQL, Oracle, PostgreSQL and other relational databases; Cassandra, mongoDB, Redis and other NoSQL databases
- Project Management (PM) : Jira, Asana, Taiga, Trello, Basecamp, Pivotal Tracker
In DevOps developers have to do something
- Continuous learning
- Understand the technology and tools used in the whole pipeline, such as Docker, K8S, Jenkins, Zabbix, etc
- Get used to Code Review
- Improve code quality