Xây dựng hệ thống đo lường hiệu năng giao thông signal performance measurement

28 1 0
Xây dựng hệ thống đo lường hiệu năng giao thông signal performance measurement

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

ĐẠI HỌC QUỐC GIA HÀ NỘI ****** ****** BÁO CÁO THỰC TẬP PHÂN TÍCH THIẾT KẾ HỆ THỐNG THÔNG TIN ĐỀ TÀI XÂY DỰNG HỆ THỐNG ĐO LƯỜNG HIỆU NĂNG GIAO THÔNG SIGNAL PERFORMANCE MEASUREMENT Sinh viên thực hiện N[.]

ĐẠI HỌC QUỐC GIA HÀ NỘI ****** ****** BÁO CÁO THỰC TẬP PHÂN TÍCH THIẾT KẾ HỆ THỐNG THƠNG TIN ĐỀ TÀI XÂY DỰNG HỆ THỐNG ĐO LƯỜNG HIỆU NĂNG GIAO THÔNG SIGNAL PERFORMANCE MEASUREMENT Sinh viên thực hiện: Nguyễn Thế Hợp – 18001142 Người hướng dẫn: Nguyễn Bá Sơn: Trưởng khối giải pháp phần mềm doanh nghiệp Ths Nguyễn Tuấn Dũng: Giám đốc kỹ thuật Hà Nội, 21/05/2022 [Hà Nội – 20/05/2022] Mục lục Lời mở đầu Lời cảm ơn Phân tích hệ thống Mục đích Phạm vi Chức nghiệp vụ Bảng điều khiển Trình tạo cảnh báo Trình phân tích liệu Trình tạo báo cáo Yêu cầu hệ thống Yêu cầu giao diện Yêu cầu hệ thống Yêu cầu bảo mật Công nghệ sử dụng General Back-End Front-End Cloud Thiết kế hệ thống 10 Xây dựng biểu đồ Use case (Use case diagram) 10 Xây dựng biểu đồ (Sequence diagram) 11 Đăng nhập xác thực người dùng 11 Tạo cảnh báo 12 Tạo báo cáo 13 Phân tích liệu 14 Kiến trúc micro-service 14 Xác thực phân quyền 15 Role-Base Access Control 15 Phân quyền cho hệ thống micro-service 16 Cấu hình tập trung 17 Quy trình vận hành phát triển 19 Agile scrum 19 CI/CD 19 Tổng quan CI/CD 19 GitLab CI 20 Git Flow 21 Triển khai hệ thống 22 Kiến trúc mạng 22 Kiến trúc đám mây 22 Tài liệu tham khảo 26 Công việc kết 27 Công việc giao 27 Nhận xét người hướng dẫn 27 [Signal Performance Measurement] Lời mở đầu Ngày nay, với phát triển mạnh mẽ cơng nghệ thơng tin, máy tính đại làm nhiều việc thay sức lao động người với độ xác, tin cậy cao Các công nghệ phát triền phần mềm không ngừng cải tiến, mở rộng ngày tốt Các nhà phát triển ứng dụng có nhiều lựa chọn công cụ phát triển phần mềm khác để đời sản phẩm phần mềm có tính ứng dụng đời sống thực tiễn Xu hướng công nghệ tương lai, phần mềm di chuyển lên dịch vụ đám mây sử dụng đâu thơng qua mạng internet Do ngơn ngữ lập trình web phát huy mạnh tương lai Qua trình thực tập, em may mắn tham gia vào dự án thực tế công ty làm phần mềm liên quan đến quản lí hệ thống giao thơng Vì vậy, báo cáo nhằm tổng kết điều em học làm trình thực tập qua việc trình bày phân tích kiến trúc hệ thống dự án mà em làm Lời cảm ơn Với thực tập sinh bước vào môi trường làm việc, người dẫn dắt bước chân người đáng quý Em xin chân thành gửi lời cám ơn đến anh chị: - Anh Nguyễn Bá Sơn: Trưởng khối giải pháp phần mềm doanh nghiệp Chị Nguyễn Thị Doan: Trưởng khối kiểm thử nghiệp vụ phần mềm doanh nghiệp Ths Nguyễn Tuấn Dũng: Giám đốc kỹ thuật công ty cổ phần Eastgate software tận tình hướng dẫn em suốt trình thực tập làm việc cơng ty Khơng tránh nhiệm, cịn tình cảm giúp đỡ đến từ tận đáy lòng mà anh chị dành cho em Em xin chân thành cám ơn thầy khoa Tốn – Cơ – Tin học, thầy cô trường ĐH KHTN giảng dạy, trang bị cho em kiến thức tảng quý báu để em có kiến thức kinh nghiệm chuẩn bị cho công việc tương lai Trong q trình trực tập, cịn nhiều hạn chế kinh nghiệm kiến thức nên cịn nhiều điểm thiếu sót, em mong nhận ý kiến nhận xét phản hồi từ thầy bạn Phân tích hệ thống Mục đích Xây dựng tảng SPM (signal performance mesurement) dựa đám mây cho phép quan quản lý giao thông chuyên gia ngành giao thông để cải thiện hiệu nút giao thông trọng điểm, cho phép việc quản lý giao lộ tối ưu hóa Ngồi ra, hệ thống giản hóa việc quản lý giao lộ làm bật khu vực có vấn đề với khả nâng cao trình tạo logic cảnh báo, giúp chuyên gia giao thông ưu tiên hành động họ dễ dàng nhiều Phạm vi Hệ thống thiết kế tảng web đám mây, sử dụng đâu có mạng, khơng thời gian cài đặt phần mềm Chức nghiệp vụ Bảng điều khiển - Cung cấp cho chuyên gia giao thông cách nhanh chóng, tổng quan vấn đề giao lộ với ba thành phần chính: o Bản đồ nhiệt độ: Cung cấp nhìn tổng quan giao lộ có vấn đề o 10 nút giao thông hang đầu theo báo động: Hiển thị 10 giao lộ có nhiều cảnh báo o Mở cảnh báo theo danh mục: Các loại biểu đồ thể số lượng cảnh báo, tùy chỉnh theo danh mục cách dễ dàng Trình tạo cảnh báo - Cho phép người dùng cài đặt để tạo cảnh báo dựa điều kiện logic định Cho phép người dùng quản lí số theo cách mà họ muốn Trình phân tích liệu - Cho phép tạo phân tích liệu theo mục đích khác nhau: o Số lượng xe vượt đèn đỏ o Số lượng người qua đường - o Số lượng xe dừng chờ đèn đỏ o … Việc tạo phân tích chọn theo khoảng thời gian với giao lộ Có thể xuất liệu chia sẻ cách đơn giản lần nhấp chuột Có sử dụng thuật tốn học máy để cải thiện hiệu độ xác phân tích Trình tạo báo cáo - Cho phép người dùng tạo mẫu cài đặt thời gian nhận báo cáo tình trạng giao thơng Hỗ trợ việc cài đặt báo cáo vào khung thời gian định cách dễ dàng Tùy chỉnh nhận báo cáo kênh khác nhau: Thông báo trang web qua hòm thư điện tử Yêu cầu hệ thống Yêu cầu giao diện - Giao diện dễ sử dụng, thân thiện với người dùng - Hỗ trợ đa ngôn ngữ, nhiều chủ đề (theme) - Tương thích với nhiều kích thước hình loại thiết bị khác Yêu cầu hệ thống - Chạy ổn đinh, tính khả dụng vụ cao (high avaibility) - Hiệu suất hoạt động tốt - Dữ liệu phân tích hiệu quả, xác, sai số phạm vi cho phép - Hỗ trợ tự động tăng giảm tài nguyên hệ thống tùy theo lưu lượng truy cập để tối ưu chi phí Yêu cầu bảo mật - Hệ thống phải đảm bảo bảo mật thông tin người dùng, tránh bị lộ liệu - Tránh dạng công internet Công nghệ sử dụng General - Sonarqube platform mã nguồn mở giúp kiểm tra chất lượng code dự án, viết java hổ trợ nhiều ngơn ngữ khác nhau: PHP, Ruby, Java (bao gồm Android), C#, JavaScript, TypeScript, C/C++, Kotlin, Go, COBOL, PL/SQL, PL/I, ABAP, VB.NET, VB6, Python, RPG, Flex, Objective-C, Swift, CSS, HTML, XML hỗ trợ database để lưu trữ kết quả: MySql, Postgresql Các tiện ích chính: o Phát bug o Phát code smell, duplicate o Tính tốn độ bao phủ Unit test (Unit-test coverage) o Tính tốn technical debt o So sánh chất lượng code so với lần kiểm tra trước Back-End - - - Spring framework, Spring Boot, Spring Cloud, Spring Security, Spring data, làm web framework cho phía back-end Spring cung cấp mơ hình lập trình cấu hình tồn diện cho ứng dụng doanh nghiệp dựa Java đại - loại tảng triển khai Yếu tố Spring hỗ trợ sở hạ tầng cấp ứng dụng: Spring tập trung vào "hệ thống ống nước" ứng dụng doanh nghiệp để nhóm tập trung vào logic nghiệp vụ cấp ứng dụng, mà ràng buộc khơng cần thiết với mơi trường triển khai cụ thể JWT: Sử dụng làm xác thực người dùng Hibernate: ORM Redis cache: Nguồn mở, kho lưu trữ liệu nhớ hàng triệu nhà phát triển sử dụng làm sở liệu, nhớ cache, công cụ phát trực tuyến môi giới tin nhắn Apache Kafka: Apache Kafka tảng phát trực tuyến kiện phân tán mã nguồn mở hàng nghìn cơng ty sử dụng cho đường ống liệu hiệu suất cao, phân tích luồng, tích hợp liệu ứng dụng quan trọng Front-End - ReactJS: Thư viện JavaScript để xây dựng giao diện người dùng dựa thành phần - - MobX: Cho phép bạn quản lý trạng thái ứng dụng bên ngồi khung giao diện người dùng Điều làm cho mã bạn tách rời, di động Open street map (OSM) dự án hợp tác nhằm tạo sở liệu địa lý chỉnh sửa miễn phí giới Bootstrap: Bộ cơng cụ giao diện người dùng mạnh mẽ, mở rộng đóng gói nhiều tính Xây dựng tùy chỉnh với Sass, sử dụng hệ thống lưới thành phần dựng sẵn, đồng thời đưa dự án vào sống với plugin JavaScript mạnh mẽ Cloud - - - Gitlab: Từ lập kế hoạch đến sản xuất, tập hợp nhóm lại với ứng dụng Gửi mã bảo mật nhanh hơn, triển khai lên đám mây thúc đẩy kết kinh doanh Azure DevOps: Lập kế hoạch thông minh hơn, cộng tác tốt giao hàng nhanh với loạt dịch vụ nhà phát triển đại Docker: Loại bỏ tác vụ cấu hình lặp lặp lại, thông thường sử dụng suốt vòng đời phát triển để phát triển ứng dụng nhanh chóng, dễ dàng di động - máy tính để bàn đám mây Nền tảng tồn diện từ đầu đến cuối Docker bao gồm giao diện người dùng, CLI, API bảo mật thiết kế để hoạt động tồn vịng đời phân phối ứng dụng AWS: Tận dụng sở hạ tầng điện tốn tồn cầu mở rộng, đáng tin cậy an toàn Thiết kế hệ thống Xây dựng biểu đồ Use case (Use case diagram) Hình: Biểu đồ use case hệ thống 10 Phân tích liệu Hình: Biểu đồ cho tính phân tích liêuk Kiến trúc micro-service - 14 Sử dụng kiến trúc micro service cho hệ thống Chia nghiệp vụ thành phần tách biệt riêng độc lập với Hình: Kiến trúc microservice Xác thực phân quyền Role-Base Access Control - - 15 Có nhiều lựa chọn cho loại acess control: o Kiểm soát truy cập bắt buộc (MAC) o Kiểm soát truy cập tùy ý (DAC) o Kiểm soát truy cập dựa quyền (RBAC) o … Lựa chọn Role-Base access control cho hệ thống Hình: Role-Base access control Phân quyền cho hệ thống micro-service - - 16 Có nhiều cách tiếp cận cho việc xác thực phân quyền người dùng hệ thống microservice: o Xác thực phân quyền service o Xác thực phân quyền toàn cục (tại service cho tất service lại) o Xác thực toàn cục phân quyền chỗ Mỗi cách tiếp cận có ưu nhược điểm riêng Hệ thống chọn cách thứ 3: Xác thực tồn cục phân quyền chỗ Hình: Xác thực phân quyền người dùng Cấu hình tập trung - - 17 Cấu hình tập trung đề cập đến việc lưu trữ liệu dạng cấu hình vị trí chung mà máy tính khác truy cập Cấu hình tập trung đơn giản hóa việc quản lý liệu cấu hình chia sẻ cài đặt cấu hình máy chủ Một tính thú vị có Máy chủ cấu hình Spring Cloud tự động làm Bất thay đổi cam kết với kho lưu trữ git, cấu hình ứng dụng tự động làm Hình: Cấu hình tập trung sử dụng Spring cloud 18 Quy trình vận hành phát triển Agile scrum - - Một số mơ hình phát triển phần mềm như: o Mơ hình thác nước (water fall) o Mơ hình chữ V o Mơ hình Agile Scrum Áp dụng quy trình phát triển phần mềm agile scrum cho dự án Waterfall hoạt động tốt dự án hồn thành theo kiểu tuyến tính không cho phép quay lại giai đoạn trước Agile tập trung vào quy trình làm việc thích ứng, đồng thời Các phương pháp Agile chia dự án thành giai đoạn nhỏ hơn, lặp lặp lại Hình: Quy trình Agile Scrum CI/CD Tổng quan CI/CD - CI/CD đôi công việc, bao gồm CI (Continuous Integration) CD (Continuous Delivery), ý nói trình tích hợp (integration) thường xun, nhanh chóng code thường xuyên cập nhật phiên (delivery) 19 Hình: Quy trình CI/CD GitLab CI Hình: Gitlab CI/CD 20 ... bạn Phân tích hệ thống Mục đích Xây dựng tảng SPM (signal performance mesurement) dựa đám mây cho phép quan quản lý giao thông chuyên gia ngành giao thông để cải thiện hiệu nút giao thông trọng... Cloud Thiết kế hệ thống 10 Xây dựng biểu đồ Use case (Use case diagram) 10 Xây dựng biểu đồ (Sequence diagram) 11 Đăng... báo cáo Yêu cầu hệ thống Yêu cầu giao diện Yêu cầu hệ thống Yêu cầu bảo mật Công nghệ sử dụng General

Ngày đăng: 26/11/2022, 10:02

Tài liệu cùng người dùng

  • Đang cập nhật ...

Tài liệu liên quan