mirror of https://github.com/zulip/zulip.git
Activate virtualenv in production Python code.
The manage.py change effectively switches the Zulip production server to use the virtualenv, since all of our supervisord commands for the various Python services go through manage.py. Additionally, this migrates the production scripts and Nagios plugins to use the virtualenv as well.
This commit is contained in:
parent
64affb83f9
commit
a9835c0ab2
|
@ -4,17 +4,21 @@ import sys
|
||||||
import logging
|
import logging
|
||||||
import subprocess
|
import subprocess
|
||||||
|
|
||||||
|
BASE_DIR = os.path.dirname(os.path.abspath(__file__))
|
||||||
|
sys.path.append(BASE_DIR)
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
if 'posix' in os.name and os.geteuid() == 0:
|
if 'posix' in os.name and os.geteuid() == 0:
|
||||||
from django.core.management.base import CommandError
|
from django.core.management.base import CommandError
|
||||||
raise CommandError("manage.py should not be run as root.")
|
raise CommandError("manage.py should not be run as root.")
|
||||||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
||||||
os.environ.setdefault("PYTHONSTARTUP", os.path.join(os.path.dirname(__file__), "scripts/lib/pythonrc.py"))
|
os.environ.setdefault("PYTHONSTARTUP", os.path.join(BASE_DIR, "scripts/lib/pythonrc.py"))
|
||||||
|
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
logger = logging.getLogger("zulip.management")
|
logger = logging.getLogger("zulip.management")
|
||||||
subprocess.check_call([os.path.join(os.path.dirname(__file__), "scripts", "lib", "log-management-command"),
|
subprocess.check_call([os.path.join(BASE_DIR, "scripts", "lib", "log-management-command"),
|
||||||
" ".join(sys.argv)])
|
" ".join(sys.argv)])
|
||||||
|
|
||||||
if "--no-traceback" not in sys.argv and len(sys.argv) > 1:
|
if "--no-traceback" not in sys.argv and len(sys.argv) > 1:
|
||||||
|
|
|
@ -7,6 +7,8 @@ from __future__ import print_function
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
sys.path.append('/home/zulip/deployments/current')
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
from zproject import settings
|
from zproject import settings
|
||||||
|
|
||||||
import glob
|
import glob
|
||||||
|
|
|
@ -18,6 +18,9 @@ import random
|
||||||
import traceback
|
import traceback
|
||||||
import os
|
import os
|
||||||
|
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
import django
|
import django
|
||||||
|
|
||||||
def total_seconds(timedelta):
|
def total_seconds(timedelta):
|
||||||
|
|
|
@ -5,6 +5,10 @@ Nagios plugin to check the length of the FTS update log.
|
||||||
"""
|
"""
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import sys
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
import psycopg2
|
import psycopg2
|
||||||
|
|
||||||
states = {
|
states = {
|
||||||
|
|
|
@ -1,11 +1,16 @@
|
||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
import dateutil.parser
|
|
||||||
import pytz
|
|
||||||
import subprocess
|
import subprocess
|
||||||
from datetime import datetime, timedelta
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
|
import sys
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
|
import dateutil.parser
|
||||||
|
import pytz
|
||||||
|
|
||||||
states = {
|
states = {
|
||||||
"OK": 0,
|
"OK": 0,
|
||||||
"WARNING": 1,
|
"WARNING": 1,
|
||||||
|
|
|
@ -8,6 +8,20 @@
|
||||||
# search column search_tsvector in the main zerver_message.
|
# search column search_tsvector in the main zerver_message.
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
# We want to use a virtualenv in production, which will be in /home/zulip/deployments/current.
|
||||||
|
# So we should add that path to sys.path and then import scripts.lib.setup_path_on_import.
|
||||||
|
# But this file is also used in development, where the above path will not exist.
|
||||||
|
# So `import scripts.lib.setup_path_on_import` will raise an ImportError.
|
||||||
|
# In development, we just want to skip this step since we know that virtualenv will already be in use.
|
||||||
|
# So catch the ImportError and do nothing.
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
try:
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
except ImportError:
|
||||||
|
pass
|
||||||
|
|
||||||
import psycopg2
|
import psycopg2
|
||||||
import psycopg2.extensions
|
import psycopg2.extensions
|
||||||
import select
|
import select
|
||||||
|
|
|
@ -13,6 +13,10 @@ import datetime
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
import sys
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
import django
|
import django
|
||||||
|
|
||||||
os.environ['DJANGO_SETTINGS_MODULE'] = "zproject.settings"
|
os.environ['DJANGO_SETTINGS_MODULE'] = "zproject.settings"
|
||||||
|
|
|
@ -1,6 +1,11 @@
|
||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import sys
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import logging
|
import logging
|
||||||
|
|
|
@ -49,6 +49,10 @@ import logging.handlers
|
||||||
import subprocess
|
import subprocess
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
import sys
|
||||||
|
sys.path.append('/home/zulip/deployments/current')
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
import boto.utils
|
import boto.utils
|
||||||
import netifaces
|
import netifaces
|
||||||
from six.moves import range
|
from six.moves import range
|
||||||
|
|
|
@ -3,9 +3,13 @@ from __future__ import absolute_import
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
import os
|
import os
|
||||||
|
from os.path import dirname, abspath
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..'))
|
BASE_DIR = dirname(dirname(abspath(__file__)))
|
||||||
|
sys.path.append(BASE_DIR)
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'zproject.settings'
|
os.environ['DJANGO_SETTINGS_MODULE'] = 'zproject.settings'
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,12 @@
|
||||||
import sys
|
import sys
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
sys.path.append(os.path.join(os.path.dirname(__file__), "..", ".."))
|
from os.path import dirname, abspath
|
||||||
|
|
||||||
|
BASE_DIR = dirname(dirname(dirname(abspath(__file__))))
|
||||||
|
sys.path.append(BASE_DIR)
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
"""
|
||||||
|
Use libraries from a virtualenv (by modifying sys.path) in production.
|
||||||
|
Also add Zulip's root directory to sys.path
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
from os.path import dirname, abspath
|
||||||
|
import sys
|
||||||
|
|
||||||
|
BASE_DIR = dirname(dirname(dirname(abspath(__file__))))
|
||||||
|
activate_this = os.path.join(BASE_DIR, "zulip-venv", "bin", "activate_this.py")
|
||||||
|
if os.path.exists(activate_this):
|
||||||
|
# this file will exist in production
|
||||||
|
exec(open(activate_this).read(), {}, dict(__file__=activate_this)) # type: ignore # https://github.com/python/mypy/issues/1577
|
||||||
|
sys.path.append(BASE_DIR)
|
|
@ -3,8 +3,12 @@
|
||||||
|
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
import sys, os, os.path
|
import sys, os, os.path
|
||||||
|
from os.path import dirname, abspath
|
||||||
|
|
||||||
|
BASE_DIR = dirname(dirname(dirname(abspath(__file__))))
|
||||||
|
sys.path.append(BASE_DIR)
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', '..'))
|
|
||||||
os.environ['DJANGO_SETTINGS_MODULE'] = 'zproject.settings'
|
os.environ['DJANGO_SETTINGS_MODULE'] = 'zproject.settings'
|
||||||
|
|
||||||
from django.utils.crypto import get_random_string
|
from django.utils.crypto import get_random_string
|
||||||
|
|
|
@ -14,6 +14,12 @@ framework.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
import os
|
import os
|
||||||
|
from os.path import dirname, abspath
|
||||||
|
import sys
|
||||||
|
|
||||||
|
BASE_DIR = dirname(dirname(abspath(__file__)))
|
||||||
|
sys.path.append(BASE_DIR)
|
||||||
|
import scripts.lib.setup_path_on_import
|
||||||
|
|
||||||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "zproject.settings")
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue