最適なソースコードリポジトリを選択する方法

チームに最適なコードリポジトリソリューションを選ぶためのガイド

ソース コード

リポジトリツールの選択

さまざまな最新のソフトウェアリポジトリホスティングツールを選択できます。それぞれのコードリポジトリシステムには、それぞれ長所と短所があります。さらに、サポート対象の基盤のバージョン管理システムは、リポジトリホスティングツールによって異なります。このガイドでは、チームのニーズに最適なコードリポジトリ管理ツールを選ぶ際に影響を与える要件について説明します。

コード管理ソフトウェアとバージョン管理ソフトウェア

リポジトリホスティングサービスとバージョン管理システムの違い

リポジトリホスティングサービスとバージョン管理システムは 2 つの異なるエンティティであることを認識することが重要です。バージョン管理システムは、ソースコードファイルのコレクションに対するソフトウェア開発ライフサイクルの変更を管理するために使用される、低レベルのコマンドラインユーティリティです。

チームに最適なバージョン管理システムの選択方法をご説明します。

リポジトリホスティングサービスは、バージョン管理システムをラップし、強化するサードパーティの Web アプリケーションです。基盤となるバージョン管理システムを使用しなければ、リポジトリホスティングサービスを十分に利用することはできません。

どのソースコードリポジトリを選ぶべきか?

code-cabinet

リポジトリホスティングサービスは、これまで不透明であったソフトウェア開発のワークフロープロセスを透過的に表示する組織管理ツールです。優れたリポジトリホスティングサービスには、ソフトウェア開発の効率性と正確性を測定、監視、議論、管理するためのツールが備わっています。リポジトリホスティングサービスでは、タスク管理、顧客関係管理、サポートチケット管理ツールなどの他の管理ツールと統合することで、組織通信ネットワークと接続される必要があります。企業がソフトウェア開発を資産として扱うのか、負債として扱うのかにかかわらず、そのリスクの原因についてのインサイトを得ることが重要です。

コードファイルキャビネット

リポジトリホスティングサービスは、これまで不透明であったソフトウェア開発のワークフロープロセスを透過的に表示する組織管理ツールです。優れたリポジトリホスティングサービスには、ソフトウェア開発の効率性と正確性を測定、監視、議論、管理するためのツールが備わっています。リポジトリホスティングサービスでは、タスク管理、顧客関係管理、サポートチケット管理ツールなどの他の管理ツールと統合することで、組織通信ネットワークと接続される必要があります。企業がソフトウェア開発を資産として扱うのか、負債として扱うのかにかかわらず、そのリスクの原因についてのインサイトを得ることが重要です。

リポジトリの選択時に考慮する要素

コードリポジトリホスティングサービスは、いずれも表面上の大きな違いはありません。どのリポジトリホスティングオプションがプロジェクトのニーズに適しているのか、判断に迷うこともあります。次のセクションでは、コードリポジトリホスティングサービスが適切かどうかを評価するときの考慮事項について説明します。


Git ブランチのアイコン

サポートされるバージョン管理システム

リポジトリホスティングサービスに、プロジェクトで使用されているバージョン管理システムとの互換性があるかを確認しなければなりません。たとえば、プロジェクトで Git を使用していても、リポジトリサービスが Git をサポートしていない場合、そのリポジトリホスティングサービスの利用は非常に難しくなります。

チームのアイコン

チーム規模とアクセス制御

プロジェクトのチーム構造と作業の進め方について、次のような項目を検討します。一人で行うのか、それともチームプロジェクトか。リモートチームが行うプロジェクトか。チームはすべてオンサイトで同じ場所にいるか。チームメンバーが必要とするリポジトリホスティングサービスへのアクセス権のレベルをどうするか、など。

時計のアイコン

リリーススケジュール

小さなアップデートを頻繁に行うか、または、頻度を減らしてより大きなリリースを行うかを検討します。リポジトリホスティングサービスの多くには CI/CD アドオンツールが備わっています。さらに、リポジトリサービスには、課題トラッキングツールとリリース管理ツールが備わっている場合があります。

データストレージのアイコン

プロジェクト規模とデータストレージ

プロジェクトで、3D モデリンググラフィックやオーディオファイルなどの大規模なバイナリデータファイルを扱うかどうかを検討します。大きなファイルを扱いやすくするための、特別なリポジトリソフトウェアがあります。プロジェクトで発生するコミットの継続的な量はどのくらいか、また、長い履歴を持つ確立されたプロジェクトの場合は、ダウンロードに時間がかかるかどうかについても検討します。

組み立てブロック

外部ツールとサードパーティとの統合

リポジトリホスティングサービスの重要な機能が、外部ツールとサービスの統合です。このような統合があってこそ、リポジトリサービスの真のパワーユーザーワークフローが実現します。一般的な外部統合の例としては、チケットやタスク管理、顧客サポート管理ツール、自動品質保証ツールがあります。チームがすでに特定のツールを使用している場合は、コードリポジトリを適切に統合する必要があります。

釣りあっていないスケール

コードリポジトリソリューションの比較

次の表は、これらの考慮事項をまとめ、さまざまなリポジトリホスティングサービスを比較したものです。

機能と要件

Bitbucket

GitHub

GitLab

コードレビュー

リポジトリホスティングサービスを使用するチームの時間の大半が、主にコードレビューに費やされています。コードレビューの支援は、どのリポジトリサービスにおいても標準的かつ重要な機能になっています。チームのスタイルに合ったレビューワークフローを見つけることが重要です。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

緑のチェックマーク

GitHub

緑のチェックマーク

GitLab

緑のチェックマーク

徹底的な Jira とのインテグレーション

ブランチからデプロイの作業をシームレスにする Jira Software と Bitbucket を使えば、リリース率を 14 %向上することが可能です。Jira Software から Bitbucket のブランチを作成したり、Bitbucket から離れることなく課題のトランジションを行うことができます。

緑のチェックマーク
赤い x
赤い x

Bitbucket

緑のチェックマーク

GitHub

赤い x

GitLab

赤い x

Wiki

プロジェクトのソースコード近くのアクセスしやすい場所にプロジェクトのドキュメントを保存しておけば、チームの効率性が飛躍的に向上します。ソースコードのホスティングに加えて、リポジトリサービスでは付随するドキュメントをホスティングします。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

緑のチェックマーク

GitHub

緑のチェックマーク

GitLab

緑のチェックマーク

無料のプライベートリポジトリ

オープンソースソフトウェアの開発では、無料でアクセス可能なソースコードが提唱されています。その点を考慮し、リポジトリサービスの中にはプライバシーをプレミアム機能として扱うものがあります。ビジネスの目標にとってプライバシーが重要である場合、リポジトリサービスを選択する際に考慮することが重要です。

緑のチェックマーク
赤い x
緑のチェックマーク

Bitbucket

緑のチェックマーク

GitHub

赤い x

GitLab

緑のチェックマーク

SoC 2 Type II 認定

Bitbucket は、主要な Git ソリューションとしてはじめて、コードの漏洩や紛失を防止することをお約束します。アトラシアンの Cloud 製品は、第三者機関による SOC 2 Type II 監査を受けています。

緑のチェックマーク
赤い x
赤い x

Bitbucket

緑のチェックマーク

GitHub

赤い x

GitLab

赤い x

コード対応検索

用法や変数名よりも定義を上位に表示するセマンティック検索により、使用結果をくまなく調べる時間を節約します。

赤い x
赤い x
赤い x

Bitbucket

緑のチェックマーク

GitHub

赤い x

GitLab

赤い x

組み込みの CI/CD

Bitbucket Pipelines は、統合された CI/CD により 1 つの場所でビルド、テスト、デプロイを実行可能にする、Bitbucket の機能です。Configuration as Code (コードによる構成) や無制限の拡張を活用しましょう。ビルドインフラストラクチャの管理は不要です。

緑のチェックマーク
赤い x
緑のチェックマーク

Bitbucket

緑のチェックマーク

GitHub

赤い x

GitLab

緑のチェックマーク

チーム

開発者に適切なタイミングで適切なコードにアクセスできる、適切な権限を付与できます。特定のユーザーの既存のアクセス権を上書きして、ブランチレベルでマージを制限できるようにします。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

緑のチェックマーク

GitHub

緑のチェックマーク

GitLab

緑のチェックマーク

自社ホスト

Bitbucket Server を使用すると、チームは機密性の高いコードプロジェクトを VPN などの安全な内部ネットワークで安全かつプライベートにホストできます。

Bitbucket

Bitbucket Server

GitHub

エンタープライズのみ

GitLab

緑のチェックマーク

Bitbucket Server

エンタープライズのみ

緑のチェックマーク

機能と要件

機能と要件

Bitbucket

GitHub

GitLab

Bitbucket

GitHub

GitLab

コードレビュー

リポジトリホスティングサービスを使用するチームの時間の大半が、主にコードレビューに費やされています。コードレビューの支援は、どのリポジトリサービスにおいても標準的かつ重要な機能になっています。チームのスタイルに合ったレビューワークフローを見つけることが重要です。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

GitHub

GitLab

徹底的な Jira とのインテグレーション

ブランチからデプロイの作業をシームレスにする Jira Software と Bitbucket を使えば、リリース率を 14 %向上することが可能です。Jira Software から Bitbucket のブランチを作成したり、Bitbucket から離れることなく課題のトランジションを行うことができます。

緑のチェックマーク
赤い x
赤い x

Bitbucket

GitHub

GitLab

Wiki

プロジェクトのソースコード近くのアクセスしやすい場所にプロジェクトのドキュメントを保存しておけば、チームの効率性が飛躍的に向上します。ソースコードのホスティングに加えて、リポジトリサービスでは付随するドキュメントをホスティングします。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

GitHub

GitLab

無料のプライベートリポジトリ

オープンソースソフトウェアの開発では、無料でアクセス可能なソースコードが提唱されています。その点を考慮し、リポジトリサービスの中にはプライバシーをプレミアム機能として扱うものがあります。ビジネスの目標にとってプライバシーが重要である場合、リポジトリサービスを選択する際に考慮することが重要です。

緑のチェックマーク
赤い x
緑のチェックマーク

Bitbucket

GitHub

GitLab

Mercurial をサポート

Bitbucket Cloud は Mercurial をサポートしています。Mercurial は、Git のような無料の分散型ソース管理システムです。分散型のバージョン管理システムを自由に選択して利用できます。

緑のチェックマーク
赤い x
赤い x

Bitbucket

GitHub

GitLab

SoC 2 Type II 認定

Bitbucket は、主要な Git ソリューションとしてはじめて、コードの漏えいや紛失を防止することをお約束します。アトラシアンの Cloud 製品は、第三者機関による SOC 2 Type II 監査を受けています。

緑のチェックマーク
赤い x
赤い x

Bitbucket

GitHub

GitLab

コード対応検索

用法や変数名よりも定義を上位に表示するセマンティック検索により、使用結果をくまなく調べる時間を節約します。

緑のチェックマーク
赤い x
赤い x

Bitbucket

GitHub

GitLab

組み込みの CI/CD

Bitbucket Pipelines は、統合された CI/CD により 1 つの場所でビルド、テスト、デプロイを実行可能にする、Bitbucket の機能です。Configuration as Code (コードによる構成) や無制限の拡張を活用しましょう。ビルドインフラストラクチャの管理は不要です。

緑のチェックマーク
赤い x
緑のチェックマーク

Bitbucket

GitHub

GitLab

チーム

開発者に適切なタイミングで適切なコードにアクセスできる、適切な権限を付与できます。特定のユーザーの既存のアクセス権を上書きして、ブランチレベルでマージを制限できるようにします。

緑のチェックマーク
緑のチェックマーク
緑のチェックマーク

Bitbucket

GitHub

GitLab

自社ホスト

Bitbucket Server を使用すると、チームは機密性の高いコードプロジェクトを VPN などの安全な内部ネットワークで安全かつプライベートにホストできます。

Bitbucket Server

エンタープライズのみ

緑のチェックマーク

組織を補完するコードリポジトリの選択

リポジトリホスティングサービス業界は競争が激しく、多くの製品を提供しています。つまり、唯一の「最善」の選択肢はないということです。「最善」の選択肢を探すということは、プロジェクトが直面する当面の要件を補完する製品を見つけることを意味します。

補完的なリポジトリホスティングサービスとは、組織の文化やワークフローの期待に十分に応えるサービスのことです。アジャイルプラクティスに従おうとする組織であれば、それに合ったリポジトリツールが重要です。コードリポジトリツールは、組織の「リリースリズム」と一致したものである必要があります。組織が迅速で継続的なリリース統合スケジュールを実行しているか、より頻度の低い静的なリリーススケジュールを実行しているかを考慮して、リポジトリツールがこれらのワークフローに対応している必要があります。このように、考慮すべき点を事前に特定しておけば、より簡単にリポジトリホスティングツールを選択できます。

コードファイルを運ぶ貨物船

Bitbucket コードリポジトリ

コードリポジトリに Bitbucket Cloud を選ぶ理由


プロフェッショナルなチームのために構築された Bitbucket

Bitbucket Cloud は、徹底的な Jira とのインテグレーションを利用したコードレビューから、ソフトウェアをより良い方法でビルド、トラック、デプロイするために、あなたのチームに必要なものを全て提供します。

トロフィーのアイコン

徹底的な Jira とのインテグレーション

Jira や Trello とのインテグレーションにより、関係者間で最新情報を共有できるようになります。ブランチ、ビルドステータス、コミット、ステータスに Jira 課題や Trello カード上でアクセスできます。

無限記号のアイコン

クラウドで継続的デリバリー

統合された CI/CD により、ビルド、テスト、デプロイを実行できます。Configuration as Code (コードによる構成) や無制限の拡張を活用しましょう。ビルドインフラストラクチャの管理は不要です。コードとデプロイメントを結び付け、1 つの場所でデプロイメントを追跡、プレビューします。

管理ツールのアイコン

他のツールは必要なし

Bitbucket Connect を使って、開発者はインターフェイスから Bitbucket Cloud のインテグレーションをビルドすることができます。他のツールやタスクとの間で内容が違うことはもうありません。ビルドやリリースに必要な全てを Bitbucket は兼ね備えています。

盾のアイコン

強化されたセキュリティ

IP 許可リストの活用、マージ チェックの強制、2 要素認証 (2FA) の強制、または Universal 2nd Factor (U2F) の活用によって、パスワードに加えて 2 つ目の確認をすることでコードを保護します。Bitbucket は SOC 2 Type II 認定を受けており、コードを確実に保護していつでもアクセスできるようにできます。

Bitbucket をお選びください

優れたソフトウェアを開発するために必要なすべての機能を、わずかな費用で利用できます。今すぐ Bitbucket Cloud をお選びください。