upgrade.sh 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #!/bin/bash
  2. # This script will prepare NetBox to run after the code has been upgraded to
  3. # its most recent release.
  4. # This script will invoke Python with the value of the PYTHON environment
  5. # variable (if set), or fall back to "python3". Note that NetBox v3.2+ requires
  6. # Python 3.8 or later.
  7. cd "$(dirname "$0")"
  8. NETBOX_VERSION="$(grep ^VERSION netbox/netbox/settings.py | cut -d\' -f2)"
  9. echo "You are installing (or upgrading to) NetBox version ${NETBOX_VERSION}"
  10. VIRTUALENV="$(pwd -P)/venv"
  11. PYTHON="${PYTHON:-python3}"
  12. # Validate the minimum required Python version
  13. COMMAND="${PYTHON} -c 'import sys; exit(1 if sys.version_info < (3, 8) else 0)'"
  14. PYTHON_VERSION=$(eval "${PYTHON} -V")
  15. eval $COMMAND || {
  16. echo "--------------------------------------------------------------------"
  17. echo "ERROR: Unsupported Python version: ${PYTHON_VERSION}. NetBox requires"
  18. echo "Python 3.8 or later. To specify an alternate Python executable, set"
  19. echo "the PYTHON environment variable. For example:"
  20. echo ""
  21. echo " sudo PYTHON=/usr/bin/python3.8 ./upgrade.sh"
  22. echo ""
  23. echo "To show your current Python version: ${PYTHON} -V"
  24. echo "--------------------------------------------------------------------"
  25. exit 1
  26. }
  27. echo "Using ${PYTHON_VERSION}"
  28. # Remove the existing virtual environment (if any)
  29. if [ -d "$VIRTUALENV" ]; then
  30. COMMAND="rm -rf ${VIRTUALENV}"
  31. echo "Removing old virtual environment..."
  32. eval $COMMAND
  33. else
  34. WARN_MISSING_VENV=1
  35. fi
  36. # Create a new virtual environment
  37. COMMAND="${PYTHON} -m venv ${VIRTUALENV}"
  38. echo "Creating a new virtual environment at ${VIRTUALENV}..."
  39. eval $COMMAND || {
  40. echo "--------------------------------------------------------------------"
  41. echo "ERROR: Failed to create the virtual environment. Check that you have"
  42. echo "the required system packages installed and the following path is"
  43. echo "writable: ${VIRTUALENV}"
  44. echo "--------------------------------------------------------------------"
  45. exit 1
  46. }
  47. # Activate the virtual environment
  48. source "${VIRTUALENV}/bin/activate"
  49. # Upgrade pip
  50. COMMAND="pip install --upgrade pip"
  51. echo "Updating pip ($COMMAND)..."
  52. eval $COMMAND || exit 1
  53. pip -V
  54. # Install necessary system packages
  55. COMMAND="pip install wheel"
  56. echo "Installing Python system packages ($COMMAND)..."
  57. eval $COMMAND || exit 1
  58. # Install required Python packages
  59. COMMAND="pip install -r requirements.txt"
  60. echo "Installing core dependencies ($COMMAND)..."
  61. eval $COMMAND || exit 1
  62. # Install optional packages (if any)
  63. if [ -s "local_requirements.txt" ]; then
  64. COMMAND="pip install -r local_requirements.txt"
  65. echo "Installing local dependencies ($COMMAND)..."
  66. eval $COMMAND || exit 1
  67. elif [ -f "local_requirements.txt" ]; then
  68. echo "Skipping local dependencies (local_requirements.txt is empty)"
  69. else
  70. echo "Skipping local dependencies (local_requirements.txt not found)"
  71. fi
  72. # Apply any database migrations
  73. COMMAND="python3 netbox/manage.py migrate"
  74. echo "Applying database migrations ($COMMAND)..."
  75. eval $COMMAND || exit 1
  76. # Trace any missing cable paths (not typically needed)
  77. COMMAND="python3 netbox/manage.py trace_paths --no-input"
  78. echo "Checking for missing cable paths ($COMMAND)..."
  79. eval $COMMAND || exit 1
  80. # Build the local documentation
  81. COMMAND="mkdocs build"
  82. echo "Building documentation ($COMMAND)..."
  83. eval $COMMAND || exit 1
  84. # Collect static files
  85. COMMAND="python3 netbox/manage.py collectstatic --no-input"
  86. echo "Collecting static files ($COMMAND)..."
  87. eval $COMMAND || exit 1
  88. # Delete any stale content types
  89. COMMAND="python3 netbox/manage.py remove_stale_contenttypes --no-input"
  90. echo "Removing stale content types ($COMMAND)..."
  91. eval $COMMAND || exit 1
  92. # Rebuild the search cache (lazily)
  93. COMMAND="python3 netbox/manage.py reindex --lazy"
  94. echo "Rebuilding search cache ($COMMAND)..."
  95. eval $COMMAND || exit 1
  96. # Delete any expired user sessions
  97. COMMAND="python3 netbox/manage.py clearsessions"
  98. echo "Removing expired user sessions ($COMMAND)..."
  99. eval $COMMAND || exit 1
  100. if [ -v WARN_MISSING_VENV ]; then
  101. echo "--------------------------------------------------------------------"
  102. echo "WARNING: No existing virtual environment was detected. A new one has"
  103. echo "been created. Update your systemd service files to reflect the new"
  104. echo "Python and gunicorn executables. (If this is a new installation,"
  105. echo "this warning can be ignored.)"
  106. echo ""
  107. echo "netbox.service ExecStart:"
  108. echo " ${VIRTUALENV}/bin/gunicorn"
  109. echo ""
  110. echo "netbox-rq.service ExecStart:"
  111. echo " ${VIRTUALENV}/bin/python"
  112. echo ""
  113. echo "After modifying these files, reload the systemctl daemon:"
  114. echo " > systemctl daemon-reload"
  115. echo "--------------------------------------------------------------------"
  116. fi
  117. echo "Upgrade complete! Don't forget to restart the NetBox services:"
  118. echo " > sudo systemctl restart netbox netbox-rq"