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

相关推荐
hdsoft_huge21 小时前
Java 实现高效查询海量 geometry 及 Protobuf 序列化与天地图前端分片加载
java·前端·状态模式
MoonBit月兔21 小时前
用 MoonBit 打造的 Luna UI:日本开发者 mizchi 的 Web Components 实践
前端·数据库·mysql·ui·缓存·wasm·moonbit
程序员修心21 小时前
CSS浮动与表格布局全解析
前端·html
POLITE321 小时前
Leetcode 238.除了自身以外数组的乘积 JavaScript (Day 7)
前端·javascript·leetcode
光影少年1 天前
AI前端开发需要会哪些及未来发展?
前端·人工智能·前端框架
Vincent_Vang1 天前
多态 、抽象类、抽象类和具体类的区别、抽象方法和具体方法的区别 以及 重载和重写的相同和不同之处
java·开发语言·前端·ide
菩提小狗1 天前
小迪安全_第4天:基础入门-30余种加密编码进制&Web&数据库&系统&代码&参数值|小迪安全笔记|网络安全|
前端·网络·数据库·笔记·安全·web安全
闲蛋小超人笑嘻嘻1 天前
非父子通信: provide和inject
前端·javascript·vue.js
止观止1 天前
不止解构:深入掌握 ES6+ 对象与函数的高级语法糖
前端·javascript·es6
C_心欲无痕1 天前
react - useTransition标记低优先级更新
前端·react.js·前端框架