Nâng cấp cổng

Quy trình này mô tả cách nâng cấp một cổng Dịch vụ dành cho nhà phát triển Apigee hiện có (hoặc đơn giản là cổng) được cài đặt tại chỗ.

Xác định quy trình cập nhật chính xác

Quy trình bạn sử dụng để cập nhật cổng thông tin dựa trên chế độ cài đặt hiện tại của bạn:

Xác định loại hình cài đặt hiện tại của bạn

Nếu bạn không chắc chắn về loại cài đặt hiện tại, hãy sử dụng lệnh sau để xác định loại cài đặt:

  • ls /opt

    Nếu đang sử dụng NGINX/Postgres, bạn sẽ thấy các thư mục sau: /opt/apigee/opt/nginx.

    Nếu bạn đang sử dụng Apache/MySQL hoặc Apache/MariaDB, thì các thư mục này sẽ không xuất hiện.

  • /opt/apigee/apigee-service/bin/apigee-all status

    Nếu đang sử dụng NGINX/Postgres, bạn sẽ thấy kết quả sau:

    + apigee-service
    apigee-drupal-devportal status
    OK: apigee-drupal-devportal is up and running
    + apigee-service apigee-lb status
    apigee-service: apigee-lb: OK
    + apigee-service apigee-postgresql status
    apigee-service: apigee-postgresql: OK
  • apachectl -S

    Nếu bạn đang sử dụng Apache/MySQL hoặc Apache/MariaDB, thì lệnh này sẽ trả về thư mục gốc web của cổng thông tin, ở dạng:

    *:80
    192.168.56.102 (/etc/httpd/conf/vhosts/devportal.conf:1)

Thư mục cài đặt mặc định

Quy trình nâng cấp giả định rằng cổng thông tin đã được cài đặt tại:

  • 4.17.05 trở lên: /opt/apigee/apigee-drupal/wwwroot
  • Trước phiên bản 4.17.05: /opt/apigee/apigee-drupal (NGINX) hoặc /var/www/html (Apache)

Nếu bạn không cài đặt cổng thông tin trong thư mục mặc định, hãy sửa đổi các đường dẫn trong quy trình bên dưới để sử dụng thư mục cài đặt của bạn.

Các phiên bản nâng cấp được hỗ trợ

Quy trình nâng cấp này được hỗ trợ trên các phiên bản cổng thông tin OPDK-17-01.x trở lên.

Để xác định phiên bản cổng thông tin, hãy mở URL sau trong trình duyệt:

http://yourportal.com/buildInfo

Trước khi cập nhật

Đối với các bản cài đặt hiện có, nếu bạn đã sửa đổi bất kỳ mã nào trong lõi Drupal hoặc trong bất kỳ mô-đun nào không phải là mô-đun tuỳ chỉnh, thì các nội dung sửa đổi của bạn sẽ bị ghi đè. Trong đó có mọi thay đổi mà bạn có thể đã thực hiện đối với .htaccess. Bạn nên giả định rằng mọi thứ bên ngoài thư mục /sites đều thuộc sở hữu của Drupal. robots.txt là trường hợp ngoại lệ của quy tắc này; nếu tệp này tồn tại trong thư mục gốc của web, thì tệp này sẽ được lưu giữ cho bạn.

Trước khi tiếp tục cài đặt, hãy sao lưu toàn bộ thư mục gốc của trang web Drupal. Sau khi thực hiện các bước cài đặt được mô tả bên dưới, bạn có thể khôi phục các tuỳ chỉnh của mình từ bản sao lưu.

Nâng cấp cổng thông tin bằng RPM

Cách cập nhật RPM của cổng thông tin trên một nút:

  1. Thay đổi thành thư mục Drupal, /opt/apigee/apigee-drupal theo mặc định:
    cd /opt/apigee/apigee-drupal
  2. Sao lưu thực thể cơ sở dữ liệu Drupal. Lệnh pg_dump tạo một bản sao của cơ sở dữ liệu:
    pg_dump --dbname=devportal --host=host_IP_address --username=drupaladmin
      --password --format=c > /tmp/portal.dmp

    Trong trường hợp:

    • devportal là tên cơ sở dữ liệu do thuộc tính PG_NAME chỉ định trong tệp cấu hình cài đặt cổng thông tin.
    • host_IP_address là địa chỉ IP của nút cổng.
    • drupaladmin là tên người dùng Postgres mà cổng thông tin sử dụng để truy cập vào cơ sở dữ liệu như được chỉ định bởi thuộc tính DRUPAL_PG_USER trong tệp cấu hình cài đặt cổng thông tin.

    Bạn sẽ được nhắc nhập mật khẩu người dùng Postgres do thuộc tính DRUPAL_PG_PASS xác định trong tệp cấu hình cài đặt cổng thông tin.

    Nếu sau này bạn muốn khôi phục từ bản sao lưu, hãy sử dụng lệnh sau:

    pg_restore --clean --dbname=devportal --host=localhost  --username=apigee < /tmp/portal.dmp
  3. Sao lưu toàn bộ thư mục gốc của trang web Drupal. Vị trí cài đặt mặc định là /opt/apigee/apigee-drupal, nhưng có thể bạn đã thay đổi vị trí này.

    Nếu bạn không chắc chắn về vị trí của thư mục này, hãy sử dụng lệnh drush status hoặc mục Configuration > Media > File (Cấu hình > Nội dung đa phương tiện > Tệp) trong trình đơn Drupal để xác định vị trí của hệ thống tệp công khai và đường dẫn hệ thống tệp riêng tư (cho bước tiếp theo).

  4. Sao lưu các tệp trong /opt/apigee/data/apigee-drupal-devportal/private.
  5. Đặt Drupal sang chế độ bảo trì:
    1. Chọn Cấu hình trong trình đơn Drupal.
    2. Trên trang Cấu hình, hãy chọn Chế độ bảo trì trong mục Phát triển.
    3. Chọn hộp Đặt trang web vào chế độ bảo trì.
    4. Nhập thông báo mà người dùng nhìn thấy trong quá trình bảo trì.
    5. Chọn Lưu cấu hình.
  6. Tắt SELinux như mô tả trong phần Cài đặt tiện ích thiết lập apigee-setup của Edge.
  7. Thay đổi thành thư mục /opt:
    cd /opt
  8. Để nâng cấp trên máy chủ có kết nối Internet:
    1. Tải tệp bootstrap_4.51.00.sh của Edge 4.51.00 xuống /tmp/bootstrap_4.51.00.sh:
      curl https://software.apigee.com/bootstrap_4.51.00.sh -o /tmp/bootstrap_4.51.00.sh
    2. Cài đặt tiện ích và phần phụ thuộc apigee-service của Edge 4.51.00:
      sudo bash /tmp/bootstrap_4.51.00.sh apigeeuser=uName apigeepassword=pWord

      Trong đó, uNamepWord là tên người dùng và mật khẩu mà bạn nhận được từ Apigee. Nếu bỏ qua pWord, bạn sẽ được nhắc nhập giá trị này.

      Theo mặc định, trình cài đặt sẽ kiểm tra để đảm bảo bạn đã cài đặt Java 1.8. Bạn có thể sử dụng tuỳ chọn "C" để tiếp tục mà không cần cài đặt Java.

  9. Để nâng cấp trên máy chủ không có kết nối Internet:
    1. Tạo kho lưu trữ 4.51.00 cục bộ như mô tả trong phần Tạo kho lưu trữ Apigee cục bộ.
    2. Cách cài đặt apigee-service từ tệp .tar:
      1. Trên nút có kho lưu trữ cục bộ, hãy sử dụng lệnh sau để đóng gói kho lưu trữ cục bộ vào một tệp .tar duy nhất có tên /opt/apigee/data/apigee-mirror/apigee-4.51.00.tar.gz:
        /opt/apigee/apigee-service/bin/apigee-service apigee-mirror package
      2. Sao chép tệp .tar vào nút mà bạn muốn cập nhật Edge. Ví dụ: sao chép tệp này vào thư mục /tmp trên nút mới.
      3. Trên nút mới, giải nén tệp vào thư mục /tmp:
        tar -xzf apigee-4.51.00.tar.gz

        Lệnh này tạo một thư mục mới có tên là repos trong thư mục chứa tệp .tar. Ví dụ: /tmp/repos.

      4. Cài đặt tiện ích apigee-service và các phần phụ thuộc của Edge từ /tmp/repos:
        sudo bash /tmp/repos/bootstrap_4.51.00.sh apigeeprotocol="file://" apigeerepobasepath=/tmp/repos

        Lưu ý rằng bạn phải thêm đường dẫn đến thư mục kho lưu trữ trong lệnh này.

    3. Cách cài đặt apigee-service bằng máy chủ web NGINX:
      1. Định cấu hình máy chủ web NGINX như mô tả trong phần "Cài đặt từ kho lưu trữ bằng máy chủ web NGINX" tại phần Cài đặt tiện ích thiết lập API Edge.
      2. Trên nút từ xa, hãy tải tệp bootstrap_4.51.00.sh của Edge xuống /tmp/bootstrap_4.51.00.sh:
        /usr/bin/curl http://uName:pWord@remoteRepo:3939/bootstrap_4.51.00.sh
          -o /tmp/bootstrap_4.51.00.sh

        Trong đó, uNamepWord là tên người dùng và mật khẩu mà bạn đã đặt ở trên cho kho lưu trữ, còn remoteRepo là địa chỉ IP hoặc tên DNS của nút kho lưu trữ.

      3. Trên nút từ xa, hãy cài đặt tiện ích apigee-service và các phần phụ thuộc của Edge:
        sudo bash /tmp/bootstrap_4.51.00.sh apigeerepohost=remoteRepo:3939
          apigeeuser=uName apigeepassword=pWord apigeeprotocol=http://

        Trong đó uNamepWord là tên người dùng và mật khẩu của kho lưu trữ.

  10. Sử dụng apigee-service để cập nhật tiện ích apigee-setup:
    /opt/apigee/apigee-service/bin/apigee-service apigee-setup update
  11. Chạy tiện ích update trên nút Postgres:
    /opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile

    Trong đó configFile là tệp cấu hình mà bạn đã dùng để cài đặt cơ sở dữ liệu Postgres. Yêu cầu duy nhất đối với tệp cấu hình là người dùng "apigee" phải có thể truy cập hoặc đọc tệp cấu hình.

  12. Xoá các RPM PHP nhưng không xoá các phần phụ thuộc RPM của Apigee Drupal Devportal bằng cách thực thi lệnh sau:
    rpm -ev --nodeps $(rpm -qa | grep php | awk '{printf "%s ", $1}')

    Lệnh này thực hiện những việc sau:

    • rpm -ev --nodeps xoá các RPM nhưng không xoá các phần phụ thuộc của RPM.
    • rpm -qa tạo danh sách các RPM cần xoá.
    • grep php tìm kiếm tất cả RPM PHP.
    • awk '{printf "%s ", $1}' in tên RPM.
  13. Chạy tiện ích update trên nút của bạn để cập nhật cổng thông tin:
    /opt/apigee/apigee-setup/bin/update.sh -c dp -f configFile

    Trong đó, configFile là tệp cấu hình mà bạn đã dùng để cài đặt trang thông tin. Yêu cầu duy nhất đối với tệp cấu hình là người dùng "apigee" phải có thể truy cập hoặc đọc tệp cấu hình.

  14. Chạy tập lệnh update.php của Drupal bằng cách mở URL sau trong cửa sổ trình duyệt:
    http://portal_IP_DNS:8079/update.php
  15. Tắt chế độ bảo trì:
    1. Chọn Configuration (Cấu hình) trong trình đơn Drupal.
    2. Trên trang Cấu hình, hãy chọn Chế độ bảo trì trong mục Phát triển.
    3. Bỏ chọn hộp Đặt trang web vào chế độ bảo trì.
    4. Chọn Lưu cấu hình.

Lưu ý rằng thư mục gốc sau khi cập nhật là:

/opt/apigee/apigee-drupal/wwwroot

Quá trình nâng cấp đã hoàn tất. Nếu tiện ích update của Apigee hạ cấp phiên bản Drupal, bạn có thể phải chạy lại tiện ích nâng cấp Drupal. Để biết thêm thông tin, hãy xem phần Chạy lại quá trình nâng cấp Drupal.

Chạy lại quy trình nâng cấp Drupal

Nếu việc chạy tiện ích update của Apigee để nâng cấp Edge cho Private Cloud thực sự dẫn đến việc hạ cấp phiên bản Drupal, hãy cài đặt lại bản nâng cấp Drupal. Điều này có thể xảy ra nếu bạn chỉ nâng cấp Drupal trong khoảng thời gian cập nhật Private Cloud.

Ví dụ:

  1. Bạn đang chạy phiên bản 4.18.05 của Edge for Private Cloud, bao gồm cả Drupal 7.59.
  2. Bạn đã nâng cấp Drupal lên phiên bản 7.64 do có bản cập nhật bảo mật bắt buộc.
  3. Bạn hiện đang nâng cấp Private Cloud lên phiên bản 4.19.01, bao gồm cả Drupal 7.61.

Như trường hợp này minh hoạ, phiên bản Drupal mà tiện ích update của Apigee sử dụng có thể không tham chiếu đến bản nâng cấp Drupal mới nhất. Do đó, bạn phải chạy lại quá trình nâng cấp Drupal để đưa quá trình cài đặt Drupal trở về phiên bản mới hơn.