【Java8】Backlogの既存プロジェクトを別スペースに移行する手順


記事概要

自分が現在働いている会社ではタスク管理の際にBacklogを使用しているのですが、とある理由で既存プロジェクトを別スペースに移行しなければならなくなり、その移行作業を任されたので手順についてメモ書き。

前提条件

Backlogの既存プロジェクトを別スペースに移行したい場合、事前に以下の状態を作り出しておく事が前提条件となります。

  • Java8の実行環境。
  • ターミナルで簡単なコマンド(mkdir、cd、mv、curlなど)が叩ける事。
  • 移行元のスペースの管理者もしくは移行元プロジェクトの管理者である事。
  • 移行先のスペースの管理者である事。

下準備編(各スペース・プロジェクトやAPIキーを準備)

業務で使っているスペースやプロジェクトをそのまま映すわけにはいかないので、この記事用にそれぞれ適当なものを作成していきます。

「スペース」と「プロジェクト」の違いについてはちょっとわかりにくいかもしれませんが、

  • スペース: 組織単位
  • プロジェクト: プロジェクト単位

みたいな感じで勝手にイメージしています。まず大きな枠としてスペースが存在し、その中にプロジェクトが点在している感じですかね。


Backlogトップページから「無料でbacklogを試してみる」をクリックし、お好みのプランを選択してください。今回はプレミアムプランで進めていきます。

移行元

それぞれ情報を入力してスペースを作成。

プロジェクトを作成

スペースの作成に成功するとこんな感じでダッシュボードに入れるようになるので、今度はプロジェクトを作成していきます。(名前は各自適当に)

こんな感じでプロジェクトができていれば成功です。

ユーザーを追加

右上にある「ユーザーを招待」ボタンをクリックし、適当なユーザーを何人か追加しておきます。

課題を追加

左サイドバーにある「課題の追加」から適当なタスクを追加しておきます。

APIキーを作成

右上のアイコンから「個人設定」をクリック。

左サイドバーにある「API」からAPIキーを発行してください。(後ほど使うのでメモなどに控えておきましょう。)

移行先

それぞれ情報を入力してスペースを作成。

プロジェクトを作成

スペースの作成に成功するとこんな感じでダッシュボードに入れるようになるので、今度はプロジェクトを作成していきます。(名前は各自適当に)

こんな感じでプロジェクトができていれば成功です。

スペースに移行元のユーザーを追加

右上のスペース名をクリックすると「組織設定」という項目があるのでそちらへ進みます。

移行元のユーザーのメールアドレスを入力し、管理者権限を持たせた上で組織内メンバーに招待してください。

途中でメール確認などのステップを挟むと思いますが、最終的にこんな感じで移行元のユーザーがメンバーに加わっていればOK。

APIキーを作成

今度は移行先のプロジェクトでAPIキーを作成します。(移行元のユーザーとして発行)

この辺はさっきと同じ要領ですね。こちらも後ほど使うのでメモに控えておきます。

実行編(Java8実行環境を構築 & ターミナルからコマンド実行)

下準備が終わったので、いよいよ実際にデータの移行に入っていきます。

Java8実行環境を構築

パソコン本体にJavaをインストールしても良いのですが、個人的にはローカル環境を汚したくなかったのでDockerを使用しました。

各種ディレクトリ・ファイルを作成

$ mkdir backlog-migration
$ cd backlog-migration

$ mkdir docker
$ mkdir docker/java
$ touch docker/java/Dockerfile

$ mkdir server
$ mkdir server/src

$ touch docker-compose.yml
./docker/java/Dockerfile
FROM openjdk:8-slim

RUN apt-get update
WORKDIR /usr/src
./docker-compose.yml
version: '3.6'
services:
  java:
    build: ./docker/java
    ports:
      - 8080:8080
    tty: true
    volumes:
      - ./server/src:/usr/src:cached

最終的に次のような構造になっていればOK。

backlog-migration
├─ docker
  ├─ java
    ├─ Dockerfile
├─ docker-compose.yml
├─ server
  ├─ src

コンテナを起動

$ docker-compose up -d
$ docker-compose exec java bash

...

root@e4aee0a9aa31:/usr/src# 

無事コンテナへ入る事ができれば成功です。

$ exit
$ docker-compose down

一旦抜けます。

移行用ツールをダウンロード

↑公式が用意してくれている移行用ツールをダウンロードしていきます。

$ (cd ~/.../backlog-migration/server/src && curl -O https://backlog.com/ja/backlog-migration/backlog-migration-1.5.2.jar)

前半の「cd ~/.../backlog-migration/server/src」という部分については適宜パスを変更してください。自分の場合はルートに「Workspace」というディレクトリを作成していたので、

$ (cd ~/Workspace/backlog-migration/server/src && curl -O https://backlog.com/ja/backlog-migration/backlog-migration-1.5.2.jar)

こんな感じになりました。

移行元と移行先をマッピング

移行用ツールがダウンロードできたら、移行元のデータと移行先のデータをマッピングしていきます。

$ docker-compose up -d
$ docker-compose exec java bash

コンテナを再度起動。

java -jar backlog-migration-1.5.2.jar \
init \
--src.key 移行元APIキー \
--src.url https://スペースID.backlog.com \
--dst.key 移行先APIキー \
--dst.url https://スペースID.backlog.com \
--projectKey 移行元プロジェクトキー:移行先プロジェクトキー

各値を自分のものに変更し、上記コマンドを実行します。

java -jar backlog-migration-1.5.2.jar \
init \
--src.key ******************* \
--src.url https://mig-src.backlog.com \
--dst.key ******************* \
--dst.url https://mig-dst.backlog.com \
--projectKey MIGSRC:MIGDST

参考までに自分はこんな感じ↑になりました。(APIキーは流石に割愛させてください。)

Backlog Migration 1.5.2 (c) nulab.inc
--------------------------------------------------
--------------------------------------------------
Source URL[https://mig-src.backlog.com]
Source access key[*******************]
Source project key[MIGSRC]
Destination URL[https://mig-dst.backlog.com]
Destination access key[*******************]
Destination project key[MIGDST]
Filter[]
Only Import[false]
Fit Issue Key[false]
Maximum number of retries[20]
https.proxyHost[]
https.proxyPort[]
https.proxyUser[]
https.proxyPassword[]
--------------------------------------------------

Checking whether the source is accessible ...
Checking whether the destination is accessible ...
Getting the source project ...
Getting the destination project ...
Checking for the presence of admin role ...
Checking for the presence of project admin role ...

Start collecting the information about the project.
--------------------------------------------------
     (4/4) [##########] 100.0% Analyzed wikis.
     (1/1) [##########] 100.0% Collected issues information.
     (1/1) [##########] 100.0% Analyzed issues.
--------------------------------------------------
Completed collecting the information about the project.

--------------------------------------------------
The mapping file about users is created.
[/usr/src/mapping/users.csv]
--------------------------------------------------

↑こんな感じのログとともにマッピング用のファイルが出力されていれば成功。

./server/src/mapping/users.csvを修正

「./server/src/mapping/users.csv」内の「Destination Backlog user name」列を、「./server/src/mapping/users_list.csv」の「Name」列に置き換えます。

./server/src/mapping/users_list.csv
"Name","Email"
"hoge","[email protected]"
"fuga","[email protected]"
./server/src/mapping/users.csv
"Source Backlog user id","Source Backlog user display name","Source Backlog user
email","Destination Backlog user name"
"test001","テスト001","[email protected]","hoge"
"test002","テスト002","[email protected]","fuga"

一番右の列が空文字になっているはずなので、それぞれ「hoge」「fuga」で置き換え。

実行

$ java -jar backlog-migration-1.5.2.jar \
execute \
--src.key 移行元APIキー \
--src.url https://スペースID.backlog.com \
--dst.key 移行先APIキー \
--dst.url https://スペースID.backlog.com \
--projectKey 移行元プロジェクトキー:移行先プロジェクトキー

途中でyesかno「」か聞かれますが((y/n [n]):y)、全て「y」で大丈夫です。

--------------------------------------------------
Export completed.

Start convert.
--------------------------------------------------
 project users Converted.
     (1/1) [##########] 100.0% Converted issues.
     (4/4) [##########] 100.0% Converted wikis.
 project key Converted.
--------------------------------------------------
Convert completed.

Start import.
--------------------------------------------------
     (8/8) [##########] 100.0% Imported project users.
     (1/1) [##########] 100.0% Imported wikis.
    (1/1) [##########] 100.0% [SUCCESSFUL] Imported issues about 2021/02/25.
--------------------------------------------------
Import completed.

こんな感じのログが出力されれば成功。


移行先のプロジェクトに課題やユーザーが移行できているのを確認してください。

あとがき

お疲れ様でした。だいぶ細かく説明したつもりですが、どこか詰まるところなどあればコメント欄などでご指摘いただけると幸いです。