Apigee 支持将适用于私有云的 Edge 从 4.50.00 或 4.51.00 版本直接升级到 4.52.00 版本。本页介绍了如何执行这两种升级。
谁可以执行更新
运行更新的用户应与最初安装 Edge 的用户相同,或者是运行以 root 身份运行的用户。
安装 Edge RPM 后,任何人都可以对其进行配置。
您必须更新哪些组件
您必须更新所有 Edge 组件。Edge 不支持包含来自多个版本的组件的设置。
更新前提条件
在升级 Apigee Edge 之前,请确保满足以下前提条件:
- 备份所有节点
出于安全考虑,我们建议您在更新之前对所有节点执行完整备份。请按照适用于当前 Edge 版本的过程执行备份。这样,您就可以制定备用方案,以防更新到新版本时出现问题。如需详细了解备份,请参阅备份和恢复。
- 确保 Edge 正在运行
使用以下命令确保 Edge 在更新过程中已启动并运行:/opt/apigee/apigee-service/bin/apigee-all status
- 确保 Cassandra 压缩策略为
LeveledCompactionStrategy
确保将 Cassandra 兼容性策略设置为LeveledCompactionStrategy
,如更改 Cassandra 压缩策略中所述。
自动传播房源设置
如果您通过修改 /opt/apigee/customer/application
中的 .properties
文件设置了任何属性,则更新会保留这些值。
必须升级到 ZooKeeper 3.8.0
此适用于私有云的 Edge 版本包含对 ZooKeeper 3.8.0 的升级。在此次升级过程中,所有 Zookeeper 数据都将迁移到 Zookeeper 3.8.0。
在升级 Zookeeper 之前,请仔细阅读 Zookeeper 维护指南。大多数 Edge 生产系统都使用分布在多个数据中心的一组 Zookeeper 节点。其中一些节点配置为参与 ZooKeeper 主副本选举的投票者,其余节点配置为观察器。 如需了解详情,请参阅 关于领导者、关注者、选民和观察者。投票节点会选举出主节点,然后投票节点本身会成为从节点。
在更新过程中,当主节点关闭时,Zookeeper 可能会出现短暂延迟或写入失败。这可能会影响写入 Zookeeper 的管理操作(例如代理的部署操作)和 Apigee 基础架构更改(例如添加或移除消息处理器等)。在按照以下步骤升级 Zookeeper 时,对 Apigee 的运行时 API 应该没有影响(除非这些运行时 API 调用管理 API)。
概括来讲,升级过程涉及对每个节点进行备份。接下来,升级所有观察器和跟随者,最后升级主节点。
备份
备份 Zookeeper 的所有节点,以便在需要回滚时使用。请注意,回滚会将 Zookeeper 恢复到进行备份时的状态。注意:自备份以来 Apigee 中的任何部署或基础架构更改(其信息存储在 Zookeeper 中)都将在恢复期间丢失。
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper backup
如果您使用的是虚拟机且具备相应功能,还可以创建虚拟机快照或备份,以便进行恢复或回滚(如有必要)。
确定主副本和观察器
注意:以下示例命令使用 nc 实用程序将数据发送到 ZooKeeper。您还可以使用其他实用程序将数据发送到 Zookeeper。
- 如果 ZooKeeper 节点上未安装 nc,请安装 nc:
sudo yum install nc
- 在节点上运行以下 nc 命令,其中 2181 是 ZooKeeper 端口:
echo stat | nc localhost 2181
您应该会看到如下所示的输出:
Zookeeper version: 3.8.0-5a02a05eddb59aee6ac762f7ea82e92a68eb9c0f, built on 2022-02-25 08:49 UTC Clients: /0:0:0:0:0:0:0:1:41246[0](queued=0,recved=1,sent=0) Latency min/avg/max: 0/0.2518/41 Received: 647228 Sent: 647339 Connections: 4 Outstanding: 0 Zxid: 0x400018b15 Mode: follower Node count: 100597
在节点输出的
Mode
行中,您应该会看到“观察器”“主副本”或“从属”(即非主副本的投票者),具体取决于节点配置。 注意:在只有一个 ZooKeeper 节点的独立 Edge 安装中,Mode
会设为独立。 - 在每个 ZooKeeper 节点上重复第 1 步和第 2 步。
在观察器节点和从属节点上升级 Zookeeper
在每个观察器节点和从属节点上升级 Zookeeper,如下所示:
- 下载并运行 Edge for Private Cloud 4.52 的引导程序,如在具有外部互联网连接的节点上更新到 4.52.00中所述。具体流程可能会因节点是否有外部互联网连接或您是否执行离线安装而异。
- 升级 Zookeeper 组件:
注意:如果这些节点安装了其他组件(例如 Cassandra),您现在也可以升级它们(例如使用 cs,zk 配置文件),也可以稍后升级其他组件。Apigee 建议您先升级 Zookeeper,确保集群正常运行,然后再升级其他组件。/opt/apigee/apigee-setup/bin/update.sh -c zk -f <silent-config-file>
- 在每个 Zookeeper 观察器和跟随者节点上重复上述步骤。
关闭主副本
完成所有观测器节点和关注者节点的升级后,关停主要节点。在被标识为主节点的节点上,运行以下命令:
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper stop
请注意,在此事件期间,在选出新的主副本之前,Zookeeper 可能会出现暂时延迟或写入失败。这可能会影响写入 Zookeeper 的操作,例如代理的部署操作或 Apigee 基础架构更改(例如添加或移除消息处理器等)。
验证是否已选举出新的主副本
使用上文确定主副本、从属副本和观察器部分中的步骤,验证是否已从从属副本中选出新的主副本(在现有主副本停止后)。请注意,领导者可能是在与当前领导者不同的数据中心中选出的。
升级主副本
请按照上文在观察器节点和跟随节点上升级 Zookeeper中的步骤操作。
旧主要节点也升级后,请验证集群运行状况并确保存在主要节点。
回滚
如果需要回滚,请执行以下操作:
- 请先对观察器和跟随者执行回滚步骤。
- 下载并执行要回滚到的版本(4.50 或 4.51)的引导程序。 此过程可能会有所不同,具体取决于节点是具有外部互联网连接还是进行离线安装。
- 如果 ZooKeeper 在节点上运行,请停止它:
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper stop
- 卸载现有的 zookeeper:
/opt/apigee/apigee-service/bin/apigee-service apigee-zookeeper uninstall
/opt/apigee/apigee-setup/bin/setup.sh -p zk -f <silent-config-file>
恢复备份
请参阅从备份恢复。 请注意,从早期版本的适用于私有云的 Edge(例如 4.50 和 4.51)获取的 ZooKeeper 备份应该与适用于 Private Cloud 4.52 的 Edge 中的 ZooKeeper 版本兼容。
必须升级到 Postgres 14
此版本的 Edge 包含对 Postgres 14 的升级。在升级过程中,所有 Postgres 数据都会迁移到 Postgres 14。
大多数 Edge 生产系统使用两个针对主备用复制配置的 Postgres 节点。在更新过程中,当 Postgres 节点停机更新时,分析数据仍会写入 Qpid 节点。更新 Postgres 节点并恢复在线状态后,系统会将分析数据推送到 Postgres 节点。
执行 Postgres 更新的方式取决于您为 Postgres 节点配置数据存储的方式:
- 如果您为 Postgres 节点使用本地数据存储,则必须在升级期间安装新的 Postgres 备用节点。升级完成后,您可以停用新的 Postgres 备用节点。
如果您因任何原因必须回滚更新,则必须使用额外的 Postgres 备用节点。如果您必须回滚更新,则新的 Postgres 备用节点会在回滚后成为主 Postgres 节点。因此,在安装新的 Postgres 备用节点时,它应位于满足 Edge 安装要求中所定义的 Postgres 服务器所有硬件要求的节点上。
在 Edge 的 1 节点和 2 节点配置(用于原型设计和测试的拓扑)中,您只有一个 Postgres 节点。您可以直接更新这些 Postgres 节点,而无需创建新的 Postgres 节点。
- 如果您为 Postgres 节点使用网络存储空间(根据 Apigee 的建议),则无需安装新的 Postgres 节点。在以下流程中,您可以跳过指定安装并稍后停用新的 Postgres 备用节点的步骤。
在开始更新流程之前,请先为 Postgres 使用的存储区创建网络快照。然后,如果更新期间发生任何错误,并且您被迫执行回滚,则可以从该快照恢复 Postgres 节点。
安装新的 Postgres 备用节点
此过程会在新节点上创建一个 Postgres 备用服务器。请确保为现有 Edge 版本(4.50.00 或 4.51.00)安装新的 Postgres 备用服务器,而不是为 4.52.00 版本安装。
如需执行安装,请使用您用于安装当前 Edge 版本的同一配置文件。
如需创建新的 Postgres 备用节点,请执行以下操作:
- 在当前的 Postgres 主服务器上,修改
/opt/apigee/customer/application/postgresql.properties
文件以设置以下令牌。如果该文件不存在,请创建:conf_pg_hba_replication.connection=host replication apigee existing_standby_ip/32 trust\ \nhost replication apigee new_standby_ip/32 trust
其中,existing_standby_ip 是当前 Postgres 备用服务器的 IP 地址,new_standby_ip 是新备用节点的 IP 地址。
- 在 Postgres 主服务器上重启
apigee-postgresql
:/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql restart
- 查看主服务器上的
/opt/apigee/apigee-postgresql/conf/pg_hba.conf
文件,验证是否已添加新的待机节点。您应该会在该文件中看到以下行:host replication apigee existing_standby_ip/32 trust host replication apigee new_standby_ip/32 trust
- 安装新的 Postgres 备用服务器:
- 修改您用于安装当前版本 Edge 的配置文件,以指定以下内容:
# IP address of the current master: PG_MASTER=192.168.56.103 # IP address of the new standby node PG_STANDBY=192.168.56.102
- 按照安装 Edge apigee-setup 实用程序中的说明停用 SELinux。
如果您目前使用的是 Edge 4.51.00:
- 将 Edge bootstrap_4.51.00.sh 文件下载到
/tmp/bootstrap_4.51.00.sh
:curl https://software.apigee.com/bootstrap_4.51.00.sh -o /tmp/bootstrap_4.51.00.sh
- 安装 Edge
apigee-service
实用程序和依赖项:sudo bash /tmp/bootstrap_4.51.00.sh apigeeuser=uName apigeepassword=pWord
如果您目前使用的是 Edge 4.50.00:
- 将 Edge bootstrap_4.50.00.sh 文件下载到
/tmp/bootstrap_4.50.00.sh
:curl https://software.apigee.com/bootstrap_4.50.00.sh -o /tmp/bootstrap_4.50.00.sh
- 安装 Edge
apigee-service
实用程序和依赖项:sudo bash /tmp/bootstrap_4.50.00.sh apigeeuser=uName apigeepassword=pWord
- 将 Edge bootstrap_4.51.00.sh 文件下载到
- 使用
apigee-service
安装apigee-setup
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-setup install
- 安装 Postgres:
/opt/apigee/apigee-setup/bin/setup.sh -p ps -f configFile
- 在新的主备节点上,运行以下命令:
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql postgres-check-standby
确认它处于待机状态。
- 修改您用于安装当前版本 Edge 的配置文件,以指定以下内容:
执行 Postgres 的就地升级
预备步骤
在对主机和备用主机执行到 Postgres 的原位升级之前,请执行以下步骤,以更新 apigee-postgresql
上的 max_locks_per_transaction
属性:
- 如果不存在,请创建文件
/opt/apigee/customer/application/postgresql.properties
。 - 将此文件的所有权更改为
apigee
:sudo chown apigee:apigee /opt/apigee/customer/application/postgresql.properties
- 将以下属性添加到文件中:
conf/postgresql.conf+max_locks_per_transaction=30000
- 配置
apigee-postgresql
:apigee-service apigee-postgresql configure
- 重启
apigee-postgresql
:apigee-service apigee-postgresql restart
执行就地升级
如需执行到 Postgres 14 的就地升级,请执行以下步骤:
- 升级主机上的 postgres
/opt/apigee/apigee-setup/bin/update.sh -c ps -f /opt/silent.conf
- 在主机上运行设置命令:
apigee-service apigee-postgresql setup -f /opt/silent.conf
- 在主机上运行 configure 命令:
apigee-service apigee-postgresql configure
- 重启主实例主机:
apigee-service apigee-postgresql restart
- 将其配置为主服务器:
apigee-service apigee-postgresql setup-replication-on-master -f /opt/silent.conf
- 确保主实例主机已启动:
apigee-service apigee-postgresql wait_for_ready
- 停止待机:
apigee-service apigee-postgresql stop
- 升级备用实例。
注意:如果此步骤出现错误/失败,可以忽略。
update.sh
会尝试使用错误的配置启动待机服务器。只要 Postgres 安装升级到 14,就可以忽略该错误。/opt/apigee/apigee-setup/bin/update.sh -c ps -f /opt/silent.conf
- 确保待机已停止:
apigee-service apigee-postgresql stop
- 移除旧的备用配置:
rm -rf /opt/apigee/data/apigee-postgresql/
- 在备用服务器上设置复制:
apigee-service apigee-postgresql setup-replication-on-standby -f /opt/silent.conf
- 从主主机和备用上的文件
/opt/apigee/customer/application/postgresql.properties
中移除conf/postgresql.conf+max_locks_per_transaction=30000
行。此行是在预备步骤中添加的。
完成此过程后,备用设备将成功启动。
停用 Postgres 节点
更新完成后,停用新的备用节点:
- 确保 Postgres 正在运行:
/opt/apigee/apigee-service/bin/apigee-all status
如果 Postgres 未运行,请启动它:
/opt/apigee/apigee-service/bin/apigee-all start
- 在新的待机节点上运行以下
curl
命令,获取新的待机节点的 UUID:curl -u sysAdminEmail:password http://node_IP:8084/v1/servers/self
您应该会在输出末尾看到节点的 UUID,格式如下:
"type" : [ "postgres-server" ], "uUID" : "599e8ebf-5d69-4ae4-aa71-154970a8ec75"
- 在新的备用节点上运行以下命令,停止新的备用节点:
/opt/apigee/apigee-service/bin/apigee-all stop
- 在 Postgres 主实例节点上,修改
/opt/apigee/customer/application/postgresql.properties
以从conf_pg_hba_replication.connection
中移除新的备用节点:conf_pg_hba_replication.connection=host replication apigee existing_standby_ip/32 trust
- 在 Postgres 主服务器上重启 apigee-postgresql:
/opt/apigee/apigee-service/bin/apigee-service apigee-postgresql restart
- 通过查看主实例上的
/opt/apigee/apigee-postgresql/conf/pg_hba.conf
文件,验证新的备用节点是否已移除。您应该只会在该文件中看到以下一行:host replication apigee existing_standby_ip/32 trust
- 在管理服务器节点上执行以下 Edge 管理 API 调用,从 ZooKeeper 中删除待机节点的 UUID:
curl -u sysAdminEmail:password -X DELETE http://ms_IP:8080/v1/servers/new_standby_uuid
Postgres 的升级后步骤
在对 Postgres 进行重大升级后,Postgres 的内部统计信息会被清除。这些统计信息有助于 Postgres 查询规划器利用最佳索引和路径来执行查询。
随着查询的执行和 autovacuum 守护程序的运行,Postgres 会逐渐重建其统计信息。不过,在重新构建统计信息之前,您的查询速度可能会很慢。
如需解决此问题,请对主 Postgres 节点上数据库中的所有表执行 ANALYZE
。或者,您也可以一次针对多个表执行 ANALYZE
。
新版 Edge 界面
本部分列出了有关 Edge 界面的注意事项。如需了解详情,请参阅适用于私有云的新 Edge 界面。
安装 Edge 界面
完成初始安装后,Apigee 建议您安装 Edge 界面,这是一个面向私有云的 Apigee Edge 开发者和管理员的增强界面。
请注意,Edge 界面要求您停用基本身份验证,并使用 SAML 或 LDAP 等 IDP。
如需了解详情,请参阅安装新的 Edge 界面。
更新 Edge 界面
如需更新 Edge 界面组件,请考虑您要从哪个版本的 Edge for Private Cloud 升级:
- 从 4.51.00 升级到 4.52.00(已安装新的 Edge 界面):请针对
edge-management-ui
组件使用本部分中的升级说明。
更新为 Apigee mTLS
如需更新 Apigee mTLS,请执行以下步骤:
回滚更新
如果更新失败,您可以尝试解决问题,然后再次执行 update.sh
。您可以多次运行此更新,系统会从上次中断的位置继续更新。
如果失败导致您需要将更新回滚到之前的版本,请参阅回滚 4.52.00 了解详细说明。
日志记录更新信息
默认情况下,update.sh
实用程序会将日志信息写入以下位置:
/opt/apigee/var/log/apigee-setup/update.log
如果运行 update.sh
实用程序的用户无权访问该目录,则该实用程序会将日志写入 /tmp
目录,并将其命名为 update_username.log
。
如果用户无权访问 /tmp
,update.sh
实用程序将失败。
零停机时间更新
零停机更新(也称为滚动更新)可让您在不停用 Edge 的情况下更新 Edge 安装。
只有采用 5 个节点及更大节点的配置才能实现零停机更新。
实现零停机升级的关键是从负载均衡器中逐个移除每个路由器。然后,更新与路由器位于同一计算机上的路由器和任何其他组件,然后将路由器重新添加到负载均衡器。
- 按照机器更新顺序中的说明,按正确的顺序更新机器。
- 要更新路由器,请选择任意一个路由器并使其无法访问,如启用/停用服务器(消息处理器/路由器)可达性中所述。
- 在与路由器位于同一台机器上更新所选路由器和所有其他 Edge 组件。 所有 Edge 配置都会在同一节点上显示路由器和消息处理器。
- 使路由器再次可访问。
- 对其余路由器重复第 2 步到第 4 步。
- 为安装中的所有剩余机器继续更新。
请在更新前后注意以下事项:
- 在路由器和消息处理器组合节点上:
- 更新前 - 执行以下操作:
- 使路由器不可访问。
- 使消息处理器不可访问。
- 更新后,请执行以下操作:
- 使消息处理器可访问。
- 使路由器可访问。
- 更新前 - 执行以下操作:
- 在单个路由器节点上:
- 在单个消息处理器节点上:
- 在更新之前,使消息处理器不可访问。
- 更新后,使消息处理器可访问。
使用静默配置文件
您必须将静默配置文件传递给 update 命令。静默配置文件应与您安装 Edge 4.50.00 或 4.51.00 时使用的配置文件相同。
在具有外部互联网连接的节点上更新到 4.52.00
按照以下步骤更新节点上的 Edge 组件:
- 在更新完成之前,停用配置为对 Cassandra 执行修复操作的所有
cron
作业(如果有)。 - 以 root 用户身份登录节点以安装 Edge RPM。
- 安装
yum-utils
和yum-plugin-priorities
:sudo yum install yum-utils
sudo yum install yum-plugin-priorities
- 停用 SELinux,如安装 Edge apigee-setup 实用程序中所述。
- 如果您是在 Oracle 7.x 上安装,请执行以下命令:
sudo yum-config-manager --enable ol7_optional_latest
- 如果要在 AWS 上安装,请执行以下
yum-configure-manager
命令:yum update rh-amazon-rhui-client.noarch
sudo yum-config-manager --enable rhui-REGION-rhel-server-extras rhui-REGION-rhel-server-optional
如果您目前使用的是 Edge 4.51.00:
- 将 Edge
bootstrap_4.52.00.sh
文件下载到/tmp/bootstrap_4.52.00.sh
:curl https://software.apigee.com/bootstrap_4.51.00.sh -o /tmp/bootstrap_4.51.00.sh
- 运行以下命令,安装 Edge 4.52.00
apigee-service
实用程序和依赖项:sudo bash /tmp/bootstrap_4.52.00.sh apigeeuser=uName apigeepassword=pWord
其中,uName:pWord 是您从 Apigee 收到的用户名和密码。如果您省略 pWord,系统会提示您输入。
默认情况下,安装程序会检查您是否安装了 Java 1.8。如果没有,安装程序会为您安装该工具。
使用
JAVA_FIX
选项指定如何处理 Java 安装。JAVA_FIX
采用以下值:I
:安装 OpenJDK 1.8(默认)。C
:继续,不安装 Java。Q
:退出。如果选择此选项,您必须自行安装 Java。
- 使用
apigee-service
更新apigee-setup
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-setup update
- 更新管理服务器上的
apigee-validate
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-validate update
- 更新管理服务器上的
apigee-provision
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-provision update
- 通过执行以下命令,在节点上运行
update
实用程序:/opt/apigee/apigee-setup/bin/update.sh -c component -f configFile
请按照机器更新顺序中所述的顺序执行此操作。
其中:
- component 是要更新的 Edge 组件。可能的值包括:
cs
:Cassandraedge
:所有 Edge 组件(边缘界面除外):管理服务器、消息处理器、路由器、QPID 服务器、Postgres 服务器ldap
:OpenLDAPps
:postgresqlqpid
:qpiddsso
:Apigee SSO(如果您已安装 SSO)ue
:新的 Edge 界面ui
:Edge 经典版界面zk
:Zookeeper
- configFile 是您在安装 4.50.00 或 4.51.00 时用于定义 Edge 组件的配置文件。
您可以通过将 component 设置为“all”来针对所有组件运行
update.sh
,但前提是您拥有 Edge 多合一 (AIO) 安装配置文件。例如:/opt/apigee/apigee-setup/bin/update.sh -c all -f ./sa_silent_config
- component 是要更新的 Edge 组件。可能的值包括:
- 在运行 Edge 界面组件的所有节点上重启该组件(如果尚未重启):
/opt/apigee/apigee-service/bin/apigee-service edge-ui restart
- 在管理服务器上运行
apigee-validate
实用程序,以测试更新(如测试安装中所述)。
如果您以后决定回滚更新,请按照回滚 4.52.00 中所述的步骤进行操作。
从本地代码库更新到 4.52.00
如果您的 Edge 节点受防火墙保护,或以其他方式被禁止通过互联网访问 Apigee 代码库,则您可以从 Apigee 代码库的本地代码库(或镜像)执行更新。
创建本地 Edge 代码库后,您可以通过以下两种方式从本地代码库更新 Edge:
- 创建代码库的 .tar 文件,将 .tar 文件复制到节点,然后从 .tar 文件更新 Edge。
- 在包含本地代码库的节点上安装 Web 服务器,以便其他节点可以访问该代码库。 Apigee 提供了 Nginx Web 服务器供您使用,您也可以使用自己的 Web 服务器。
如需从本地 4.52.00 代码库更新,请执行以下操作:
- 按照安装 Edge apigee-setup 实用程序中的“创建本地 Apigee 代码库”部分中的说明创建本地 4.52.00 代码库。
- 如需从 .tar 文件安装 apigee-service,请执行以下操作:
- 在具有本地代码库的节点上,使用以下命令将本地代码库打包到一个名为
/opt/apigee/data/apigee-mirror/apigee-4.52.00.tar.gz
的单个 .tar 文件中:/opt/apigee/apigee-service/bin/apigee-service apigee-mirror package
- 将 .tar 文件复制到您要更新 Edge 的节点。例如,将其复制到新节点上的
/tmp
目录。 - 在新节点上,将文件解压缩到
/tmp
目录:tar -xzf apigee-4.52.00.tar.gz
此命令会在包含 .tar 文件的目录中创建一个名为
repos
的新目录。例如/tmp/repos
。 - 从
/tmp/repos
安装 Edgeapigee-service
实用程序和依赖项:sudo bash /tmp/repos/bootstrap_4.52.00.sh apigeeprotocol="file://" apigeerepobasepath=/tmp/repos
请注意,您需要在此命令中添加代码库目录的路径。
- 在具有本地代码库的节点上,使用以下命令将本地代码库打包到一个名为
- 如需使用 Nginx Web 服务器安装 apigee-service,请执行以下操作:
- 按照安装 Edge apigee-setup 实用程序中的“使用 Nginx Web 服务器从代码库安装”部分中的说明配置 Nginx Web 服务器。
- 在远程节点上,将 Edge
bootstrap_4.52.00.sh
文件下载到/tmp/bootstrap_4.52.00.sh
:/usr/bin/curl http://uName:pWord@remoteRepo:3939/bootstrap_4.52.00.sh -o /tmp/bootstrap_4.52.00.sh
其中 uName:pWord 是您之前为代码库设置的用户名和密码,remoteRepo 是代码库节点的 IP 地址或 DNS 名称。
- 在远程节点上,安装 Edge
apigee-setup
实用程序和依赖项:sudo bash /tmp/bootstrap_4.52.00.sh apigeerepohost=remoteRepo:3939 apigeeuser=uName apigeepassword=pWord apigeeprotocol=http://
其中 uName:pWord 是代码库用户名和密码。
- 使用
apigee-service
更新apigee-setup
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-setup update
- 更新管理服务器上的
apigee-validate
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-validate update
- 更新管理服务器上的
apigee-provision
实用程序,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service apigee-provision update
- 按照计算机更新顺序中所述的顺序,在节点上运行
update
实用程序:/opt/apigee/apigee-setup/bin/update.sh -c component -f configFile
其中:
- component 是要更新的 Edge 组件。您通常需要更新以下组件:
cs
:Cassandraedge
:所有 Edge 组件(边缘界面除外):管理服务器、消息处理器、路由器、QPID 服务器、Postgres 服务器ldap
:OpenLDAPps
:postgresqlqpid
:qpiddsso
:Apigee SSO(如果您安装了 SSO)ue
新版 Edge 界面ui
:经典版 Edge 界面zk
:Zookeeper
- configFile 是您在安装 4.50.00 或 4.51.00 期间用于定义 Edge 组件的配置文件。
您可以通过将 component 设置为“all”来针对所有组件运行
update.sh
,但前提是您拥有 Edge 多合一 (AIO) 安装配置文件。例如:/opt/apigee/apigee-setup/bin/update.sh -c all -f /tmp/sa_silent_config
- component 是要更新的 Edge 组件。您通常需要更新以下组件:
- 在运行该界面的所有节点上重启界面组件(如果尚未重启):
/opt/apigee/apigee-service/bin/apigee-service [edge-management-ui|edge-ui] restart
- 在管理服务器上运行
apigee-validate
实用程序,以测试更新(如测试安装中所述)。
如果您日后决定回滚更新,请使用回滚 4.52.00 中所述的步骤。
机器更新顺序
更新 Edge 安装中的计算机的顺序非常重要:
- 您必须先更新 所有 Cassandra 和 ZooKeeper 节点,然后才能更新任何其他节点。
- 对于具有多个 Edge 组件(管理服务器、消息处理器、路由器、QPID 服务器,但不包括 Postgres 服务器)的任何机器,请使用
-c edge
选项同时更新它们。 - 如果某个步骤指定应在多台机器上执行,请按指定的机器顺序执行该步骤。
- 您无需单独执行任何步骤即可更新创收设置。当您指定
-c edge
选项时,它会更新。
1 个节点的独立升级
如需将单节点独立配置升级到 4.52.00,请执行以下操作:
- 更新所有组件:
/opt/apigee/apigee-setup/bin/update.sh -c all -f configFile
- (如果您安装了
apigee-adminapi
)更新了apigee-adminapi
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
2 个节点的独立升级
针对 2 节点独立安装更新以下组件:
如需查看 Edge 拓扑和节点编号列表,请参阅安装拓扑。
- 在机器 1 上更新 Cassandra 和 ZooKeeper:
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 在机器 2 上更新 Qpid 和 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c qpid,ps -f configFile
- 更新计算机 1 上的 LDAP:
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 更新机器 2 和 1 上的 Edge 组件:
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 更新机器 1 上的界面:
/opt/apigee/apigee-setup/bin/update.sh -c ui -f configFile
- (如果您安装了
apigee-adminapi
)更新了机器 1 上的apigee-adminapi
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- (如果您安装了 Apigee SSO)在计算机 1 上更新 Apigee SSO:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
其中 sso_config_file 是您在安装 SSO 时创建的配置文件。
- 在机器 1 上重启 Edge 界面组件:
/opt/apigee/apigee-service/bin/apigee-service edge-ui restart
5 节点升级
对于 5 节点安装,请更新以下组件:
如需查看 Edge 拓扑和节点编号列表,请参阅安装拓扑。
- 在机器 1、2 和 3 上更新 Cassandra 和 ZooKeeper:
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 在机器 4 上更新 Qpid 和 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c qpid, ps -f configFile
- 在机器 5 上更新 Qpid 和 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c qpid, ps -f configFile
- 在机器 1 上更新 LDAP:
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 更新机器 4、5、1、2、3 上的 Edge 组件:
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 更新了 Edge 界面:
- 传统版界面:如果您使用的是传统版界面,请在机器 1 上更新
ui
组件,如以下示例所示:/opt/apigee/apigee-setup/bin/update.sh -c ui -f configFile
- 新版 Edge 界面:如果您安装了新版 Edge 界面,请更新相应机器(可能不是机器 1)上的
ue
组件:/opt/apigee/apigee-setup/bin/update.sh -c ue -f /opt/silent.conf
- 传统版界面:如果您使用的是传统版界面,请在机器 1 上更新
- (如果您安装了
apigee-adminapi
)更新了机器 1 上的apigee-adminapi
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- (如果您安装了 Apigee SSO)在机器 1 上更新 Apigee SSO:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
其中 sso_config_file 是您在安装 SSO 时创建的配置文件。
- 重启界面组件:
- 传统版界面:如果您使用的是传统版界面,请在机器 1 上重启
edge-ui
组件,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service edge-ui restart
- 新版 Edge 界面:如果您安装了新版 Edge 界面,请在相应机器(可能不是机器 1)上重启
edge-management-ui
组件:/opt/apigee/apigee-service/bin/apigee-service edge-management-ui restart
- 传统版界面:如果您使用的是传统版界面,请在机器 1 上重启
9 节点集群升级
对于 9 节点集群安装,请更新以下组件:
如需查看 Edge 拓扑和节点编号列表,请参阅安装拓扑。
- 在机器 1、2 和 3 上更新 Cassandra 和 ZooKeeper:
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 更新机器 6 和 7 上的 Qpid:
/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 更新机器 8 上的 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 更新机器 9 上的 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 在机器 1 上更新 LDAP:
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 依次更新机器 6、7、8、9、1、4 和 5 上的 Edge 组件:
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 更新机器 1 上的新界面 (
ue
) 或传统界面 (ui
):/opt/apigee/apigee-setup/bin/update.sh -c [ui|ue] -f configFile
- (如果您安装了
apigee-adminapi
) 在计算机 1 上更新apigee-adminapi
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- (如果您安装了 Apigee SSO)在机器 1 上更新 Apigee SSO:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
其中 sso_config_file 是您在安装 SSO 时创建的配置文件。
- 重启界面组件:
- 传统界面:如果您使用的是传统界面,请重启机器 1 上的
edge-ui
组件,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service edge-ui restart
- 新的 Edge 界面:如果您安装了新的 Edge 界面,请在适当的机器(可能不是机器 1)上重启
edge-management-ui
组件:/opt/apigee/apigee-service/bin/apigee-service edge-management-ui restart
- 传统界面:如果您使用的是传统界面,请重启机器 1 上的
13 节点集群升级
对于 13 节点的集群安装,请更新以下组件:
如需查看 Edge 拓扑和节点编号列表,请参阅安装拓扑。
- 在计算机 1、2 和 3 上更新 Cassandra 和 ZooKeeper:
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 在机器 12 和 13 上更新 Qpid:
/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 更新机器 8 上的 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 更新机器 9 上的 Postgres:
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 在机器 4 和 5 上更新 LDAP:
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 按如下顺序更新机器 12、13、8、9、6、7、10 和 11 上的 Edge 组件:
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 在机器 6 和 7 上更新新界面 (
ue
) 或经典界面 (ui
):/opt/apigee/apigee-setup/bin/update.sh -c [ui|ue] -f configFile
- (如果您安装了
apigee-adminapi
)更新了机器 6 和 7 上的apigee-adminapi
实用程序:/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- (如果您安装了 Apigee SSO)在计算机 6 和 7 上更新 Apigee SSO:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
其中 sso_config_file 是您在安装 SSO 时创建的配置文件。
- 重启界面组件:
- 传统界面:如果您使用的是传统界面,请在机器 6 和 7 上重启
edge-ui
组件,如以下示例所示:/opt/apigee/apigee-service/bin/apigee-service edge-ui restart
- 新版 Edge 界面:如果您安装了新版 Edge 界面,请在机器 6 和 7 上重启
edge-management-ui
组件:/opt/apigee/apigee-service/bin/apigee-service edge-management-ui restart
- 传统界面:如果您使用的是传统界面,请在机器 6 和 7 上重启
12 节点集群升级
对于 12 节点集群安装,请更新以下组件:
如需查看 Edge 拓扑和节点编号列表,请参阅安装拓扑。
- 更新 Cassandra 和 ZooKeeper:
- 在数据中心 1 中的机器 1、2 和 3 上:
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 在数据中心 2 中的机器 7、8 和 9 上
/opt/apigee/apigee-setup/bin/update.sh -c cs,zk -f configFile
- 在数据中心 1 中的机器 1、2 和 3 上:
- 更新了 qpidd:
- 数据中心 1 中的机器 4、5
- 更新机器 4 上的
qpidd
:/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 更新机器 5 上的
qpidd
:/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 更新机器 4 上的
- 数据中心 2 中的机器 10、11
- 更新机器 10 上的
qpidd
:/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 在机器 11 上更新
qpidd
:/opt/apigee/apigee-setup/bin/update.sh -c qpid -f configFile
- 更新机器 10 上的
- 数据中心 1 中的机器 4、5
- 更新 Postgres:
- 数据中心 1 中的机器 6
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 数据中心 2 中的机器 12
/opt/apigee/apigee-setup/bin/update.sh -c ps -f configFile
- 数据中心 1 中的机器 6
- 更新 LDAP:
- 数据中心 1 中的机器 1
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 数据中心 2 中的机器 7
/opt/apigee/apigee-setup/bin/update.sh -c ldap -f configFile
- 数据中心 1 中的机器 1
- 更新 Edge 组件:
- 数据中心 1 中的机器 4、5、6、1、2、3
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 数据中心 2 中的机器 10、11、12、7、8、9
/opt/apigee/apigee-setup/bin/update.sh -c edge -f configFile
- 数据中心 1 中的机器 4、5、6、1、2、3
- 更新新界面 (
ue
) 或旧版界面 (ui
):- 数据中心 1 的机器 1:
/opt/apigee/apigee-setup/bin/update.sh -c [ui|ue] -f configFile
- 数据中心 2 中的机器 7:
/opt/apigee/apigee-setup/bin/update.sh -c [ui|ue] -f configFile
- 数据中心 1 的机器 1:
- (如果您安装了
apigee-adminapi
) 更新了apigee-adminapi
实用程序:- 数据中心 1 中的机器 1:
/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- 数据中心 2 中的机器 7:
/opt/apigee/apigee-service/bin/apigee-service apigee-adminapi update
- 数据中心 1 中的机器 1:
- (如果您安装了 Apigee SSO)更新 Apigee SSO:
- 数据中心 1 中的机器 1:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
- 数据中心 2 中的机器 7:
/opt/apigee/apigee-setup/bin/update.sh -c sso -f sso_config_file
其中 sso_config_file 是您在安装 SSO 时创建的配置文件。
- 数据中心 1 中的机器 1:
- 在机器 1 和 7 上重启新版 Edge 界面 (
edge-management-ui
) 或传统版 Edge 界面 (edge-ui
) 组件:/opt/apigee/apigee-service/bin/apigee-service [edge-ui|edge-management-ui] restart
对于非标准配置
如果您使用的是非标准配置,请按以下顺序更新 Edge 组件:
- ZooKeeper
- Cassandra
- qpidd、ps
- LDAP
- 边缘,表示以下顺序所有节点上的“-c 边缘”配置文件:具有 Qpid 服务器、Edge Postgres 服务器、管理服务器、消息处理器和路由器的节点。
- Edge 界面(旧版或新版)
apigee-adminapi
- Apigee SSO
完成更新后,请务必在运行 Edge 界面组件的所有机器上重启该组件。
- 将 Edge