How to upgrade Remote Mesh Nodes

お困りですか?

アトラシアン コミュニティをご利用ください。

コミュニティに質問


プラットフォームについて: Data Center - この記事は、Data Center プラットフォームのアトラシアン製品に適用されます。

このナレッジベース記事は製品の Data Center バージョン用に作成されています。Data Center 固有ではない機能の Data Center ナレッジベースは、製品のサーバー バージョンでも動作する可能性はありますが、テストは行われていません。サーバー*製品のサポートは 2024 年 2 月 15 日に終了しました。サーバー製品を利用している場合は、アトラシアンのサーバー製品のサポート終了のお知らせページにて移行オプションをご確認ください。

*Fisheye および Crucible は除く

要約

When upgrading Bitbucket, the version of the Remote Mesh nodes may also need to be upgraded to maintain compatibility. Relevant Bitbucket-Remote Mesh version compatibility chart is given on the page Bitbucket Mesh compatibility matrix

環境

Bitbucket Data Center 8.x and newer

Remote Mesh 1.0.0 and newer

At least one of the repositories has been migrated to Mesh nodes.

General procedure for upgrading Remote Mesh nodes

When upgrading Remote Mesh nodes, it is important to upgrade them one node node at a time, following this procedure:

  1. Drain and disable the node from the Bitbucket Web UI.

  2. Stop the Remote Mesh process.

  3. Upgrade the node.
    Detailed description of this step is given in the section “Details on upgrading the Remote Mesh node“ below.

  4. Start the Remote Mesh process.

  5. Enable the node from the Bitbucket Web UI.


  6. Repeat the procedure for every node.

How to minimize downtime when upgrading Remote Mesh nodes

The most important thing to consider when upgrading is to maintain compatibility between Bitbucket version and Remote Mesh version. The compatibility chart is given on the page Bitbucket Mesh compatibility matrix

Here are other important notes:

  • When upgrading Remote Mesh nodes, upgrade to the new bugfix version of Remote Mesh, one node at a time.
    Make sure all replicas have become consistent between proceeding with the upgrade of the next node.

  • If you use a Remote Mesh version that is too old with a Bitbucket that requires a newer version, the setup will break!

  • Bitbucket will work with the Remote Mesh with the bugfix versions higher than the version required by the Bitbucket Mesh compatibility matrix.
    For example, Bitbucket 8.19.0 requires Remote Mesh 2.5.0, but it will also work with Remote Mesh 2.5.4.

  • When upgrading both Bitbucket and Remote Mesh, upgrade first all Remote Mesh nodes, then upgrade main Bitbucket application.
    Follow standard Bitbucket upgrade documents for main Bitbucket application.

Details on upgrading the Remote Mesh node

n this example, we are upgrading from Mesh v2.0.8 to Mesh v2.3.0. The Mesh installation directory is /opt/atlassian/mesh/current where current is a symlink to the existing version:

# ls -l
/opt/atlassian/mesh/current -> /opt/atlassian/mesh/atlassian-bitbucket-mesh-2.0.8

Download the new version

Download the package for the new version from the Bitbucket Mesh Downloads page and place it in the installation directory.

We can use this opportunity to update the scripts to match the configuration currently running: 

ファイル用途
set-jmx-opts.sh  Add JMX settings
set-jre-home.sh Define JRE_HOME  or JAVA_HOME 
set-mesh-home.sh Set the MESH_HOME  directory
set-mesh-user.sh Define the process user (aka MESH_USER )
_start-mesh.sh Configure the JVM heap or set JVM_SUPPORT_RECOMMENDED_ARGS 

Using a symlink allows us to stage the files and quickly switch between versions to minimize downtime. We can update the symlink using the following command: 

# ln -sfnv /opt/atlassian/mesh/atlassian-bitbucket-mesh-2.3.0 /opt/atlassian/mesh/current
...
# ls -l
/opt/atlassian/mesh/current -> /opt/atlassian/mesh/atlassian-bitbucket-mesh-2.3.0

Restart Mesh

With the symlink updated, we can use the stop and start scripts to restart Mesh with the updated version. Check log files to verify the version was updated:

# cat /var/atlassian/application-data/mesh/log/atlassian-mesh.log

...
INFO  [main] - c.a.b.mesh.app.BuildInfoLogger Starting Mesh 2.3.0
...

H2 database update may be necessary

Remote Mesh upgrade may require update of mesh H2 database. Indication that H2 database upgrade is needed is that Mesh node does not start and this message is written to the atlassian-mesh.log file:

***************************
APPLICATION FAILED TO START
***************************
Description:
The storage format for the internal database that you are using has changed and requires manual migration.
Action:
Please perform the manual migration of the database. See https://confluence.atlassian.com/bitbucketserver088/migrate-h2-database-1216583295.html.

In this case, follow the procedure described in the “Solution” section of the page Bitbucket Mesh Sidecar H2 database migration.

When is it safe to add or remove nodes

You should not remove nodes if that would leave the system with less nodes than the replication factor (default and minimum 3). In fact, the system should block this action entirely!

Assuming you have more than 3 nodes then the best time to add or remove them is outside business hours. This is to reduce the load on existing mesh nodes and lessen the chances of a replica being unable to catch up due to concurrent commits being made during the partition migration.

On large, busy repositories it is possible that the repair job is unable to catch up to the latest changes. This can happen if the frequency of repository updates is high, and mesh repair process takes longer time so it can’t catch up. Currently, there is no other solution than waiting for the repository to be quiet long enough so repair process can finish.


最終更新日 2024 年 11 月 13 日

この内容はお役に立ちましたか?

はい
いいえ
この記事についてのフィードバックを送信する
Powered by Confluence and Scroll Viewport.