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服务!

相关推荐
Danny_FD13 分钟前
Vue + Element UI 实现模糊搜索自动补全
前端·javascript
gnip17 分钟前
闭包实现一个简单Vue3的状态管理
前端·javascript
斐济岛上有一只斐济23 分钟前
后端程序员的CSS复习
前端
Enddme26 分钟前
《面试必问!JavaScript 中this 全方位避坑指南 (含高频题解析)》
前端·javascript·面试
有梦想的程序员27 分钟前
微信小程序使用 Tailwind CSS version 3
前端
溟洵1 小时前
Qt 窗口 工具栏QToolBar、状态栏StatusBar
开发语言·前端·数据库·c++·后端·qt
用户2519162427111 小时前
Canvas之图像合成
前端·javascript·canvas
每天开心1 小时前
噜噜旅游App(4)——构建旅游智能客服模块,实现AI聊天
前端·微信小程序·前端框架
超凌1 小时前
el-input-number出现的点击+-按钮频现不生效
前端
三小河1 小时前
contentEditable 实现可编辑区域
前端