多租户系统中由css引起的CDN资源覆盖
如图:
问题描述:
- 本系统下所有的请求包括静态资源都必须携带 tenantid,即租户ID。
- 原来图片服务器有多台,访问图片的域名每个图片服务器一个。
- 后来打算改造成所有图片只从一个域名的入口请求图片。
- 于是问题就产生了,css文件中的url不可能动态的确定tenantid的值,所以请求css文件中的资源无法加上tenantid这个参数,而CDN又必须要通过tenantid来区分不同的ImgServer。于是就发生了图中CDN的覆盖。
解决思路如下:
方案一,在CDN中加脚本通过请求header中的referer来区分请求不同的来源。但是CDN不支持脚本定制化。
方案二,在路由Server上对css文件的响应做过滤,通过lua脚本给所有css文件加上tenantid。问题是代码写起来有些复杂,另外会牺牲路由Server一部分性能。