Architecture of the actual combat camp module three operations
2022-08-04 02:35:00
【InfoQ】
The < div> module three requirements: < / div>< br>< div> write the outsourcing of the student management system architecture document < / div>< div> "requirements" < / div>< div> 1. & have spentBased on module 1 class 5 page P15 outsourcing candidate architecture student management system (see next page 1), 1 write complete architecture design document;< / div>< div> 2. & have spentAttention is not optional architecture document, but eventually fall to the ground of architecture detail design documents;< / div>< div> 3. & have spentWithout considering the database table design, the design because the table is made of the scheme design phase, not do architecture design phase;< / div>< div> "prompt" < / div>< div> 1. & have spentArchitecture design document is complete documentation (Word Sparrow or language) document, rather than & have spentPPT;< / div>< div> 2. & have spentArchitecture document covers 3 class 4 please refer to the content of the module, detailed architecture design reference module 3 lesson 6;< / div>< div> 3. & have spentOutsourcing business please refer to the student management system module 1 class 5 courseware;< / div>< div> 4. & have spentArchitecture document templates can be reference: architecture of actual combat battalion detailed architecture design document template < / div>< br>< br>< div> introduction < / div>< div> is the outsourcing of the student management system, this paper has a detailed architecture design document, used to guide the system of subsequent development, test, and operations.< / div>< div> & amp;nbsp;< / div>< div> revision history < / div>< img SRC="/ / img.inotgo.com/imagesLocal/202208/04/202208040225471562_4.png" Alt=null loading=lazy>< br>< div> vocabulary < / div>< div> 1) SpringBoot: Spring Boot is the Pivotal team to provide a new framework, the design purpose is used to simplify the initial set up of new Spring application and development process.< / div>< div> & amp;nbsp;< / div>< div> 2) Mysql main standby mode: in the actual production, in order to solve the single point of failure of Mysql, generally USES the "standby mode".< / div>< div> & amp;nbsp;< / div>< div> 3) subsystems: subsystem is a kind of model elements, it has a package and class semantics.The behavior of the subsystems are provided by it contains classes or other subsystems.Subsystem achieve one or more interfaces, the interface definition subsystem can perform the behavior.< / div>< div> & amp;nbsp;< / div>< div> 1. & have spentBusiness background < / div>< div> with the enlargement of the scale of the school, the increasing number of students have to deal with information is increased.Maintenance in the form of the manual for teachers not only spend a lot of teacher resources, processing efficiency is very low.Main problems are as follows: < / div>< div> 1, the student information data quantity is bigger, and it is not convenient for management.Many data statistical analysis work takes a long time.< / div>< div> 2, student information data after the establishment, maintenance, in the late update is not convenient, information is duplicate, low accuracy, seriously affect the efficiency of daily work.< / div>< div> 3 information, lack of students, and students' course selection, scores query etc. The systematic, standardization and automation.< / div>< div> based on the above background, the student management system, it is necessary to develop a set of outsourcing will systematically the student information data, convenient and unified management, maintenance, query.< / div>< div> & amp;nbsp;< / div>< div> 2. & have spentConstraints and restrictions on < / div>< div> 1, using Mysql database community edition < / div>< div> 2, the system must be completed in August 31, 2022 online < / div>< div> 3, project cost control within 200000 < / div>< div> 4, system need to support 1000 users < / div>< div> 5, the system must be deployed in school Intranet environment, from the Internet < / div>< div> 6, a total of only three developers < / div>< div> & amp;nbsp;< / div>< div> 3. & have spentOverall architecture < / div>< div> 3.1 & have spentArchitecture analysis < / div>< div> 3.1.1 & have spentHigh-performance < / div>< div> because the system only need to support 1000 users, no big problem in terms of performance.< / div>< div> 3.1.2 & have spentHigh availability < / div>< div> stop service outsourcing student management system for short periods of time, won't cause too big effect.But for data, must guarantee the high availability, student information data is an important asset, must not be lost.< / div>< div> 3.1.3 & have spentExtensible < / div>< div> for outsourcing student management system, the demand mainly includes the student management, curriculum management, examination management, rights management, business requirements and has certain complexity, need to consider the proper resolution, and encapsulation predictable demand changes.< / div>< div> 3.2.4 & have spentSecurity < / div>< div> with system deployment in school Intranet environment, therefore is relatively safe.< / div>< div> 3.2.5 & have spentCost < / div>< div> this project needs to support the number of users is less, and the performance requirements is not high, so the cost is relatively controllable.< / div>< div> & amp;nbsp;< / div>< div> to sum up, this system is important to guarantee the high availability of data, so the mysql database using the pattern design, in addition, the need to have certain extensibility, so the system into three subsystems, respectively are subsystems of students, curriculum, permissions, subsystem.< / div>< div> & amp;nbsp;< / div>< div> & amp;nbsp;< / div>< div> 3.2 & have spentOverall architecture < / div>< img SRC="/ / img.inotgo.com/imagesLocal/202208/04/202208040225471562_2.png" Alt=null loading=lazy>< br>< div> 1, use nginx implement reverse proxy back-end services.< / div>< div> 2, the system into three subsystems, respectively are subsystems of students, curriculum, permissions, subsystem.< / div>< div> 3, using mysql database, designed primarily for architecture, under normal circumstances, the back-end service access mysql host, when the host fails, switch to the standby.By binlog mysql data synchronization and backup, to ensure high availability of data.< / div>< div> & amp;nbsp;< / div>< div> 4. & have spentThe detailed design < / div>< div> 4.1 & have spentCore function < / div>< div> 4.4.1 & have spentStudent information query < / div>< img SRC="/ / img.inotgo.com/imagesLocal/202208/04/202208040225471562_0.png" Alt=null loading=lazy>< br>< div> & amp;nbsp;< / div>< div> 4.1.2 & have spentStudents online course < / div>< img SRC="/ / img.inotgo.com/imagesLocal/202208/04/202208040225471562_1.png" Alt=null loading=lazy>< br>< div> & amp;nbsp;< / div>< div> 4.1.3 & have spentTeacher ratings determine < / div>< img SRC="/ / img.inotgo.com/imagesLocal/202208/04/202208040225471562_3.png" Alt=null loading=lazy>< br>< div> & amp;nbsp;< / div>< div> 4.2 & have spentKey design < / div>< div> 1) student information data storage high availability < / div>< div> student information data stored in a mysql, master a mysql USES a framework, the main for data synchronization between service guarantee high availability of storage.If delay between main case, happened to mysql master server downtime data cannot recover, this part of the data will be lost permanently, this extreme condition is not do targeted design, because a small amount of data loss does not affect the usability of the system as a whole, you just need to collection data, high availability can guarantee full amount (mostly) data.At the same time, in view of the data synchronization delay, need to design the alarm mechanism, more than 30 seconds are not synchronized in time issued a warning, artificial solution can solve.< / div>< div> 2) system scalability < / div>< div> business needs is more complex, so the system is split into subsystems of student subsystem, curriculum, permissions, such split strength makes the complexity system internal and external balance.In addition, broken down into three subsystems, just the three of developers, each person is responsible for one, is conducive to improve the efficiency of research and development, a relatively reasonable.< / div>< div> & amp;nbsp;< / div>< div> 4.3 & have spentDesign specification < / div>< div> 1) mysql use the innodb storage engine < / div>< div> 2) three subsystems use Spring The Boot framework development < / div>< div> & amp;nbsp;< / div>< div> 5. & have spentQuality design < / div>< div> 5.1 & have spentSystem monitoring platform < / div>< div> design system monitoring platform, and monitoring the performance of the server, including CPU, memory, disk usage.Monitoring subsystem, the usability of the application server, monitor the usability of the database server, monitor the database server for synchronization indices such as delay of the Lord.< / div>< div> & amp;nbsp;< / div>< div> 5.2 & have spentCost < / div>< div> may consider using container deployment, less appropriate hardware server resources.< / div>< div> & amp;nbsp;< / div>< div> 6. & have spentEvolution planning < / div>< div> 6.1 & have spentComplete the demand analysis, August 1 - August 3 < / div>< div> 6.2 & have spentTo complete the overall architecture design, August 4-5 August < / div>< div> 6.3 & have spentComplete the detailed design, August 6-7 August < / div>< div> 6.4 & have spentDevelopment and self-test function, August 8 - August 16 < / div>< div> 6.5 & have spentFunctional test (three rounds), on August 25, August 17 - < / div>< div> 6.6 & have spentUsers uat test, August 26th - 30th August < / div>< div> 6.7 & have spentOnline system deployment, August 31 < / div>< div> 6.8 & have spentCommissioning, began on September 1 < / div>< div> & amp;nbsp;
原网站版权声明
本文为[InfoQ]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/216/202208040225471562.html