多租户系统中由css引起的CDN资源覆盖

如图:

多租户系统中由css引起的CDN资源覆盖

问题描述:

  • 本系统下所有的请求包括静态资源都必须携带 tenantid,即租户ID。
  • 原来图片服务器有多台,访问图片的域名每个图片服务器一个。
  • 后来打算改造成所有图片只从一个域名的入口请求图片。
  • 于是问题就产生了,css文件中的url不可能动态的确定tenantid的值,所以请求css文件中的资源无法加上tenantid这个参数,而CDN又必须要通过tenantid来区分不同的ImgServer。于是就发生了图中CDN的覆盖。

解决思路如下:
方案一,在CDN中加脚本通过请求header中的referer来区分请求不同的来源。但是CDN不支持脚本定制化。

方案二,在路由Server上对css文件的响应做过滤,通过lua脚本给所有css文件加上tenantid。问题是代码写起来有些复杂,另外会牺牲路由Server一部分性能。