政大機構典藏-National Chengchi University Institutional Repository(NCCUR):Item 140.119/152035
English  |  正體中文  |  简体中文  |  Post-Print筆數 : 27 |  Items with full text/Total items : 113869/144892 (79%)
Visitors : 51891576      Online Users : 485
RC Version 6.0 © Powered By DSPACE, MIT. Enhanced by NTU Library IR team.
Scope Tips:
  • please add "double quotation mark" for query phrases to get precise results
  • please goto advance search for comprehansive author search
  • Adv. Search
    HomeLoginUploadHelpAboutAdminister Goto mobile version
    Please use this identifier to cite or link to this item: https://nccur.lib.nccu.edu.tw/handle/140.119/152035


    Title: 基於數據驅動與模組化篩選機制的自適應HPA模組設計與實現
    Design and Implementation of an Adaptive HPA Module Based on Data-Driven and Modular Filtering Mechanisms
    Authors: 王盛泰
    Wang, Sheng-Tai
    Contributors: 張宏慶
    Jang, Hung-Chin
    王盛泰
    Wang, Sheng-Tai
    Keywords: 水平自動縮放
    微服務架構
    數據驅動
    雲端計算
    容器
    資源管理穩定性
    機器學習
    服務品質
    Horizontal Pod Autoscaler
    Microservice architecture
    Data-driven
    Cloud computing
    Containers
    Resource management stability
    Machine learning
    Quality of service
    Date: 2024
    Issue Date: 2024-07-01 12:30:14 (UTC+8)
    Abstract: 微服務是近年來,很受歡迎的應用程式部署方式,透過對應用程式解偶,使其成為功能獨立的微服務,就可以讓應用程式某些遇上需求瓶頸的微服務水平擴充,而不影響到其它微服務。透過利用Kubernetes平台與其相關的網路套件,我們可以自動化將服務請求導向至對應的微服務實體,並且依照特定規則與閾值進行自動化水平擴展(Horizontal Pod Autoscaler, HPA)。現有的HPA模組透過設定同服務容器的平均資源使用率與監控當前資源使用率,動態調整提供服務所需的容器數量。現有的HPA模組的演算法運算簡單並且實作容易,運作起來也有一定的績效,目前已被kubernetes平台使用多年。它能確保資源使用率,但它無法直接針對服務品質進行有系統的分析與並根據結果提出縮放決策。除此之外,當需求流量變化很大時,縮放週期短會導致頻繁新建或終止多個容器,造成系統不穩定與產生額外的系統負擔;相反地在週期長時,則會跟不上流量的變化,導致服務品質不穩定,甚至極端狀況可能會劇烈增加到無法接受的程度。本研究提出一種模組化的篩選方法,並依照此流程實作可以確保服務品質並維持穩定性的HPA模組。此模組又分為三個部分,第一部分透過預測模組確保可能的決策行為是否合乎服務品質;第二部分透過篩選模組,依照所需的策略遴選出最好的決策;第三部分透過穩定性模組,從最佳決策與穩定性決策中選出最終決策。研究結果顯示,提出的HPA模組在實驗的所有情況下,依然保持與現有算法接近的平均CPU使用率與平均反應時間,但大幅減少了運行期間所新建或刪除的容器數。最後本研究提出還可以進一步改善的部分,以及可以考量的實驗設計,以供未來從事相關研究的人參考。
    Microservices have become a popular application deployment method, allowing inde-pendent scaling of specific microservices without affecting others. Using the Kubernetes platform and related network packages, service requests can be automated to route to corre-sponding microservices and perform horizontal scaling. One specific implementation of horizontal scaling is the Horizontal Pod Autoscaler (HPA), which adjusts the number of service containers dynamically by setting and monitoring average resource usage. The ex-isting HPA module uses a simple algorithm that has been easy to implement and effective for years on Kubernetes. While it ensures resource utilization, it cannot systematically ana-lyze service quality or make scaling decisions based on these analyses. Frequent scaling due to demand fluctuations can cause system instability and extra burden, while slow scaling can't keep up with traffic changes, affecting service quality. This study proposes a modular filtering method to ensure service quality and stability in HPA, divided into three parts: a prediction module to ensure decisions comply with service quality, a filtering module to select the best strategy, and a stability module to choose the final decision. The proposed HPA module maintains CPU utilization and response times close to the existing algorithm but significantly reduces container creation and deletion during operation. Lastly, the study suggests areas for improvement and experimental design considerations for future research.
    Reference: [1] G. Liu, B. Huang, Z. Liang, M. Qin, H. Zhou and Z. Li, "Microservices: architecture, container, and challenges," 2020 IEEE 20th International Conference on Software Quality, Reliability and Security Companion (QRS-C), Macau, China, 2020, pp. 629-635, doi: 10.1109/QRS-C51114.2020.00107.
    [2] Z. Xiao, I. Wijegunaratne and X. Qiang, "Reflections on SOA and Microservices," 2016 4th International Conference on Enterprise Systems (ES), Melbourne, VIC, Australia, 2016, pp. 60-67, doi: 10.1109/ES.2016.14.
    [3] Oracle, "What is Cloud Native?," Oracle Cloud, https://www.oracle.com/cloud/cloud-native/what-is-cloud-native/.
    [4] T. Salah, M. J. Zemerly, C. Y. Yeun, M. Al-Qutayri and Y. Al-Hammadi, "Performance comparison between container-based and VM-based services," 2017 20th Conference on Innovations in Clouds, Internet and Networks (ICIN), Paris, France, 2017, pp. 185-190, doi: 10.1109/ICIN.2017.7899408.
    [5] "Linux namespaces," Wikipedia, https://en.wikipedia.org/wiki/Linux_namespaces.
    [6] "Cgroups," Wikipedia, https://en.wikipedia.org/wiki/Cgroups.
    [7] H. Qian, Q. Wen, L. Sun, J. Gu, Q. Niu and Z. Tang, "RobustScaler: QoS-Aware Au-toscaling for Complex Workloads," 2022 IEEE 38th International Conference on Data Engineering (ICDE), Kuala Lumpur, Malaysia, 2022, pp. 2762-2775, doi: 10.1109/ICDE53745.2022.00252.
    [8] Zheng, T., Zheng, X., Zhang, Y. et al. SmartVM: a SLA-aware microservice deploy-ment framework. World Wide Web 22, 275–293 (2019).
    [9] Umberger, M., Lumbar, S. & Humar, I. Modeling the influence of network delay on the user experience in distributed home-automation networks. Inf Syst Front 14, 571–584 (2012).
    [10] Paula R. Selvidge, Barbara S. Chaparro, Gregory T. Bender. The world wide wait: ef-fects of delays on user performance. International Journal of Industrial Ergonomics, Volume 29, Issue 1, 2002,Pages 15-20, ISSN 0169-8141.
    [11] Dimitris Tsolkas, Eirini Liotou, Nikos Passas, Lazaros Merakos, A survey on paramet-ric QoE estimation for popular services. Journal of Network and Computer Applica-tions, Volume 77, 2017, Pages 1-17, ISSN 1084-8045.
    [12] Prometheus, "Configuration," Prometheus Documentation, https://prometheus.io/docs/prometheus/latest/configuration/configuration/.
    [13] Nguyen, T.-T.; Yeom, Y.-J.; Kim, T.; Park, D.-H.; Kim, S. Horizontal Pod Autoscaling in Kubernetes for Elastic Container Orchestration. Sensors 2020, 20, 4621.
    [14] Casalicchio, E. A study on performance measures for auto-scaling CPU-intensive con-tainerized applications. Cluster Comput 22, 995–1006 (2019).
    [15] K. Aykurt et al., "HyPA: Hybrid Horizontal Pod Autoscaling with Automated Model Updates," 2023 IEEE Conference on Network Function Virtualization and Software De-fined Networks (NFV-SDN), Dresden, Germany, 2023, pp. 8-14, doi: 10.1109/NFV-SDN59219.2023.10329742.
    [16] G. Yu, P. Chen and Z. Zheng, "Microscaler: Cost-Effective Scaling for Microservice Applications in the Cloud With an Online Learning Approach," in IEEE Transactions on Cloud Computing, vol. 10, no. 2, pp. 1100-1116, 1 April-June 2022, doi: 10.1109/TCC.2020.2985352.
    [17] S. Roy, A. C. König, I. Dvorkin and M. Kumar, "PerfAugur: Robust diagnostics for per-formance anomalies in cloud services," 2015 IEEE 31st International Conference on Data Engineering, Seoul, Korea (South), 2015, pp. 1167-1178, doi: 10.1109/ICDE.2015.7113365.
    [18] Z. Xiao and S. Hu, "DScaler: A Horizontal Autoscaler of Microservice Based on Deep Reinforcement Learning," 2022 23rd Asia-Pacific Network Operations and Manage-ment Symposium (APNOMS), Takamatsu, Japan, 2022, pp. 1-6, doi: 10.23919/APNOMS56106.2022.9919994.
    [19] Horn, A., Fard, H.M., Wolf, F. (2022). Multi-objective Hybrid Autoscaling of Micro-services in Kubernetes Clusters. In: Cano, J., Trinder, P. (eds) Euro-Par 2022: Parallel Processing. Euro-Par 2022. Lecture Notes in Computer Science, vol 13440. Springer, Cham.
    [20] R. Chowdhury, C. Talhi, H. Ould-Slimane and A. Mourad, "Proactive and Intelligent Monitoring and Orchestration of Cloud-Native IP Multimedia Subsystem," in IEEE Open Journal of the Communications Society, vol. 5, pp. 139-155, 2024, doi: 10.1109/OJCOMS.2023.3341002.
    [21] Jiang, Chunmao and Peng Wu. “A Fine-Grained Horizontal Scaling Method for Con-tainer-Based Cloud.” Sci. Program. 2021 (2021): 6397786:1-6397786:10.
    [22] Pozdniakova, O.; Mažeika, D.; Cholomskis, A. SLA-Adaptive Threshold Adjustment for a Kubernetes Horizontal Pod Autoscaler. Electronics 2024, 13, 1242. https://doi.org/10.3390/electronics13071242
    [23] M. -N. Tran, D. -D. Vu and Y. Kim, "A Survey of Autoscaling in Kubernetes," 2022 Thirteenth International Conference on Ubiquitous and Future Networks (ICUFN), Bar-celona, Spain, 2022, pp. 263-265, doi: 10.1109/ICUFN55119.2022.9829572.
    [24] Senjab, K., Abbas, S., Ahmed, N. et al. A survey of Kubernetes scheduling algorithms. J Cloud Comp 12, 87 (2023). https://doi.org/10.1186/s13677-023-00471-1
    [25] Kubernetes.io, "Horizontal Pod Autoscaler," Kubernetes Documentation. https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/.
    Description: 碩士
    國立政治大學
    資訊科學系
    110753147
    Source URI: http://thesis.lib.nccu.edu.tw/record/#G0110753147
    Data Type: thesis
    Appears in Collections:[Department of Computer Science ] Theses

    Files in This Item:

    File Description SizeFormat
    314701.pdf3729KbAdobe PDF0View/Open


    All items in 政大典藏 are protected by copyright, with all rights reserved.


    社群 sharing

    著作權政策宣告 Copyright Announcement
    1.本網站之數位內容為國立政治大學所收錄之機構典藏,無償提供學術研究與公眾教育等公益性使用,惟仍請適度,合理使用本網站之內容,以尊重著作權人之權益。商業上之利用,則請先取得著作權人之授權。
    The digital content of this website is part of National Chengchi University Institutional Repository. It provides free access to academic research and public education for non-commercial use. Please utilize it in a proper and reasonable manner and respect the rights of copyright owners. For commercial use, please obtain authorization from the copyright owner in advance.

    2.本網站之製作,已盡力防止侵害著作權人之權益,如仍發現本網站之數位內容有侵害著作權人權益情事者,請權利人通知本網站維護人員(nccur@nccu.edu.tw),維護人員將立即採取移除該數位著作等補救措施。
    NCCU Institutional Repository is made to protect the interests of copyright owners. If you believe that any material on the website infringes copyright, please contact our staff(nccur@nccu.edu.tw). We will remove the work from the repository and investigate your claim.
    DSpace Software Copyright © 2002-2004  MIT &  Hewlett-Packard  /   Enhanced by   NTU Library IR team Copyright ©   - Feedback