集群(cluster)是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户与集群相互作用时,集群像是一个独立的服务器。负载均衡(Load Balance),其意思就是分摊到多个操作单元上进行执行阿里云负载均衡架构文档负载均衡好处节省成本,一个服务器性能再好也是有瓶颈的,而且性能越高的服务器成本也越大。极大的提高了并发量和响应速度。实践例子学无止境网该web应用,由两个服务器一起提供的服务实现负载均衡遇到的问题nginx负载均衡策略多台服务器代码同步多台服务器数据库同步node服务,代码更新后,服务重启源的代码更新问题和数据升级用户上传的图片等静态资源同步Nginx反向代理及负载均衡轮询权重ip_hashurl_hash等等…这里使用最简单的轮询机制,session存放在数据库,解决了session服务器之间不同步的问题。upstream tianshengjie{ server ip地址; server ip地址 max_fails=2 fail_timeout=10s;}server { listen 80 default_server; server_name 47.99.90.167 www.tianshengjie.cn tianshengjie.cn; location / { proxy_pass http://tianshengjie; proxy_cache_key $http_range$uri$is_args$args; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; }}服务部署forever start -c nodemon app.js –exitcrashforeverA simple CLI tool for ensuring that a given script runs continuously守护node进程程序nodemon自动监听文件变化,重启node服务exitcrash,当node服务奔溃后,重启代码同步使用shell脚本,自动更新代码,一键同步更新#!/bin/bashcd git仓库git pull;yarn install –production;rsync -av –exclude-from=/opt/ssh/blog_exclude.list git仓库 代码发布地址rsync -avz -e ssh /var/www/blog/ root@负载均衡服务器ip:负载均衡服务器发布代码目录cd 代码发布地址 ;forever stop app.js;npm run start;echo “发布成功"将git仓库和正式应用的代码地址分离更新git仓库地址下载程序依赖将git仓库更新后的代码复制到正式发布目录将代码同步更新到负载均衡服务器重启服务数据库同步阿里 云数据库文档地址性能最高,有备份有容灾,功能强大,但是收费mysqlmysql远程连接配置配置相对简单,数据库会有性能瓶颈,免费分布式数据库研究中静态资源同步当用户通过负载均衡,被定位到了不同的服务器。这时候,上传文件时,将会把文件上传到不同的服务器中。当用户被分配到了其他服务器时,就会找不到这个文件了。所以我们需要同步负载均衡的服务器的文件。方案一:自己实现统一文件上传管理系统,所有用户文件统一上传到一个地方。方案二:使用阿里云的NAS文件系统管理方案三:使用NFS系统阿里云 NAS文件系统管理阿里云文件存储(Network Attached Storage,简称 NAS)是面向阿里云 ECS 实例、HPC 和 Docker 等计算节点的文件存储服务,提供标准的文件访问协议,您无需对现有应用做任何修改,即可使用具备无限容量及性能扩展、单一命名空间、多共享、高可靠和高可用等特性的分布式文件系统。配置挂载缺点缺点:收费优点配置相对简单弹性伸缩,按量收费阿里出品NFS (Network FileSystem)配置文档缺点配置相对复杂server宕机了所有客户端都不能访问在高并发下NFS效率/性能有限数据是通过明文传送,安全性一般对数据完整性不做验证多台机器挂载NFS服务器时,连接管理维护麻烦优点免费,免费的就是好节省存储空间实现了多台服务器共享文件原文地址:https://tianshengjie.cn/artic…