目前我自己創(chuàng)建的項(xiàng)目奶躯,是前后端分離的項(xiàng)目帚桩,后端項(xiàng)目采用PHP編寫(xiě)亿驾,運(yùn)行環(huán)境采用lamp;前端采用Vue編寫(xiě)账嚎,前端項(xiàng)目通過(guò)Webpack進(jìn)行打包莫瞬,服務(wù)器采用Nginx。
后端服務(wù)器集群搭建
第一步下載lamp鏡像
docker run -it -d -v /docker/apache/www/:/var/www/html -v /docker/apache/log/:/var/log/apache2 --net=host --name lamp_node1 --privileged lamp
docker run -it -d -v /docker/apache/www/:/var/www/html -v /docker/apache/log/:/var/log/apache2 --net=host --name lamp_node2 --privileged lamp
docker run -it -d -v /docker/apache/www/:/var/www/html -v /docker/apache/log/:/var/log/apache2 --net=host --name lamp_node3 --privileged lamp
我們將項(xiàng)目的目錄郭蕉,從宿主機(jī)上映射到容器里面疼邀,方便后期項(xiàng)目的維護(hù)以及上線( -v /docker/apache/www/:/var/www/html);--net=host召锈,這句的意思是旁振,將容器里的端口以及IP直接映射到宿主機(jī)上,和宿主機(jī)保持一樣涨岁。
第二步:?jiǎn)?dòng)apache
//進(jìn)入容器
docker exec -it lamp_node1 /bin/bash
//運(yùn)行apache
/start-apache2.sh
docker exec -it lamp_node1 /bin/bash
將剩下的兩個(gè)服務(wù)器拐袜,按照同樣的方式進(jìn)行啟動(dòng),這樣一個(gè)三節(jié)點(diǎn)的服務(wù)器就啟動(dòng)了梢薪,還差一點(diǎn)蹬铺,如果沒(méi)有負(fù)載均衡,那么服務(wù)器的壓力還是會(huì)集中在某一臺(tái)服務(wù)器上秉撇,為此我們?yōu)楹蠖朔?wù)器創(chuàng)建負(fù)載均衡甜攀。因?yàn)檎?qǐng)求后端都是HTTP請(qǐng)求,所以我們采用Nginx服務(wù)器作為負(fù)載均衡器琐馆。
第三步:安裝Nginx
docker run -it -d -v /docker/nginx/nginx.conf:/etc/nginx/nginx.conf --net=host --name nginx_apache_node1 --privileged nginx
修改配置Nginx文件
upstream apache {
server 116.196.89.83:6001;
server 116.196.89.83:6002;
server 116.196.89.83:6003;
}
server {
listen 6101;
server_name 116.196.89.83;
location / {
proxy_pass http://apache;
index index.html index.htm;
}
這樣我們就搭建了后端服務(wù)器的集群规阀,但是還有一個(gè)問(wèn)題,如果這個(gè)負(fù)載均衡器掛掉了瘦麸,那么我們我們的項(xiàng)目又要回到初始階段谁撼,變成單臺(tái)服務(wù)器,所以我們采用雙機(jī)熱備的方案瞎暑,創(chuàng)建兩個(gè)負(fù)載均衡器彤敛,來(lái)解決這個(gè)問(wèn)題与帆。
創(chuàng)建第二個(gè)負(fù)載均衡器(配置文件和node1一樣)
docker run -it -d -v /docker/nginx/nginx.conf:/etc/nginx/nginx.conf --net=host --name nginx_apache_node2 --privileged nginx
這里我直接采用京東云的負(fù)載均衡器,將后端負(fù)載均衡器墨榄,直接部署在京東云上玄糟。這里就搭建了完整的后端服務(wù)小集群。
前端服務(wù)器集群搭建
和服務(wù)端類似袄秩,我們將lamp運(yùn)行環(huán)境變?yōu)镹ginx服務(wù)器
第一步:創(chuàng)建節(jié)點(diǎn)
docker run -it -d -v /docker/web_nginx/nginx.conf:/etc/nginx/nginx.conf -v /docker/web_nginx/www/:/docker/web_nginx/www/ --privileged --net=host --name nginx_web_node1 nginx
docker run -it -d -v /docker/web_nginx/nginx_node2.conf:/etc/nginx/nginx.conf -v /docker/web_nginx/www/:/docker/web_nginx/www/ --privileged --net=host --name nginx_web_node2 nginx
docker run -it -d -v /docker/web_nginx/nginx_node3.conf:/etc/nginx/nginx.conf -v /docker/web_nginx/www/:/docker/web_nginx/www/ --privileged --net=host --name nginx_web_node3 nginx
前端服務(wù)器的負(fù)載均衡和后端的負(fù)載均衡一模一樣阵翎。
目前我整個(gè)項(xiàng)目的架構(gòu)如下圖所示:
采用京東云負(fù)載均衡的原因是:我購(gòu)買的是云服務(wù)器,采用Keepalived方案實(shí)現(xiàn)雙機(jī)熱備方案需要分配虛擬IP之剧,但是京東云不允許在云主機(jī)上分配虛擬IP所以采用負(fù)載均衡替代方案郭卫。