nginx - 两个反向代理后面的气流 - 图 GET 请求不包含任何 DAG ID
问题描述
我的设置:
我在两个 nginx 代理后面运行 Airflow 1.10.9。第一个代理将请求转发到位于专用网络中的第二个代理。第二个代理将请求转发到请求的 Airflow 实例,其中气流主机在 URL 中指定。这基本上允许我们运行多个气流实例并正确路由到它们。
我还将 Airflow base_url 更新为http://myhost/airflow-<airflowid>/
Here,URL 的气流 id 部分是第二个代理如何识别要转发到哪台机器的方式。
代理设置正在运行,因为可以访问 Airflow UI,并且我可以看到我的 DAGS 已加载到 UI 中。但是,当我尝试与 DAG 交互时,出现以下错误:
DAG "None" seems to be missing.
我将问题追溯到到达 Airflow UI 的 GET 请求。我可以看到该请求不包含任何 DAG ID。在我的工作 Airflow 实例(一个不在任何代理后面运行的实例)上,请求包含 DAG ID run_etl
:
"GET /graph?dag_id=run_etl&root=&execution_date=2020-02-10T11%3A42%3A14.454118%2B00%3A00 HTTP/1.1" 200 10174 "http://10.83.163.248:3128/graph?dag_id=run_etl" "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.87 Safari/537.36"
在专用网络中运行的 Airflow 实例上,GET 请求不包含 DAG ID:
"GET /admin/airflow/graph HTTP/1.1" 302 221 "https://<redacted host>/admin/" "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.87 Safari/537.36"
我的nginx配置如下:
代理 1:
server {
listen 443 ssl;
server_name <redacted server name>;
location ~ /airflow-(.*) {
proxy_pass http://172.23.7.79:80;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Host $host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
代理 2:
server {
listen 80;
location ~ /airflow-([^\/]+)/(.*) {
proxy_pass http://$1-<redacted hostname>:8080/airflow-$1/$2;
proxy_redirect off;
proxy_set_header Host $host;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
任何关于这里有什么问题的想法将不胜感激!
解决方案
事实证明,答案比我预期的更直接。
代理 2 需要一些额外的配置才能在代理通道中传递 URL 查询。
proxy_pass http://$1-<redacted hostname>:8080/airflow-$1/$2$is_args$args;
推荐阅读
- java - javafx线程同步时为真
- c# - 在 asp.net MVC 中使用 EF 更新特定字段
- android-studio - Oppo A57 - 无法在 Ubuntu 和 Android Studio 中检测到手机
- java - java.text.ParseException:无法解析的日期:“2018-05-23T06:39:37+0000”
- sql - 如何根据sql server中行的列值从表中选择行
- google-chrome - 为什么cookie过期后仍然存在于Chrome开发工具中
- jface - 无法在 JFace 对话框的 ListViewer 中获取所选项目
- windows - 谷歌助手不工作
- c# - 从客户端将数据和文件发布到 Web api 中检测到潜在危险的 Request.Form 值
- ios - OKta + react native + OKta 自定义登录页面 + okta 离线登录