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:
- Nếu quá trình cài đặt của bạn sử dụng Nginx/Postgres, hãy sử dụng phần Nâng cấp cổng thông tin bằng RPM bên dưới.
- Nếu quá trình cài đặt của bạn sử dụng Apache/MySQL hoặc Apache/MariaDB, hãy xem phần Chuyển đổi cổng thông tin dựa trên tar sang cổng thông tin dựa trên RPM.
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
và/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, có dạng như sau:
*: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ổng thông tin phiên bản 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ệ đối với 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 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:
- Thay đổi thành thư mục Drupal,
/opt/apigee/apigee-drupal
theo mặc định:cd /opt/apigee/apigee-drupal
- 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 thông tin.
- 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 theo quy định của 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
- devportal là tên cơ sở dữ liệu do thuộc tính
- 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 Cấu hình > 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). - Sao lưu các tệp trong
/opt/apigee/data/apigee-drupal-devportal/private
. - Đặt Drupal thành chế độ bảo trì:
- Chọn Cấu hình trong trình đơn Drupal.
- Trên trang Cấu hình, hãy chọn Chế độ bảo trì trong mục Phát triển.
- Chọn ô Put site onbảo trì mode (Đặt trang web vào chế độ bảo trì).
- Nhập thông báo mà người dùng thấy trong quá trình bảo trì.
- Chọn Lưu cấu hình.
- Tắt SELinux như mô tả trong phần Cài đặt tiện ích thiết lập apigee-setup của Edge.
- Thay đổi thành thư mục
/opt
:cd /opt
- Để nâng cấp trên máy chủ có kết nối Internet:
- Tải tệp
bootstrap_4.19.06.sh
của Edge 4.19.06 xuống/tmp/bootstrap_4.19.06.sh
:curl https://software.apigee.com/bootstrap_4.19.06.sh -o /tmp/bootstrap_4.19.06.sh
- Cài đặt tiện ích và phần phụ thuộc
apigee-service
của Edge 4.19.06:sudo bash /tmp/bootstrap_4.19.06.sh apigeeuser=uName apigeepassword=pWord
Trong đó, uName và pWord 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.
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.
- Tải tệp
- Để nâng cấp trên máy chủ không có kết nối Internet:
- Tạo một kho lưu trữ cục bộ 4.19.06 như mô tả trong bài viết Tạo kho lưu trữ Apigee cục bộ.
- Cách cài đặt dịch vụ apigee từ tệp .tar:
- 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.19.06.tar.gz
:/opt/apigee/apigee-service/bin/apigee-service apigee-mirror package
- 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 đó vào thư mục
/tmp
trên nút mới. - Trên nút mới, giải nén tệp vào thư mục /tmp:
tar -xzf apigee-4.19.06.tar.gz
Lệnh này sẽ 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.
- Cài đặt tiện ích và các phần phụ thuộc
apigee-service
Edge từ/tmp/repos
:sudo bash /tmp/repos/bootstrap_4.19.06.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.
- 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
- Cách cài đặt apigee-service bằng máy chủ web Nginx:
- Đị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.
- Trên nút từ xa, hãy tải tệp
bootstrap_4.19.06.sh
của Edge xuống/tmp/bootstrap_4.19.06.sh
:/usr/bin/curl http://uName:pWord@remoteRepo:3939/bootstrap_4.19.06.sh -o /tmp/bootstrap_4.19.06.sh
Trong đó, uName và pWord 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ữ.
- Trên nút từ xa, hãy cài đặt tiện ích
apigee-service
của Edge và các phần phụ thuộc:sudo bash /tmp/bootstrap_4.19.06.sh apigeerepohost=remoteRepo:3939 apigeeuser=uName apigeepassword=pWord apigeeprotocol=http://
Trong đó uName và pWord là tên người dùng và mật khẩu kho lưu trữ.
- Sử dụng
apigee-service
để cập nhật tiện íchapigee-setup
:/opt/apigee/apigee-service/bin/apigee-service apigee-setup update
- 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.
- 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 RPM cần loại bỏ.grep php
tìm kiếm tất cả RPM theo PHP.awk '{printf "%s ", $1}'
in tên RPM.
- 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 cổng 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 được tệp cấu hình.
- 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
- Tắt chế độ bảo trì:
- Chọn Configuration (Cấu hình) trong trình đơn Drupal.
- Trên trang Cấu hình, hãy chọn Chế độ bảo trì trong phần Phát triển.
- Bỏ chọn hộp Đặt trang web vào chế độ bảo trì.
- 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 Apigee update
để nâng cấp Edge cho Cloud riêng tư thực sự dẫn đến việc hạ cấp phiên bản Drupal của bạn, 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ụ:
- 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.
- 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.
- Bây giờ bạn đang nâng cấp Private Cloud lê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.