Go 和 Web 入门:部署至 Railway

Go 和 Web 入门:部署至 Railway

本指南旨在向您展示如何使用 Go 构建 Web 应用。您将在本地计算机上使用 Go 创建并测试一个简单的 Web 服务器,然后将您的 Web 应用部署到 Railway。

Railway 是一种托管服务,可用于部署您的应用。它支持各种部署配置,并具有大量功能,可为您的应用自定义托管设置。

开始之前

要遵循本指南,您必须在计算机上安装 Go。在此处下载并安装 Go:下载并安装 Go。

您的机器上应该安装了 Git 和 GitHub CLI。从这里下载并安装 Git:下载 - Git。从这里下载并安装 GitHub CLI:下载并安装 GitHub CLI。

需要 GitHub 帐户和 Railway 帐户。在此处注册 GitHub:创建 GitHub 帐户。在此处注册 Railway:创建 Railway 帐户

您必须熟悉 HTML、CSS、JavaScript 和 HTTP,才能理解指南中讨论的概念。

最后,了解 Go 很有用,但不是必需的。这是一份初学者指南。

你好,世界!前往

打开你的工作目录并创建一个新文件并将其命名为“main.go”。

在 `main.go` 中添加如下代码:

package main

import "fmt"

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

保存文件并通过在工作目录中的终端运行以下命令来测试它:

go run main.go

你的终端输出中应该会出现文本“Hello, World!”。

你好,世界!上网

我们刚刚使用 Go 创建了一个简单的 CLI 应用程序。接下来,让我们使用 Go 创建一个简单的 Web 服务器。注释掉上一步中刚刚编写的代码。在注释块上方,添加以下代码:

package main

import "fmt"
import "net/http"

func main() {
  http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "

Hello, World!

") }) http.ListenAndServe(":80", nil) }

保存文件并运行。在浏览器中访问“localhost”,您应该会在网页上看到文本“Hello, World!”。

Hello World web page

创建并上传 GitHub Repo

将您的项目目录初始化为 Git repo。

git init

提交您的项目文件。在本例中,它只是“main.go”文件。

git add main.go
git commit -m "Initial commit"

使用 GitHub 进行身份验证

gh auth login

将您的仓库上传到 GitHub

gh repo create my-repo --public --source=. --remote=origin
git push --set-upstream origin master

将“my-repo”替换为您想要的 repo 名称。

部署至铁路

Railway 提供多种方式来部署您的 Web 应用。您可以使用仪表板、CLI、API 等。本文:Railway 部署选项解释了在 Railway 平台上部署应用的所有多种方式。

我们将首先使用仪表板。

创建新的铁路项目

在浏览器中访问 dev.new。这会将您重定向到 railway.com/new,您将看到带有部署选项的 **新项目** 模式。

Railway New Project Modal

选择 **从 GitHub repo 部署** 并选择您之前创建的 repo。

Deploy From GitHub repo

Railway 平台将读取您的 repo 的内容,初始化项目,构建然后自动将其部署为服务。

Railway Build successful

为你的项目生成域

在铁路项目服务中选择**设置**。在**网络**下单击**生成域**。这样您就可以在互联网上访问您的服务。

Generate Domain

Railway 将为您的应用生成一个域名。单击 **生成域名** 几秒钟后,URL 就会出现。您将使用此 URL 在互联网上访问您的 Go Web 应用。

View Generated Domain

在浏览器中测试您新生成的域名。访问链接时,您应该会看到“Hello, World!”文本。

Test Generated Domain

使用 Go 提供静态文件

在本地项目文件夹中,创建一个新文件夹“static”。在“static”内创建一个名为“index.html”的新文件并添加以下代码:


  

My Static Website

更新 `main.go` 文件以从 `static` 文件夹提供静态文件。注释掉您编写的所有代码。在注释块上方,将以下代码添加到 `main.go`:

package main

import "net/http"

func main() {
    http.Handle("/", http.FileServer(http.Dir("./static")))
    http.ListenAndServe(":80", nil)
}

测试你的代码:

go run main.go

在浏览器中访问“localhost”,你应该会看到一个带有文字的网页:“我的静态网站”

My Static Website Local

铁路更新部署

要更新您的部署,只需使用 Git 暂存并提交您所做的文件更改。

git add .
git commit -m "App update"

然后将更新推送到 GitHub。

git push

将更改推送到 GitHub 后,Railway 将自动更新您的项目。等待几秒钟,然后访问您的应用程序 URL 以测试您的更改

Test Updated Site Live

结论

恭喜!您已成功使用 Go 构建了一个简单的 Web 应用程序并将其部署到 Railway。您学习了如何创建基本的 Web 服务器、提供静态文件以及利用 GitHub 进行版本控制和部署。Railway 凭借其用户友好的平台和强大的功能,让您可以轻松部署和管理应用程序。继续尝试使用 Go 和 Railway 构建更复杂、更可扩展的 Web 应用程序。祝您编码愉快!