news 2026/4/28 3:17:47

Linux---Tomcat服务器Varnish代理服务器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Linux---Tomcat服务器Varnish代理服务器

Linux 上配置 Varnish 作为 Tomcat 服务器的反向代理

Varnish 是一款高性能的 HTTP 加速器和反向代理缓存服务器,常用于前端缓存动态内容(如 Java Web 应用),减少 Tomcat 的负载。Tomcat 是 Java 应用的容器,通常运行在 8080 端口。Varnish 可以直接代理 Tomcat(通过 HTTP),比通过 Apache + mod_jk 更简单高效,尤其在缓存命中时性能提升显著。

1. 基本架构
  • Varnish:监听公共端口(如 80 或 443 前需 SSL 终止),作为入口。
  • Tomcat:运行在后端端口(如 8080),处理动态内容。
  • 典型部署:Varnish 在前端(端口 80),Tomcat 在本地或远程的 8080 端口。
  • 注意:Varnish 不原生支持 SSL,如果需要 HTTPS,通常在前加 Nginx 或 Pound 处理 SSL 终止,然后转发到 Varnish。
2. 安装步骤(以 Ubuntu/CentOS 示例)

安装 Tomcat(假设单机部署):

  • 下载 Tomcat(例如 apache-tomcat-10.x.tar.gz)。
  • 解压到/opt/tomcat,启动./bin/startup.sh
  • 默认监听 8080 端口,确保应用部署在 webapps 下。

安装 Varnish

  • Ubuntu:添加官方仓库后apt install varnish
  • CentOS/RHEL:yum install epel-releaseyum install varnish
  • 最新版建议从 varnish-cache.org 下载源代码编译。
3. 配置 Varnish 代理 Tomcat

修改 Varnish 监听端口(让 Varnish 占 80 端口):

  • 编辑/etc/varnish/varnish.params/etc/default/varnish(旧版):
    VARNISH_LISTEN_PORT=80
  • 或在 systemd 服务中调整:-a :80

配置 VCL 文件/etc/varnish/default.vcl):
基本配置(单后端 Tomcat):

vcl 4.0; # 或 4.1,视版本而定 import directors; # 如果需要负载均衡多 Tomcat backend tomcat { .host = "127.0.0.1"; # Tomcat 主机 IP,如果远程改成对应 IP .port = "8080"; # Tomcat HTTP 端口 .connect_timeout = 600s; .first_byte_timeout = 600s; .between_bytes_timeout = 600s; .probe = { # 可选:健康检查 .url = "/"; # 检查根路径 .timeout = 1s; .interval = 5s; .window = 5; .threshold = 3; } } sub vcl_recv { set req.backend_hint = tomcat; # 不缓存动态内容(如登录、POST),直接 pass 到 Tomcat if (req.method == "POST" || req.url ~ "\.(jsp|do|action)$" || req.url ~ "^/admin") { return (pass); } # 处理 Cookie:Java Session 常使用 Cookie,避免缓存带 Session 的页面 if (req.http.Cookie ~ "JSESSIONID") { return (pass); } # 移除不必要的 Cookie unset req.http.Cookie; } sub vcl_backend_response { # 移除 Set-Cookie 如果不想缓存带 Session 的响应(慎用,根据应用调整) # unset beresp.http.Set-Cookie; # 设置缓存时间(静态资源长缓存,动态短缓存) if (bereq.url ~ "\.(jpg|png|css|js)$") { set beresp.ttl = 1d; # 静态文件缓存 1 天 } else { set beresp.ttl = 10m; # 动态页面短缓存 } } sub vcl_deliver { # 添加缓存命中标志(调试用) if (obj.hits > 0) { set resp.http.X-Cache = "HIT"; } else { set resp.http.X-Cache = "MISS"; } }
  • 重启 Varnish:systemctl restart varnish
4. Java 应用特定注意事项
  • Session 管理:Tomcat 默认使用 JSESSIONID Cookie。如果页面依赖 Session,Varnish 缓存会造成 Session 丢失。解决方案:
    • 在 VCL 中检测 Cookie 并return (pass);(不缓存)。
    • 或在应用中设置响应头Cache-Control: no-cache
  • 静态资源:CSS/JS/图片等可安全长缓存,提升性能。
  • X-Forwarded-For:Varnish 默认添加,Tomcat 可通过 Valve 配置获取真实客户端 IP。
  • 多 Tomcat 负载均衡:使用directors.round-robin;directors.random;定义多个 backend。
5. 测试与优化
  • 访问 http://your-server-ip,应看到 Tomcat 应用。
  • curl -I检查X-Cache: HIT/MISS
  • 监控:varnishstatvarnishlog
  • 如果应用是动态 Java(如 Spring Boot),缓存命中率取决于静态内容比例,通常 20%+ 即可显著加速。
6. HTTPS 支持

Varnish 不处理 SSL,推荐:

  • Nginx 前置:Nginx 监听 443(SSL),代理到 Varnish 80。
  • 或 Hitch/Pound 作为 SSL 终止器。

这种配置简单高效,许多生产环境直接用 Varnish + Tomcat,而非加 Apache 中间层。如果有具体错误或应用细节,可进一步调整 VCL。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 7:23:58

C# 里弹出“确定”“取消”对话框

C# 中弹出“确定”“取消”对话框的几种常用方法 C# 中最常用、最简单的弹出“确定/取消”对话框就是使用 MessageBox 类(位于 System.Windows.Forms 命名空间)。以下是详细说明和示例。 方法一:最常用 - MessageBox.Show(推荐&…

作者头像 李华
网站建设 2026/4/21 16:10:02

Java常用的日期和时间格式化转换符

Java 中常用的日期和时间格式化转换符大全 Java 中日期和时间的格式化主要通过以下两个类实现: 旧 API(Java 8 之前):java.text.SimpleDateFormat新 API(Java 8 推荐):java.time.format.DateT…

作者头像 李华
网站建设 2026/4/25 10:40:43

保姆级教程:Spring AI RAG知识库构建,让你的AI助手“满腹经纶“!

当用户提问:“有哪些优惠券?” 。 RAG 工程会去查询本地向量数据库中的相关数据,然后将这部分数据 用户问题,一起发送给大模型进行处理。 先来看一下效果,如图 加载数据文件到向量数据库中 手动查询向量数据库实现 R…

作者头像 李华
网站建设 2026/4/28 2:04:16

用 Python 编写 K8s 漏洞扫描器,自动发现集群内的配置错误

标签: #Kubernetes #Python #DevSecOps #网络安全 #云原生 #自动化运维🚨 前言:你的集群也许正在“裸奔” 你是否见过这种 YAML 配置? securityContext:privileged: true # 为了省事,直接给特权runAsUser: 0 # 直…

作者头像 李华
网站建设 2026/4/25 10:33:11

L911349010CB 继电器板

L911349010CB 继电器板概述类型:工业继电器控制板功能:通过低电压控制信号驱动高电压或大电流负载用途:实现设备开关控制、自动化逻辑执行或保护回路主要功能开关控制接收来自 PLC、控制器或传感器的低电压信号控制继电器闭合或断开&#xff…

作者头像 李华