因为我们应用是运行在Liferay 应用服务器上的,所以对于服务器进行一些优化当然是我们最先想到的。
之前我们也做了很多测试, 因为liferay会有css-fast-load,和 js-fast-load,这些参数会吧若干个css文件或者若干个js文件合并成单个大文件,这样可以显著的减少网络的IO开销次数,我们开发为了方便 调试,当然是需要让这些文件都不合并,这样我们可以方便的进行调试,但是在DEMO服务器,我们显然还是吧他们合并为好,所以我们在portal- ext.properties上进行了如下的配置:
如图所示,就是把theme,javascript这些fast load 从false变为true.
当然了,我们开发阶段使用的一般是ext-all-debug.js,我们为了提高性能,会使用ext-all.js来代替ext-all-debug.js。
对于多数Http请求来说,如果我们能让他们以压缩文件的形式提供这些资源的话,也会极大的提高效率。我们只要开启Gzip,然后就可以减少下载这些资源所占用的网络传输时间。
为了进行比较,我们先给个截图,这是没有启用Gzip的情况:
从这里可以看出,在启用Gzip之前,下载ext-all-debug.js需要2.8MB这么大的文件,需要用时1.53秒。
然后我们就配置Gzip Filter,为此需要做2个步骤:
(1)在$LIFERAY_HOME/portal-ext.properties文件中启用GzipFilter的功能如下:
(2)在$TOMCAT_HOME/conf/server.xml中,因为我们要测试的页面部署在8080端口上,所以我们找到8080端口的连接器(Connector),然后启用gzip ,具体就是加入以下参数:
compression="on"
compressionMinSize="2048"
noCompressionUserAgents="gozilla,traviata"
compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain,image/gif,image/png,image/jpg"/>
这里我们可以很明显的看出来,我们启用了compression,然后我们定义了需要压缩的资源类型,用compressableMimeType属性,所以这里所有我们能想到的前端资源都在这个类型列表中。
最后,我们打开Firebug进行再次测试,作为结果的比较,果然性能提升很大:
从这我们不难看出,现在的Resource Header中 Content-Encoding被设置成了gzip,所以这表示我们的gzip的功能已经被正确的开启,然后我们发现ext-all-debug.js的尺寸从2.8MB缩小成了只有550KB,而且网络的传输时间从1.53秒缩短到了906毫秒,几乎减少了40%的下载时间,其他的资源也都相应的下载时间有了大幅度的减少。可见效果很明显。
-------------------------------------------------------------------------------------------------------------------------------
由于实际项目中,user_表的数据通常很多,所以需要在user_表的userId字段上加索引。