lvs 四層 dr 直接返回給用戶
支持大併發 四層負載均衡 複雜 不能更改端口
lvs負載均衡 (大併發) NGINX 實現web動靜分離 移動和pc分離
解決 WEB高併發html
mysql優化參數調整
打開MySQL配置文件my.cnf
1 back_log參數值:由默認的50修改成500.(每一個鏈接256kb,佔用:125M)
back_log=500
值指出在MySQL暫時中止回答新請求以前的短期內多少個請求能夠被存在堆棧中。也就是說,若是MySql的鏈接數據達到max_connections時,新來的請求將會被存在堆棧中,以等待某一鏈接釋放資源,該堆棧的數量即back_log,若是等待鏈接的數量超過back_log,將不被授予鏈接資源。將會報:unauthenticated user | xxx.xxx.xxx.xxx | NULL | Connect | NULL | login | NULL 的待鏈接進程時.
back_log值不能超過TCP/IP鏈接的偵聽隊列的大小。若超過則無效,查看當前系統的TCP/IP鏈接的偵聽隊列的大小命令:cat /proc/sys/net/ipv4/tcp_max_syn_backlog目前系統爲1024。對於Linux系統推薦設置爲小於512的整數。node
修改系統內核參數,)
查看mysql 當前系統默認back_log值,命令:
show variables like 'back_log'; 查看當前數量
2 改wait_timeout參數值,由默認的8小時,修改成30分鐘。(本次不用)
wait_timeout=1800(單位爲妙)MySQL客戶端的數據庫鏈接閒置最大時間值
網站有大量的MySQL連接請求(每一個MySQL鏈接都是要內存資源開銷的 ),因爲你的程序的緣由有大量的鏈接請求空閒啥事也不幹,白白佔用內存資源,或者致使MySQL超過最大鏈接數歷來沒法新建鏈接致使「Too many connections」的錯誤
3修改max_connections參數值,由默認的151,修改成3000(750M)。
max_connections=3000
max_connections是指MySql的最大鏈接數,若是服務器的併發鏈接請求量比較大,建議調高此值,以增長並行鏈接數量,固然這創建在機器能支撐的狀況下,由於若是鏈接數越多,介於MySql會爲每一個鏈接提供鏈接緩衝區,就會開銷越多的內存,因此要適當調整該值,不能盲目提升設值
4修改max_user_connections值,由默認的0,修改成800
max_user_connections=800 是指每一個數據庫用戶的最大鏈接
5修改thread_concurrency值,由目前默認的8,修改成64
thread_concurrency=64
thread_concurrency應設爲CPU核數的2倍. 好比有一個雙核的CPU, 那thread_concurrency 的應該爲4; 2個雙核的cpu, thread_concurrency的值應爲8
6default-storage-engine(設置MySQL的默認存儲引擎)
default-storage-engine= InnoDB(設置InnoDB類型(支持實物類型),另外還能夠設置MyISAM(讀多寫少創建引擎)
二 全局緩存
動MySQL時就要分配而且老是存在的全局緩存。目前有:key_buffer_size(默認值:402653184,即384M)、innodb_buffer_pool_size(默認值:134217728即:128M)、innodb_additional_mem_pool_size(默認值:8388608即:8M)、innodb_log_buffer_size(默認值:8388608即:8M)、query_cache_size(默認值:33554432即:32M)等五個。總共:560M.
這些變量值均可以經過命令如:show variables like '變量名';查看到。
三 局部緩存
read_buffer_size(默認值:2097144即2M)
read_buffer_size=4M是MySql讀入緩衝區大小。對錶進行順序掃描的請求將分配一個讀入緩衝區,MySql會爲它分配一段內存緩衝區。read_buffer_size變量控制這一mysql
緩衝區的大小。若是對錶的順序掃描請求很是頻繁,而且你認爲頻繁掃描進行得太慢,能夠經過增長該變量值以及內存緩衝區大小提升其性能.
sort_buffer_size,read_rnd_buffer_size,tmp_table_size 大小的內存空間. 不過它們只是在須要的時候才分配,而且在那些操做作完以後就釋放了。有的是馬上分配成單獨的組塊。tmp_table_size 可能高達MySQL所能分配給這個操做的最大內存空間
四 其餘緩存
thread_cache_size (服務器線程緩存)
table_cache(默認值:512)linux
#######################################################
NGINX優化
1 worker_processes 1;通常調整到與CPU的顆數相同
2 優化綁定不一樣的nginx進程到不一樣的CPU上
3 nginx事件處理模型優化
4 調整nginx單個進程容許的客戶端最大鏈接數
參數語法:worker_connections number
默認配置:worker_connections 512
放置位置:events 標籤
events {
worker_connections 1024; #一個worker進程的併發
}
總併發= worker_processes* worker_connections
5 配置nginx worker進程最大打開文件數
參數語法:worker_rlimit_nofile number
放置位置:主標籤段
說明:做用是改變worker processes能打開的最大文件數
worker_rlimit_nofile 65535;
這各參數受系統文件的最大打開數限制,解決方法:
[root@admin nginx]# cat /proc/sys/fs/file-max
8192
文件系統最大可打開文件數
[root@admin nginx]# ulimit -n
1024
程序限制只能打開1024個文件
使用# ulimit -n 8192調整一下
或者永久調整打開文件數 可在啓動文件/etc/rc.d/rc.local末尾添加(在/etc/sysctl.conf末尾添加fs.file-max=xxx無效)
6 開啓高效文件傳輸模式
設置參數 sendfile on;
sendfile參數用於開啓文件的高效傳輸模式。同時將tcp_nopush和tcp_nodelay兩個指令設置爲on,可防止網絡及磁盤i/o阻塞,提高nginx工做效率。
http {
sendfile on; #放在http,server,location均可以
7 FastCGI相關參數調優
fastcgi_connect_timeout 240;
fastcgi_send_timeout 240;
fastcgi_read_timeout 240;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;
#fastcgi_temp_path /data/ngx_fcgi_tmp;
fastcgi_cache_path /data/ngx_fcgi_cache levels=2:2 keys_zone=ngx_fcgi_cache:512m inactive=1d max_size=40g;
8 部署網站程序權限設置
目錄:755
文件:644
全部者:root
cd /application/apache/html/
chown -R root.root blog
find ./blog/ -type f|xargs chmod 644
find ./blog/ -type d|xargs chmod 755
9. 控制Nginx併發鏈接數量
ngx_http_limit_conn_module這個模塊用於限制每一個定義key值得鏈接數,特別是單個TP的鏈接數。
不是全部的鏈接數都會被計算。一個符合計數要求的鏈接是整個請求頭已經被讀取的鏈接。
控制Nginx併發鏈接數量參數的說明
1)limit_conn_zone參數:
語法:limit_conn_zone key zone=name:size;
上下文:http
用於設置共享內存區域,key能夠是字符串、Nginx自帶變量或前兩個組合。name爲內存區域的名稱,size爲內存區域的大小。nginx
2)limit_conn參數
語法:limit_conn zone number;
上下文:http、server、location
用於指定key設置最大鏈接數。當超時最大鏈接數時,服務器會返回503報錯。web
10. 控制客戶端請求Nginx的速率
ngx_http_limit_req_module模塊用於限制每一個IP訪問每一個定義key的請求速率。
limit_req_zone參數說明以下。
語法:limit_req_zone key zone=name:size rate=rate;
上下文:http
用於設置共享內存區域,key能夠是字符串,Nginx自帶變量或前兩個組合。name爲內存區域的名稱,size爲內存區域的大小,rate爲速率,單位爲r/s,每秒一個請求。
limit_req參數說明以下:
語法:limit_req zone=name [burst-number] [nobelay]
上下文:http、server、location
這裏運用了令牌桶原理,burst=num,一個有num快令牌,令牌發完後,多出來的那些請求就會返回503。
nodelay默認在不超過burst值得前提下會排隊等待處理,若是使用此參數,就會處理完num+1次請求,剩餘的請求爲超時,返回503。
###########################################################
修改Linux內核參數提升Nginx服務器在高的時候的性能
TCP TIME_WAIT套接字數量常常達到兩、三萬,服務器很容易被拖死。經過修改Linux內核參數,能夠減小Nginx服務器的TIME_WAIT套接字數量sql
vi /etc/sysctl.conf
增長如下幾行:
引用
net.ipv4.tcp_fin_timeout = 30
net.ipv4.tcp_keepalive_time = 1200
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.ip_local_port_range = 1024 65000
net.ipv4.tcp_max_syn_backlog = 8192
net.ipv4.tcp_max_tw_buckets = 5000
net.ipv4.tcp_syncookies = 1 表示開啓SYN Cookies。當出現SYN等待隊列溢出時,啓用cookies來處理,可防範少許SYN攻擊,默認爲0,表示關閉;
net.ipv4.tcp_tw_reuse = 1 表示開啓重用。容許將TIME-WAIT sockets從新用於新的TCP鏈接,默認爲0,表示關閉;
net.ipv4.tcp_tw_recycle = 1 表示開啓TCP鏈接中TIME-WAIT sockets的快速回收,默認爲0,表示關閉。
net.ipv4.tcp_fin_timeout = 30 表示若是套接字由本端要求關閉,這個參數決定了它保持在FIN-WAIT-2狀態的時間。
net.ipv4.tcp_keepalive_time = 1200 表示當keepalive起用的時候,TCP發送keepalive消息的頻度。缺省是2小時,改成20分鐘。
net.ipv4.ip_local_port_range = 1024 65000 表示用於向外鏈接的端口範圍。缺省狀況下很小:32768到61000,改成1024到65000。
net.ipv4.tcp_max_syn_backlog = 8192 表示SYN隊列的長度,默認爲1024,加大隊列長度爲8192,能夠容納更多等待鏈接的網絡鏈接數。
net.ipv4.tcp_max_tw_buckets = 5000 表示系統同時保持TIME_WAIT套接字的最大數量,若是超過這個數字,TIME_WAIT套接字將馬上被清除並打印警告信息。默認爲180000,改成5000。對於Apache、Nginx等服務器,上幾行的參數能夠很好地減小TIME_WAIT套接字數量,可是對於Squid,效果卻不大。此項參數能夠控制TIME_WAIT套接字的最大數量,避免Squid服務器被大量的TIME_WAIT套接字拖死。
更改linux內核參數後,當即生效的命令!
/sbin/sysctl -p
Nginx優化
使用FastCGI 緩存
fastcgi_cache TEST
開啓FastCGI 緩存而且爲其制定一個名稱。我的感受開啓緩存很是有用,能夠有效下降CPU 負載,而且防止502 錯誤。
fastcgi_cache_path /usr/local/nginx/fastcgi_cache levels=1:2
keys_zone=TEST:10m
inactive=5m;
這個指令爲FastCGI 緩存指定一個路徑,目錄結構等級,關鍵字區域存儲時間和非活動刪除時間。 數據庫