Current location - Training Enrollment Network - Books and materials - Didi taxi use case analysis book
Didi taxi use case analysis book
What is the primary productivity in the Internet age? There is no doubt that it must be someone from R&D. Without R&D personnel code, even if the product manager puts forward many good ideas and designs a good draft, it is useless for the operation and maintenance personnel to repair all the network servers in the computer room. No code means no operating system, no hardware devices such as mobile phones and computer tablets, no middleware such as database message queues, and no software such as Taobao, Tik Tok, Alipay and Meituan Didi.

Therefore, in the Internet age, R&D talents are the most important talents. They can create a product from 0 to 1 If R&D personnel are not effective, they will often work overtime, often have accidents and repeat inefficient work. Therefore, for large Internet companies, it is very important to improve the productivity of R&D personnel and create R&D efficiency. Statistics show that the annual investment cost of Amazon and Ali in R&D accounts for 15% of the whole company's cost budget. So what is R&D efficiency? How to build it? How to think about it?

The process of software from development to online is probably requirements review > development > testing > pre-release > operation and maintenance. In the whole process, R&D personnel participate in the whole process from the requirements review stage to the launch. A large number of stages involved include developing code, writing unit test cases, writing automated test cases, packaging, deploying test environment, testing, deploying production environment and online. The tools used in this process include requirements management tools, code warehouse tools, packaging tools, deployment tools, testing tools and online tools. If each tool is scattered in different places and developed by different teams, R&D personnel need to go to different platforms to find these tools, learn to use them, and connect them all in series during the development process, which leads to R&D personnel unable to concentrate on business development. Therefore, building R&D efficiency means building sustainable delivery capacity.

The construction of continuous delivery capability is the idea of continuous integration, continuous delivery and continuous deployment. For continuous integration, when R&D has developed the code locally, it will continue to integrate into the main branch to let the team members know the latest modifications; For continuous delivery, after the code is merged into the main branch, it is continuously deployed in the test environment and delivered to the test or product or internal test users for acceptance testing; For continuous deployment, the modified content is continuously deployed to the production environment for users to use and verify the feasibility of the product.

In addition to developing its own continuous delivery capability, it is also necessary to make full use of cloud computing resources. In cloud computing, service mode, automation mode and elastic scaling mode are all basic skills. To run a program, it must rely on the server, database, operating system and middleware. Therefore, when using IAAS, PAAS and SAAS products provided by cloud vendors, it is necessary to abstract the development details more carefully, so that cloud vendors can be responsible for more underlying capacity building. When using cloud resources, you can realize automation through API calls, avoid manual input, and realize online operation and maintenance through elastic expansion.

For the consideration of R&D efficiency, we can consider demand delivery cycle, continuous release ability, delivery process quality and delivery quality. For the demand delivery cycle, it depends on how long it takes to go online and develop after the demand is put forward from the product. For continuous release ability, it depends on the number of releases per unit time and the time taken from code submission to online. The quality of the delivery process is how many automated tests and unit tests fail and how many bugs there are after the code is submitted. For the quality of delivery, it means how many problems there are per unit time after the product goes online, how long it takes to respond to online problems and how long it takes to solve them. By considering these four directions, we can measure the productivity of R&D personnel and make adjustments according to the actual situation.

Ali even said 2- 1- 1, instead of 2 1 1 in 985. The so-called 2 1 1 can meet 85% of the demand within a two-week delivery cycle.

Now we have entered the second half of the internet, and almost everything that can be thought of in the market has been realized. However, there are so many users and so much traffic. If you can't open source, you can only cut costs. It is also a new idea to improve the production efficiency of R&D team and reduce the cost of the whole enterprise through the construction of R&D efficiency. Now you understand why Didi Today Headlines and Ali Meituan are investing in R&D efficiency.

The construction of R&D efficiency should be sooner rather than later. From the early stage, we should lay a good technical foundation as much as possible, cultivate the standards of R&D teamwork, and avoid making up for the technical debts in the early stage when the user scale expands in the later stage. Now act quickly ~