A compactação GZip não funciona no Tomcat7

2

Recentemente, tentei usar compactação gzip para melhorar o desempenho da interface com a web. Eu configurei o Tomcat Connector como abaixo.

compression="on"
compressionMinSize="2048"
noCompressionUserAgents="gozilla, traviata"
compressableMimeType="text/html,text/xml,text/css,text/javascript,text/json,application/x-javascript,application/javascript,application/json"

Abaixo está RequestHeader - Accept-Encoding é gzip, deflate.

Key Value
Request GET /app/jquery-ui.min.js HTTP/1.1
Accept  */*
Referer https://cdduat.app.com/Apptech/
Accept-Language en-US
User-Agent  Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; Trident/7.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E; InfoPath.3)
Accept-Encoding gzip, deflate
Host    cdduat.app.com
Connection  Keep-Alive
Cache-Control   no-cache
Cookie  JSESSIONID=CB793FFEE9A34B5B8E7DE34A17C90B5D; mbox=session#1436174197635-942865#1436176058|PC#1436174197635-942865.28_07#1437383802; s_fid=498342221B10B4ED-297E46742B9393BE; s_vi=[CS]v1|2ACD23BB851D5DBF-40001903C00C9391[CE]; oo_event_entry=41eebf1007f6e19f5b0ee4b5841be2441e970f9c

Para cabeçalho de resposta - não há valor de chave Accept-enconding. Além disso, não tenho certeza se está funcionando ou não. Abaixo está o cabeçalho de resposta. O tempo de carregamento do formulário da Web ainda é o mesmo. Não tenho certeza se estou fazendo algo errado aqui.

Server  Apache-Coyote/1.1
Accept-Ranges   bytes
ETag    W/"238326-1435860126000"
Last-Modified   Thu, 02 Jul 2015 18:02:06 GMT
Content-Type    application/javascript
Content-Length  238326
Date    Mon, 13 Jul 2015 22:22:23 GMT

Também consegui ver o valor do controle de cache como sem cache. Isso significa que o navegador não armazenará em cache os arquivos JS e solicitará esses recursos novamente na solicitação subsequente?

Eu notei a codificação de transferência como fragmentada. Não tenho certeza se pode ou não substituir a codificação gzip. Qualquer ajuda ou orientação seria realmente útil.

    
por pratikpawar 14.07.2015 / 01:45

1 resposta

0

Logo: você precisa adicionar esses atributos para todos os conectores e seus protocolos:

compression="on" compressionMinSize="0" useSendFile="false"

Consulte Atributos de conectores HTTP do Apache Tomcat

1. conector http

<Connector port="8080" protocol="HTTP/1.1"
           connectionTimeout="20000"
           compression="on" compressionMinSize="0" useSendFile="false"
           redirectPort="8443" />

2. conector https (altere os nomes dos arquivos de certificados para o seu)

<Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
           compression="on" compressionMinSize="0" useSendFile="false"
           maxThreads="150" SSLEnabled="true" >

    <SSLHostConfig>
        <Certificate certificateKeyFile="conf/localhost-rsa-key.pem"
                     certificateFile="conf/localhost-rsa-cert.pem"
                     certificateChainFile="conf/localhost-rsa-chain.pem"
                     type="RSA" />
    </SSLHostConfig>
</Connector>

Se você usa o protocolo http2 e tomcat9 - adicione também esta linha:

<UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol"
                 compression="on" compressionMinSize="0" useSendFile="false" />
    
por 22.09.2018 / 21:52