Nginx部署Gin Web服务

简介

Go是一门开放源代码的编程语言,它与其他语言相比有着更好的性能和更高的并发性。Gin是一个用于构建Web应用程序的轻量级框架,它提供了简单而强大的API来实现Web应用程序和微服务的开发。在本文中,我们将介绍如何使用Nginx部署Go Gin开发的Web服务,并提供centos7系统上的Nginx安装步骤。

准备工作

在开始之前,需要确保您已经在centos7系统上安装了以下软件:

Go 1.14或更高版本

Nginx

Git

步骤

安装Nginx

使用yum安装Nginx:

python 复制代码
yum install nginx

启动Nginx并使其在系统启动时自动启动:

python 复制代码
systemctl start nginx
systemctl enable nginx

验证Nginx是否已成功安装:

在浏览器中输入服务器的IP地址或域名,如果能看到"Welcome to nginx!"的响应页面,表示Nginx已经成功安装。

创建Gin Web服务

在终端或命令行中使用以下命令创建Gin Web服务:

python 复制代码
mkdir myweb
cd myweb
go mod init myweb
go get -u github.com/gin-gonic/gin

然后,创建一个名为main.go的文件,并将以下内容添加到该文件中:

python 复制代码
package main

import (
    "net/http"

    "github.com/gin-gonic/gin"
)

func main() {
    r := gin.Default()

    r.GET("/", func(c *gin.Context) {
        c.String(http.StatusOK, "Hello, world!")
    })

    r.Run(":8080")
}

测试Web服务:

在终端或命令行中使用以下命令启动Web服务:

go复制代码go run main.go

如果一切正常,您应该在浏览器中输入http://localhost:8080并看到"Hello, world!"的响应。

配置Nginx

打开Nginx配置文件/etc/nginx/nginx.conf:

bash复制代码vi /etc/nginx/nginx.conf

将以下内容添加到配置文件中:

python 复制代码
server {
    listen 80;

    server_name example.com;

    location / {
        proxy_pass http://localhost:8080;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

其中,server_name是您的域名或服务器的IP地址。

使用以下命令检查Nginx配置是否正确:

python 复制代码
sudo nginx -t

如果配置正确,则重新加载Nginx:

sudo systemctl reload nginx

测试部署:

在浏览器中输入您的服务器的IP地址或域名。如果一切正常,您应该看到"Hello, world!"的响应。

注意:如果您使用了防火墙(例如firewalld),请确保允许流量通过端口80。

python 复制代码
sudo firewall-cmd --add-service=http --permanent
sudo firewall-cmd --add-service=https --permanent
sudo firewall-cmd --reload

恭喜,您已经成功地使用Nginx部署了Go Gin开发的Web服务!

相关推荐
月弦笙音2 小时前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端
吹水一流2 小时前
微信小程序页面栈:从一个 Bug 讲到彻底搞懂
前端·微信小程序
j***82702 小时前
【MyBatisPlus】MyBatisPlus介绍与使用
android·前端·后端
Python大数据分析@2 小时前
我把pdfplumber整成了可以拖拉拽的web软件
前端·pdf
小华同学ai2 小时前
终于有人帮你整理好了,火爆的“系统级提示词”支持ChatGPT、Claude、Gemini、xAI的
前端·后端·github
葡萄城技术团队3 小时前
SpreadJS 电子表格权限管控设置指南
前端
HashTang3 小时前
一个人就是一支队伍:从 Next.js 到显示器,聊聊我的“全栈续航”方案
前端·后端·程序员
朕的剑还未配妥3 小时前
vue2中transition使用方法解析,包含底部弹窗示例、样式未生效踩坑记录
前端·vue.js
q***48413 小时前
Redis Desktop Manager(Redis可视化工具)安装及使用详细教程
android·前端·后端
码上成长3 小时前
组件库提速:Storybook + Chromatic + Visual Test 实战
前端·自动化