首先說明筆者的服務器環境,阿里雲服務器:8G內存,2核。自從團隊運維小伙伴搭建了gitlab之后,git push 代碼時不時的就很卡,也經常出現 gitlab 反應超時——返回502錯誤,嚴重阻塞了團隊項目的開發,傷心!
轉載請注明出處: https://www.cnblogs.com/NaughtyCat/p/gitlab-eat-too-much-memory-and-response-with-502-error.html
SSH登上服務器,我去,卡的不要不要的,top 命令一看,內存只有不到125M。在top -d 3(每3秒刷新一次)模式下,按住 shift + m (以內存排序), 內存和cpu使用情況如下圖:
CPU還是有很多空閑的,內存所剩不多,USER為 git和gitlab-+的全是gitlab的東東,gitlab內存占比超過%35,而且隨着時間推移,如5小時后,free memory 持續減少,buff/cache 持續增加【CoderBaby】,on my god!
慌不要慌,淡定。我有上網法寶,我怕誰,一通google,答案了然於胸。
基本方略,改配置文件(/etc/gitlab/gitlab.rb ),配置文件生效(gitlab-ctl reconfigure),重啟(gitlab-ctl restart)
1)unicorn改小進程數,及內存占用
unicorn['worker_processes'] = 2
unicorn['worker_memory_limit_min'] = "300 * 1 << 20"
unicorn['worker_memory_limit_max'] = "500 * 1 << 20"
注:
a. gitlab有很多組件,部分組件有memory leak — 內存泄露,gitlab 搞了個 unicorn-worker-killer,會自動丟棄(drop)那些崩潰了且沒有用戶請求的worker,關於Unicorn and unicorn-worker-killer,詳情參見:
https://docs.gitlab.com/ee/administration/operations/unicorn.html
b. ps aux|grep unicorn|wc -l 【查看unicorn進程數,一看原來默認有9個】
c. unicorn['worker_processes'] 至少得有2個,推薦: (CPU cores * 1.5) + 1 = Unicorn workers
2)其它修改
sidekiq['concurrency'] = 4
prometheus_monitoring['enable'] = false
postgresql['shared_buffers'] = 256M 【postgresql內存改小】
3)linux kernal swap調整到適當比例
配置文件:/etc/sysctl.conf ,修改: vm.swappiness = 10 ,使其生效:重啟,或者通過
sysctl vm.swappiness=10 使其運行時生效
跑了一天,gitlab運行正常,內存已始終有1.7G空閑,開心
4) 如果跑了幾天,top命令看到buff/cache越來越大,空閑內存越來越少,可通過如下命令【終極解決方案】:
- 釋放page cache:
echo 1 > /proc/sys/vm/drop_caches
- 釋放 dentries 和 inodes:
echo 2 > /proc/sys/vm/drop_caches
- 一起搞
echo 3 > /proc/sys/vm/drop_caches 或者
free && sync && echo 3 > /proc/sys/vm/drop_caches && free
運行【一月后】,一切正常,開心鴨
注:
- gitlab配置說明【至少要2 core, 8G RAM】:https://gitlab.com/gitlab-org/gitlab-foss/blob/master/doc/install/requirements.md
- 設置kernal swapping: https://askubuntu.com/questions/103915/how-do-i-configure-swappiness/103916#103916
- buff/cache 內存釋放: https://unix.stackexchange.com/questions/415814/memory-runs-full-over-time-high-buffer-cache-usage-low-available-memor
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
*******************************************************************************************
精力有限,想法太多,專注做好一件事就行
- 我只是一個程序猿。5年內把代碼寫好,技術博客字字推敲,堅持零拷貝和原創
- 寫博客的意義在於打磨文筆,訓練邏輯條理性,加深對知識的系統性理解;如果恰好又對別人有點幫助,那真是一件令人開心的事
*******************************************************************************************