需求:
在多个不同机器上部署同一个tomcat做服务器负载均衡(nginx),每个tomcat实例都有上传静态自己的功能(比如图片)。但是对外访问的时候,需要一个统一的出口。所以这里使用NFS文件共享服务。
搭建过程如下:
NFS文件共享服务搭建
1.环境:
NFS服务器地址:192.168.0.100
tomcat1地址:192.168.0.101
tomcat2地址:192.168.0.102
2.安装NFS服务器(192.168.0.100): sudo apt-get install nfs-kernel-server
3.配置NFS服务器的共享目录:
sudo vim /etc/exports
在最后面添加一行:/nfs *(insecure,rw,sync,no_root_squash,no_subtree_check)
(/nfs为root目录下新建的一个文件夹,这个文件夹就是nfs服务对外的共享目录,名字可以随便。
,注意如果当前登录用户不是root那么这个目录必须要在root目录下,不可以是当前登录用户的根目录)
启动nfs服务器(前提关闭防火墙):sudo service nfs-kernel-server start|restart|stop
到此NFS服务器就搭建完成了。
4.配置NFS客户端(192.168.0.101,192.168.0.102)
假设tomcat1,tomcat2实例会上传文件到各自的/home/pan/upload目录下(两台机器都有这个目录)
对这个目录要执行:chmod 777 /home/pan/upload命令
这个时候就需要通过NFS共享服务将这两台服务器里/home/pan/upload目录的内容挂载到NFS的共享服务目录下。
配置有3种,这里以最简单的那种:
sudo mount -t nfs 192.168.0.100:/nfs /home/pan/upload
若不出问题就可以查看是否挂载了
sudo showmount -e 192.168.0.100
到此客户端挂载NFS服务配置就可以了。
5.测试
在任意一台tomcat所在机器的/home/pan/upload目录下新建一个文件/文件夹
然后去192.168.0.100的NFS服务器上查看/nfs目录下是否已经存在同样的文件/文件夹
注意:nginx访问的时候,可以配置一个访问静态资源的server,然后root指向这个NFS的共享文件夹