開発者ドキュメント

Ubuntu20.04にGoをインストールする方法

序章

Go は、「Golang」と呼ばれることもあり、2012年にGoogleによってリリースされたオープンソースのプログラミング言語です。 Googleの意図は、すぐに習得できるプログラミング言語を作成することでした。

Goはリリース以来、開発者の間で非常に人気があり、クラウドやサーバー側のアプリケーションから人工知能やロボット工学に至るまで、さまざまなアプリケーションに使用されています。 このチュートリアルでは、最新バージョンのGo(現在のバージョン 1.16.7 )をUbuntu 20.04サーバーにダウンロードしてインストールし、有名なHello, World!アプリケーションをビルドして、Goコードを将来使用するための実行可能バイナリ。

前提条件

このチュートリアルでは、 Ubuntu 20.04 を使用したサーバーの初期設定で説明されているように、sudo権限を持つroot以外のユーザーとファイアウォールで構成されたUbuntu20.04システムが必要です。

ステップ1—Goのインストール

このステップでは、サーバーにGoをインストールします。

まず、sshを介してUbuntuサーバーに接続します。

  1. ssh sammy@your_server_ip

次に、Webブラウザで公式のGoダウンロードページに移動します。 そこから、現在のバイナリリリースのtarballのURLをコピーします。

この記事の執筆時点で、最新リリースはgo1.16.7です。 GoをUbuntuサーバー(または任意のLinuxサーバー)にインストールするには、linux-amd64.tar.gzで終わるファイルのURLをコピーします。

リンクの準備ができたので、最初にホームディレクトリにいることを確認します。

  1. cd ~

次に、curlを使用してtarballを取得し、強調表示されたURLをコピーしたURLに置き換えてください。 -Oフラグは、これがファイルに出力されることを保証し、LフラグはHTTPSリダイレクトを指示します。これは、このリンクがGo Webサイトから取得され、ファイルがダウンロードされる前にここにリダイレクトされるためです。

  1. curl -OL https://golang.org/dl/go1.16.7.linux-amd64.tar.gz

ダウンロードしたファイルの整合性を確認するには、sha256sumコマンドを実行し、引数としてファイル名に渡します。

  1. sha256sum go1.16.7.linux-amd64.tar.gz

これにより、tarballのSHA256チェックサムが返されます。

Output
go1.16.7.linux-amd64.tar.gz 7fe7a73f55ba3e2285da36f8b085e5c0159e9564ef5f63ee0ed6b818ade8ef04 go1.16.7.linux-amd64.tar.gz

チェックサムがダウンロードページにリストされているものと一致する場合、この手順は正しく実行されています。

次に、tarを使用してtarballを抽出します。 このコマンドには、他の操作を実行する前にtarに指定されたディレクトリに移動するように指示する-Cフラグが含まれています。 これは、抽出されたファイルが/usr/local/ディレクトリに書き込まれることを意味します。これは、Goのインストールに推奨される場所です。xフラグは、tarに抽出するように指示します。詳細な出力(抽出されるファイルのリスト)が必要であることを通知し、fはファイル名を指定することを通知します。

  1. sudo tar -C /usr/local -xvf go1.16.7.linux-amd64.tar.gz

/usr/local/goはGoをインストールするための推奨される場所ですが、一部のユーザーは別のパスを好むか、または必要とする場合があります。

ステップ2—Goパスの設定

このステップでは、環境にパスを設定します。

まず、Goのルート値を設定します。これにより、ファイルを探す場所がGoに指示されます。 これを行うには、.profileファイルを編集します。このファイルには、ログインするたびにシステムが実行するコマンドのリストが含まれています。

好みのエディタを使用して、ユーザーのホームディレクトリに保存されている.profileを開きます。 ここでは、nanoを使用します。

  1. sudo nano ~/.profile

次に、ファイルの最後に次の情報を追加します。

sudo nano〜/ .profile
. . .
export PATH=$PATH:/usr/local/go/bin

この情報をプロファイルに追加したら、ファイルを保存して閉じます。 nanoを使用した場合は、CTRL+XYENTERの順に押してください。

次に、次のコマンドを実行してプロファイルを更新します。

  1. source ~/.profile

その後、go versionを実行して、goコマンドを実行できるかどうかを確認します。

  1. go version

このコマンドは、システムにインストールされているGoのバージョンのリリース番号を出力します。

Output
go version go1.16.7 linux/amd64

この出力は、サーバーでGoを実行していることを確認します。

ステップ3—インストールのテスト

Goがインストールされ、サーバーのパスが設定されたので、Hello, World!アプリケーションを作成して、Goが機能していることを確認できます。

まず、Goワークスペース用の新しいディレクトリを作成します。このディレクトリにGoがファイルを作成します。

  1. mkdir hello

次に、作成したディレクトリに移動します。

  1. cd hello

パッケージをインポートするときは、コード自体のモジュールを介して依存関係を管理する必要があります。 これを行うには、go mod initコマンドを使用してgo.modファイルを作成します。

  1. go mod init your_domain/hello

次に、お好みのテキストエディタでHello, World!Goファイルを作成します。

  1. nano hello.go

次のテキストをhello.goファイルに追加します。

hello.go
package main

import "fmt"

func main() {
    fmt.Println("Hello, World!")
}

次に、CTRL+XYENTERの順に押して、ファイルを保存して閉じます。

コードをテストして、Hello, World!グリーティングが出力されることを確認します。

  1. go run .
Output
Hello, World!

go runコマンドは、作成した新しいhelloディレクトリとインポートしたパスの.goソースファイルのリストからGoパッケージをコンパイルして実行します。 ただし、go buildを使用して、時間を節約できる実行可能ファイルを作成することもできます。

ステップ4—Goコードを実行可能ファイルのバイナリに変換する

go runコマンドは通常、頻繁な変更が必要なプログラムをコンパイルして実行するためのショートカットとして使用されます。 コードを完成させて、毎回コンパイルせずに実行したい場合は、go buildを使用して、コードを実行可能バイナリに変換できます。 コードを実行可能バイナリにビルドすると、アプリケーションは、バイナリの実行に必要なすべてのサポートコードを含む単一のファイルに統合されます。 バイナリ実行可能ファイルを作成したら、go installを実行してプログラムを実行可能ファイルのパスに配置し、システムのどこからでも実行できるようにします。 その後、プロンプトが表示されたら、プログラムはHello, World!を正常に出力し、プログラムを再度コンパイルする必要はありません。

試してgo buildを実行してください。 hello.goファイルが保存されているのと同じディレクトリからこれを実行するようにしてください。

  1. go build

次に、./helloを実行して、コードが正しく機能していることを確認します。

  1. ./hello
Output
Hello, World!

これにより、hello.goコードが実行可能バイナリに正常に変換されたことを確認できます。 ただし、このバイナリは、このディレクトリ内からのみ呼び出すことができます。 サーバー上の別の場所からこのプログラムを実行する場合は、実行するためにバイナリのフルファイルパスを指定する必要があります。

バイナリの完全なファイルパスを入力すると、すぐに面倒になる可能性があります。 別の方法として、go installコマンドを実行することもできます。 これはgo buildに似ていますが、実行可能ファイルを現在のディレクトリに残す代わりに、go install$GOPATH/binディレクトリに配置します。これにより、上の任意の場所から実行可能ファイルを実行できます。サーバー。

go installを正常に実行するには、go buildで作成したバイナリのインストールパスを渡す必要があります。 バイナリのインストールパスを見つけるには、次のgo listコマンドを実行します。

  1. go list -f ‘{{.Target}}

go listは、現在の作業ディレクトリに保存されている名前付きGoパッケージのリストを生成します。 fフラグを使用すると、go listは、渡されたパッケージテンプレートに基づいて異なる形式で出力を返します。 このコマンドは、Targetテンプレートを使用するように指示します。これにより、go listは、このディレクトリに保存されているパッケージのインストールパスを返します。

Output
‘/home/sammy/go/bin/hello

これは、go buildで作成したバイナリファイルのインストールパスです。 これは、このバイナリがインストールされているディレクトリが/home/sammy/go/bin/であることを意味します。

このインストールディレクトリをシステムのシェルパスに追加します。 異なる場合は、システム上のバイナリのインストールディレクトリを反映するように、このコマンドの強調表示された部分を必ず変更してください。

  1. export PATH=$PATH:/home/sammy/go/bin/

最後に、go installを実行して、パッケージをコンパイルしてインストールします。

  1. go install

helloと入力するだけで、この実行可能バイナリを実行してみてください

  1. hello
Output
Hello, World!

Hello, World!の出力を受け取った場合は、サーバー上の特定のパスと指定されていないパスの両方からGoプログラムを正常に実行可能にしています。

結論

最新のGoパッケージをダウンロードしてインストールし、そのパスを設定することで、Go開発に使用するシステムができました。 「Go」タグ内で、Goのインストールと使用に関する追加の記事を見つけてサブスクライブできます。

モバイルバージョンを終了