forked from kubeflow/examples
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathnotebook_setup.py
63 lines (50 loc) · 2.24 KB
/
notebook_setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
"""Some routines to setup the notebook.
This is separated out from util.py because this module installs some of the pip packages
that util depends on.
"""
import sys
import logging
import os
import subprocess
from importlib import reload
from pathlib import Path
TF_OPERATOR_COMMIT = "9238906"
# add env default to google, we can override it.
def notebook_setup(platform ='gcp'):
# Install the SDK
logging.basicConfig(format='%(message)s')
logging.getLogger().setLevel(logging.INFO)
home = str(Path.home())
logging.info("pip installing requirements.txt")
subprocess.check_call(["pip3", "install", "--user", "-r", "requirements.txt"])
clone_dir = os.path.join(home, "git_tf-operator")
if not os.path.exists(clone_dir):
logging.info("Cloning the tf-operator repo")
subprocess.check_call(["git", "clone", "https://github.com/kubeflow/tf-operator.git",
clone_dir])
logging.info(f"Checkout kubeflow/tf-operator @{TF_OPERATOR_COMMIT}")
subprocess.check_call(["git", "checkout", TF_OPERATOR_COMMIT], cwd=clone_dir)
# Installing the python packages locally doesn't appear to have them automatically
# added the path so we need to manually add the directory
local_py_path = os.path.join(home, ".local/lib/python3.6/site-packages")
tf_operator_py_path = os.path.join(clone_dir, "sdk/python")
for p in [local_py_path, tf_operator_py_path]:
if p not in sys.path:
logging.info("Adding %s to python path", p)
# Insert at front because we want to override any installed packages
sys.path.insert(0, p)
if platform == 'gcp':
setup_gcp()
# Force a reload of kubeflow; since kubeflow is a multi namespace module
# if we've loaded up some new kubeflow subpackages we need to force a reload to see them.
import kubeflow
reload(kubeflow)
def setup_gcp():
logging.info("Configure docker credentials")
subprocess.check_call(["gcloud", "auth", "configure-docker", "--quiet"])
if os.getenv("GOOGLE_APPLICATION_CREDENTIALS"):
logging.info("Activating service account")
subprocess.check_call(["gcloud", "auth", "activate-service-account",
"--key-file=" +
os.getenv("GOOGLE_APPLICATION_CREDENTIALS"),
"--quiet"])