• 日本語
    • English (英語)
Avinton JapanAvinton JapanAvinton JapanAvinton Japan
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ

Gitとは

  • ルーティング
  • データベースの命名規則
  • 三目並べ – 2.〇×を交互にゲーム盤に入るようにしよう
  • 三目並べ – 3.勝敗がつくようにしよう
  • クリーンコード(Clean Code)
  • 三目並べ – 4.「スタート」「リセット」ボタンをつけよう
  • 三目並べ – 5.先攻後攻を決めて、コンピュータ対戦にしよう(前編)
  • インフラストラクチャー(サーバー、コンポーネント、RAID)
  • 機械学習入門者向け Support Vector Machine (SVM) に触れてみる
  • YOLOv8を用いた物体検出
  • 正規表現とパイプ
  • 機械学習エンジニアに必要なスキル
  • 軽量版Kubernetesディストリビューション – k0s クラスターの構築
  • ファイル操作コマンド
  • グループとユーザー
  • 困った時に使うコマンド
  • 一般グループのユーザーとグループ
  • プライバシーポリシー
  • 三目並べ – 6.先攻後攻を決めて、コンピュータ対戦にしよう(後編)
  • フロントエンド開発のための環境構築
  • ファイル検索コマンド
  • 質問
  • 仮想化環境のディスク容量を拡張する
  • ユーザー権限とアクセス権
  • データ分析基礎 – Part1
  • 三目並べ – 0.導入
  • テキスト処理
  • データベースへのデータロード
  • 機械学習概要1
  • 機械学習入門者向け Naive Bayes(単純ベイズ)アルゴリズムに触れてみる
  • ファイル管理
  • SSHを使用してホストOSからゲストOSに接続する
  • 機械学習入門者向け ChainerRLでブロック崩しの学習
  • 機械学習入門者向け ランダムフォレストによる Kaggle Titanic生存者予測
  • 機械学習概要2
  • データ分析基礎 – Part 2
  • 機械学習入門者向け 分類と回帰の違いをプログラムを書いて学ぼう
  • フロントエンドのWeb開発について
  • ダイナミックルーティング
  • 三目並べ – 1.ゲーム盤を作ろう
  • 【Python入門】Python Numpy チュートリアル
  • Amazon EC2 インスタンスの初期設定をしよう
  • AmazonEC2とVPCでネットワークとサーバーを構築しよう
  • Apache NiFi Exercise
  • Apache NiFi データパイプライン基礎
  • Apache NiFiの環境設定
  • Apache Spark 基礎
  • Apache SparkとApache Zeppelinの概要と環境構築
  • Apache Superset maptoolの使い方
  • Apache Superset 基礎
  • Apache Superset 概要と環境構築
  • Apache Zeppelin 基本機能
  • APIのデモンストレーション
  • Avinton Academy コンテンツガイド
  • AWS CLIをインストールしてコマンド操作しよう
  • AWS CLIを使ってEC2のファイルをS3へアップロードしよう
  • AWS Route 53を使って独自ドメインのWebページを表示させてみよう
  • AWSアカウントの作成と必ずやるべきセキュリティ対策
  • AWSのEC2インスタンスでWordPressブログを公開してみよう
  • AWS入門者向け 初心者が最初に理解すべきEC2とVPCの基本的な用語解説
  • CCNA
  • Certbotを使ってSSL証明書を発行し、HTTP通信を暗号化しよう
  • CISCO 1800ルータセットアップ
  • CSV import & export – Node.js, mySQL – 1
  • CSV import & export – Node.js, mySQL – 2
  • Docker Compose(Nginx + Flask + MySQL)演習
  • Docker Engineのubuntu上へのinstall
  • Docker 概要とセットアップ
  • Docker, Kubernetesの学び方について
  • Dockerコンテナイメージの最適化/ベストプラクティス
  • DockerとApacheを使ってWebサーバーを構築しよう
  • EC2からS3へ自動でぽいぽいアップロードするスクリプトの作成
  • ESP32-CAMのサンプルアプリケーションを実行する
  • 01 – Sparkfun Inventor’s Kit の準備
  • 02 – Sparkfun Inventor’s KitでLチカ
  • 03 ポテンショメータでLEDの点滅間隔をアナログ入力する
  • 04 フォトレジスタで明るさに反応するシステムをつくる
  • 05 LCDに文字列を表示する
  • 06 – BME280とLCDを組み合わせて温度計をつくる
  • ESP32とArduino IDE/PlatfromIOでHello Worldアプリケーションの実行
  • ESP32と超音波センサー HC-SR04 で物体の距離を計測する
  • ESXi – Switchの追加とVLAN
  • ESXi – VyOS
  • ESXi – 小規模ネットワーク 構築
  • Gitとは
  • VS CodeでGitHub Copilotを設定する
  • VSCode リモート開発環境
  • GNS3のセットアップ
  • Kubernetesクラスター上へのOpenVINOモデルサーバーを使用したサンプルアプリケーションのデプロイ
  • Linuxとは
  • NAT
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – React編
  • NodeJSでWebアプリケーション開発 – Socket.IO編
  • NVIDIA Cumulus VX + GNS3でBGPネットワークのシミュレーション
  • OpenCVのテストプログラム
  • PacketTracerのセットアップ
  • Pandasによる構造化データ分析
  • PCからルータ、スイッチへのSSH接続設定
  • PostGIS exercise
  • PostgreSQL – Python – Apache – Bootstrap
  • MySQLとMySQL Workbench のセットアップ
  • PostgreSQL Setup
  • PostgreSQL – インデックスを利用したパフォーマンス改善方法
  • PostgreSQL – パーティショニングを利用したパフォーマンス改善方法
  • PostgreSQLによるデータ分析
  • postgreSQLへのshp fileのimport
  • Python2.7とOpenCVのインストール
  • Python3.8 と OpenCV のインストール (Ubuntu20.04LTS)
  • Pythonでデータベースを操作する
  • Pythonで画像を分類するプログラムを作成する
  • Pythonによるマルチスレッドプログラミング実践
  • Raspberry Pi 4B のセットアップ
  • Raspberry PiとBME280を使用して温度と湿度、気圧を読み取る
  • REDIS
  • Redux基礎 – 主要な概念と用語
  • Ruby on Rails を MySQLでセットアップ
  • Ruby on Railsによる簡単なウェブアプリケーション
  • SampleアプリケーションのKubernetes上へのデプロイ
  • Scala 基礎
  • scikit-learnとは
  • Spark SQL エクササイズ
  • SparkMLによるKaggle Titanic生存者予測
  • SparkMLによる住宅価格予測
  • SQL 便利な関数
  • Ubuntuの基本設定
  • uhubctlでUSBデバイスのオンオフをコントロール
  • Terraform入門 2 – Terraformのstate管理
  • Terraform入門 1 – TerraformでAWS上にEC2インスタンスを作成する
  • Virtualisation and Container (仮想化とコンテナ) – Ansible, Docker and Kubernetes
  • viエディタ
  • VLAN
  • VMware ESXi サーバー構築
  • Webアプリ開発に欠かせないGoogle Chrome DevToolsの基本
  • Windows Server 2012 R2 Hyper-V
  • YOLOv5を用いた物体検出
Home Avintonアカデミー Gitとは
git logo

1. Gitとは

Gitとは、分散型バージョン管理システムです。噛み砕いていうと、ファイルのバージョン管理がとても簡単になるツールです。通常、ファイルを更新すると、古いバージョンには戻せません。ただ、Gitで管理しているファイルであれば、Git上でファイルの編集履歴を管理できるので、編集前のファイルの内容を保存したまま、編集後のファイルも保存することが出来ます。 例えば、ファイルを更新してエラーが起きたときに、一旦変更前に戻したいとします。そのとき、コードを一文一文直していたら手間がかかります。自分ひとりのプロジェクトなら少しの労力ですみますが、数十人以上の規模の大きいプロジェクトとなると、ファイル数も多いので、結構な手間がかかります。そういった際に、無駄なく処理を行えるのがGitというツールになります。

上記はほんの一例ですが、ほかにも下記のようなことがGitによって可能になります。

1. 新旧のファイルを一括管理
2. 前のバージョンのファイルに戻れる
3. チームでファイルの変更履歴を共有
4. 複数のメンバーで修正した部分の統合
5. チーム開発の効率化

2. Gitの基礎

2.1 基礎用語

まずはGitを理解するうえで重要な用語を紹介します。

repository

repositpry(リポジトリ)は、ファイルやディレクトリの状態や変更履歴を記録しておく場所です。Gitのリポジトリにはリモートリポジトリとローカルリポジトリという2種類が存在します。リポジトリのディレクトリ内に.gitというディレクトリが存在します。ここにコミットの記録や差分などのリポジトリの情報が保存されています。

  • リモートリポジトリ:インターネットやサーバー上に存在するリポジトリで複数の開発者間で共有することができます
  • ローカルリポジトリ:開発者個人のPCなどローカル環境で作業を行うためのリポジトリです

commit

commit(コミット)とは、ファイルやディレクトリの変更を記録することです。
コミットにはコミットメッセージという作業の内容を記したメッセージを付与する必要があります。コミットメッセージに決まった書式はありませんが、1行目に変更内容の概要、2行目を空白行として3行目以降に変更内容の詳細を記述する書き方が一般的です。

clone

clone(クローン)は、既存のリポジトリをローカル環境にコピーすることです。
プロジェクト本体のリポジトリは既に作成されているものの、自分のローカル環境に何もない状態の時などに使用します。

branch

branch(ブランチ)とは、日本語で枝という意味であるようにプロジェクト本体からの分岐を作成することです。ブランチはデフォルトのmainブランチと、トピックブランチと呼ばれるmainから分岐するブランチが存在します。
ブランチでは他のブランチから分離して作業を進めることができます。

例えば、複数人で開発を行うプロジェクトで機能の追加やバグ修正などいくつかの作業を並行して行う必要があるとします。その際、トピックブランチを各々が作成することで他のメンバーの作業や変更点の影響を受けずに独立した状態で機能の追加や修正作業を進めることができます。
そして、次に紹介するマージという機能によって作業が終了したブランチをmainブランチに統合することができます。

merge

merge(マージ)は、分岐したブランチを統合することです。
例えば、バグ修正のために新たにブランチを作成しその作業が完了した場合、その変更内容をプロジェクト本体と統合する必要があります。この統合のために使用される機能がマージです。

push

push(プッシュ)は、コミットしたファイルやディレクトリをローカルリポジトリからリモートリポジトリにアップロードすることです。

コミット段階では変更内容の記録はローカルリポジトリのみに対して行われており、プッシュすることで初めて変更内容が他の開発者と共有されます。

pull

pull(プル)は、リモートリポジトリ内にあるものをローカルリポジトリに反映させることです。つまりプッシュがローカルからリモートへのアップロードであるのと反対に、プルはリモートからローカルへのダウンロードです。

プルしたコンテンツはリモートから独立したものと見なされ、以降のローカルでの変更内容はコミット、プッシュするまでリモートには反映されません。

fetch

fetch(フェッチ)は、リモートリポジトリ上の差分をローカルリポジトリに反映することなく、差分の情報の取得のみを行います。これによりプルを行ってリモートの変更を適用する前に、更新分の変更が衝突しないかどうかを確認することができます。フェッチでデータを取得した後にマージを行うという二つのステップを踏むことで、間違った操作を避け安全にリモートの差分を取得することができます。

2.2 GitHub/GitLab

実際にGitを使用する場合には、GitHubまたはGitLabのようなサービス/プラットフォームを使用することが一般的です。

GitHub

GitHubはソフトウェア開発プラットフォームの一つで、8300万人以上のユーザーと2億件以上の豊富なリポジトリを持つ世界最大のGitのサービスです。
GitHubではリポジトリを用途に応じて公開・非公開の設定をすることができます。公開設定のリポジトリをパブリックリポジトリと呼び、インターネット上で共有や参照が可能な状態です。非公開設定のリポジトリはプライベートリポジトリと呼ばれ、機密性の高いファイルや外部に公開したくないプロジェクトに利用するものです。プライベートリポジトリは以前は有料プランの機能でしたが現在は誰でも無料で作成することができます。
また、GitHubは開発プラットフォームであることに加え、開発者のためのコミュニティという側面も持っているため公開されているオープンソースコードに対して開発者間で日々活発なコミュニケーションが行われています。これによってGitHub上では新たなプログラミング言語やアプリケーション、先進的な技術が生み出されています。

GitLab

GitLabはGitHubをもとに開発されたDevOpsのオープンソースソフトウェア(OSS)です。GitHubが開発者間のコミュニケーションに焦点を当てている一方、GitLabはプロジェクトやチームの管理など信頼性に重きを置いたアプリケーションです。
例えば、GitHubを含む従来のサービスを利用してDevOpsを実現する場合、プロジェクト管理、ホスティング、CI/CD、デプロイなど各工程で異なるツールを導入する必要がありました。しかし、GitLabはこれらのツールを一つにまとめたDevOps支援アプリケーションとして開発されているため、効率的な開発が可能です。
また、プロジェクトにおける課題提起と対応状況、ToDoやコードレビューに関する機能などプロジェクト管理を円滑にするための機能はGitHub以上に豊富に取り揃えられています。

Avintonでは各プロジェクトごとに異なるリポジトリでコード管理を行うためにGitを使用しています。
具体的には、GitLabに実装されている他の機能と合わせて、タスク管理、タスクの割り当て、ワークフローの設計、CI/CDツールチェーンの統合、バグ追跡などを行なっています。例えば以下の画像にあるissue boardと呼ばれるGitLabの機能を利用することで、タスク管理やワークフローの確認を簡単に行うことができます。

Gitとは
Ref: GitLab – issue board

3. Git基礎教材

より詳しくGitを理解するための教材として以下を紹介します。いずれも日本語で無料で利用できる教材です。

  • Pro Git book
    • 1, 2, 3章が基本の理解のために役立ちます
  • Git Guide
    • 10分程度のチュートリアルです。

4. 演習

基本的な概念やコマンドを理解したら、実際に手を動かして理解を深めましょう。

4.1 Learn Git Branching

オープンソースで作成された、Webブラウザ上でGitコマンドを練習できるLearn Git Branchingがあります。こちらでは基本的なレベルから複雑な操作までインタラクティブに学習することができます。「まずはここから」と「次のレベルに進もう」の合計8つのシナリオをクリアしてみましょう。興味がある方はその続きのコースも進めてください。

4.2 Gitコマンド演習課題

次の通りローカルリポジトリを作成してください:

1. myworkという名前のディレクトリを作成
2. Gitレポジトリとして初期化
3. 今日の日付をtoday.txtに書き込み、そのファイルをコミットする
4. masterブランチからtomorrowという名前のブランチを作成
5. today.txtの日付を明日の日付に更新しコミットする
6. tomorrowブランチをmasterブランチにマージ
7. git logコマンドで2つのコミットが表示されていることを確認
8. tomorrowブランチを削除

 

4.3 Q&A

以下の質問について調べてみてください。

  • 上記課題において、.gitディレクトリはどこのコマンドで作成されましたか
  • ファイルをコミットする前に差分を確認するにはどのコマンドを使いますか
  • .gitignoreはどのような場合に便利ですか
  • git statusはどのような場合に便利ですか

5. GitとDevOps

GitとはRef: Wikipedia – Devops-toolchain

このようにGitは様々な機能を提供していますが、他にも近年開発の主流になりつつあるDevOpsを実践する上でも非常に有用なシステムです。DevOps(デブオプス)とは、アジャイル開発においてDEVelopment(開発)とOPeration(運用)を組み合わせる概念です。この概念は、これまで異なるフィールドだった開発と運用の連携強化によって開発スピードやアプリケーションの安定性向上を目指しています。DevOpsを導入することで、アジャイル開発において重要な効率的で安全なソフトウェアライフサイクルを実現することを目指します。

CI/CDはそれぞれContinuous Integration(継続的インテグレーション)とContinuous Delivery(継続的デリバリー)を指しています。CIはソースコードを自動でビルド・テストすることで、効率的かつ素早く不具合を見つけ、修正することを目的とするプロセスです。一方、CDはCIのテストをパスしたコードが本番環境にデプロイされるまでのプロセスを自動化するものです。このようにCI/CDはビルド・テスト・デリバリーを自動的に行うことであり、これはDevOpsを実現する上で最も重要な仕組みの一つです。

ここではDevOpsを実現するための一つとしてCI/CDを紹介しましたが、実際にはCI/CDの他に調査やプロジェクト自体の管理が必要であるなどDevOpsを実践する上でクリアしなければいけない課題はいくつかあります。そこで、Gitリポジトリ機能や多くのDevOps機能を備えるGitLabやGithubなどのシステムを利用し、プロジェクト全体の管理からアプリケーションの運用までカバーすることがあります。Gitに対する理解を深めることはモダンな開発フローを実践していく上でも非常に重要です。

6. まとめ

Gitを効率的に使用することによって、チームでの開発を加速することができます。近年ではDevOpsの技術と組み合わせて、ソフトウェアライフサイクルを管理するための一部として重要な技術になっています。多くオープンソースのアプリケーションはGithub上で開発されました。Gitを使用することで、個人や小さいチームでの開発だけではなく、世界中に分散しているプログラマーがコードの変更や修正を衝突することなく、協力して効率的に開発を行うことができます。

あなたも、Avintonでこのような最先端技術を習得し活用してみませんか?

社員の成長を導きながら、AIやビッグデータなどの最先端技術をプロジェクトに活用していくことが私たちのビジョンです。Avintonの充実した技術研修でスキルアップを図り、あなたのキャリア目標を一緒に達成しませんか?

採用情報

採用情報

採用情報

Categories

  • 相互学習
  • 採用
  • 社員インタビュー
  • 学習&資格取得
  • 技術解説
  • イベント告知
  • 学内説明会&講義
  • 産学連携
  • 就職活動
  • イベントレポート
  • その他
  • 技術ブログ&インタビュー
  • mainpage
  • New Graduates Interviews
  • 中途エンジニア
  • カテゴリーなし
  • ニュースリリース&イベント

Avinton SDGs

SDGsへの貢献

Search

タグ

AI EXPO AIカメラ AvintonAcademy Big Data ccna ChatGPT Digital Transformation Edge AI GUGA Imagine Analysis K3s LPIC-1 mikei Planet OS PM6PMO Ruby技術者認定試験 SSL エッジAI エンジニア キャリア クラウド コンテナ技術 スマートマニュファクチャリング セキュリティ ソフトウェア開発 データベース ニュース ネットワーク プログラマー プログラミングスクール 仮想化 仮想化、ネットワーク、サーバー、インフラ 協働 地域貢献 地引網 場作り 就職活動 新年のご挨拶 森部好樹 深層学習 生成AI 統計学 自社開発 資格 連携
© 2023 Avinton | All Rights Reserved | プライバシーポリシー
  • サービス
    • Avinton Data Platform
    • エッジAIカメラ
      • 自動車ナンバープレート自動認識システム
    • プライベートクラウド
    • AIサービス開発
    • AIカメラ/画像解析無料体験版
  • 最新情報
    • ニュースリリース&イベント情報
    • 技術ブログ&インタビュー
  • アカデミー
    • Avintonアカデミー
    • Academy on Campus
    • Academy with Platform
  • 採用情報
    • Avintonジャパン 採用ページ
    • 求人一覧
    • よくある質問
    • 新卒採用
  • 企業情報
    • 会社概要
    • 代表からご挨拶
    • SDGsへの貢献
  • お問い合わせ
  • 日本語
    • English (英語)
Avinton Japan