Airflow — ModuleNotFoundError: нет модуля с именем «kubernetes»

Я установил Python, Docker на свою машину и пытаюсь импортировать from airflow.contrib.operators.kubernetes_pod_operator import KubernetesPodOperator но при подключении докера получаю сообщение что модуль не существует. Я уже сделал pip install apache-airflow[kubernetes] и у меня все еще та же ошибка. Есть ли конкретное место на машине, где я должен проверить, действительно ли установлена ​​библиотека? Что я могу сделать, чтобы решить эту проблему?

Airflow — ModuleNotFoundError: нет модуля с именем «kubernetes»

from airflow import DAG
from datetime import datetime, timedelta
from airflow.contrib.operators.kubernetes_pod_operator import KubernetesPodOperator
from airflow.operators.dummy_operator import DummyOperator
import logging
import os
from airflow.utils.helpers import parse_template_string

default_args = {
    'owner': 'airflow',
    'depends_on_past': False,
    'start_date': datetime.utcnow(),
    'email': ['[email protected]'],
    'email_on_failure': False,
    'email_on_retry': False,
    'retries': 1,
    'retry_delay': timedelta(minutes=5)
}

dag = DAG(
    'kubernetes_sample', default_args=default_args, schedule_interval=timedelta(minutes=10))


start = DummyOperator(task_id='run_this_first', dag=dag)

passing = KubernetesPodOperator(namespace='default',
                          image = "Python:3.6",
                          cmds=["Python","-c"],
                          arguments=["print('hello world')"],
                          labels = {"foo": "bar"},
                          name = "passing-test",
                          task_id = "passing-task",
                          get_logs=True,
                          dag=dag
                          )

failing = KubernetesPodOperator(namespace='default',
                          image = "ubuntu:1604",
                          cmds=["Python","-c"],
                          arguments=["print('hello world')"],
                          labels = {"foo": "bar"},
                          name = "fail",
                          task_id = "failing-task",
                          get_logs=True,
                          dag=dag
                          )

passing.set_upstream(start)
failing.set_upstream(start)

webserver_1 | Traceback (most recent call last): webserver_1 |
File "/usr/local/lib/python3.6/site-packages/airflow/models.py", line 377, in process_file webserver_1 | m = imp.load_source(mod_name, filepath) webserver_1 | File "/usr/local/lib/python3.6/imp.py", line 172, in load_source webserver_1 | module = _load(spec) webserver_1 | File "", line 684, in _load webserver_1 | File "", line 665, in _load_unlocked webserver_1 | File "", line 678, in exec_module webserver_1 | File "", line 219, in _call_with_frames_removed webserver_1 | File "/usr/local/airflow/dags/example_airflow.py", line 3, in webserver_1 | from airflow.contrib.operators.kubernetes_pod_operator import KubernetesPodOperator webserver_1 | File "/usr/local/lib/python3.6/site-packages/airflow/contrib/operators/kubernetes_pod_operator.py", line 21, in webserver_1 | from airflow.contrib.kubernetes import kube_client, pod_generator, pod_launcher webserver_1 | File "/usr/local/lib/python3.6/site-packages/airflow/contrib/kubernetes/pod_launcher.py", line 25, in webserver_1 | from kubernetes import watch, client webserver_1 | ModuleNotFoundError: No module named 'kubernetes'

Попробуйте: pip install airflow['kubernetes']

AC at CA 24.05.2019 20:12

@FelipeFB - ты решил?

tooptoop4 29.08.2019 21:52

Я просто перезапускаю, как написал @Kalil!

Felipe FB 29.08.2019 21:54

я получил ту же ошибку при обновлении с 1.10.3 до 1.10.4, но это предложение не исправляет это :(

tooptoop4 01.09.2019 13:31
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
5
4
11 679
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Он пытается импортировать модуль с именем kubernetes. Попробуй это:

pip install kubernetes

Я тоже импортирую это... но ничего не изменилось!

Felipe FB 25.05.2019 02:04
Ответ принят как подходящий

Запустите следующее

pip install apache-airflow[kubernetes]

После этого перезапустите веб-сервер и планировщик Airflow.

я получил ту же ошибку при обновлении с 1.10.3 до 1.10.4, но это предложение не исправляет это :(

tooptoop4 01.09.2019 13:30

попробуйте любой из этих импортов. один из них устарел, поэтому у вас может быть версия, которая больше не поддерживается.

    #from airflow.providers.cncf.kubernetes.operators.kubernetes_pod import KubernetesPodOperator
    from airflow.contrib.operators.kubernetes_pod_operator import KubernetesPodOperator

Другие вопросы по теме