upgrade.sh 4.9 KB

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