使用gin框架,编写一个接收数据的api接口

功能:这里主要编写一个接口,将其json 数据存入对应的redis队列中,并统计每天的每小时请求数量

环境:

go

version go1.22.0 linux/amd64

 平台  linux X64

步骤一  新建目录  命令如下:

mkdir FormData

步骤二 新增配置文件config.yaml   内容如下:

#开启的端口
server:
    port: 8082

# 存储数据数据
redis_mq:
    host: 127.0.0.1
    port: 6379
    password:
    db: 2
    queue_key_name: data_list

redis_count:
    host: 127.0.0.1
    port: 6379
    password:
    db: 2

步骤三 编写主要逻辑  main.go 内容如下:

package main

import (
        "fmt"
        "github.com/gin-gonic/gin"
        "github.com/go-redis/redis"
        "gopkg.in/yaml.v3"
        "io/ioutil"
        "log"
        "strconv"
        "sync"
        "time"
)

var (
        redisClient      *redis.Client
        redisCountClient *redis.Client
        mutex            sync.Mutex
        wg               sync.WaitGroup
)

func main() {
        // 初始化 Redis 连接
        config, err := loadConfig("config.yaml")
        if err != nil {
                log.Fatal(err)
        }
        //      fmt.Printf("%v", config)
        //}
        dbnum, err := strconv.Atoi(config["redis_mq"]["db"])
        if err != nil {
                fmt.Println("转换失败:", err)
                return
        }
        redisClient = redis.NewClient(&redis.Options{
                Addr:     config["redis_mq"]["host"] + ":" + config["redis_mq"]["port"],
                Password: config["redis_mq"]["password"],
                DB:       dbnum,
                PoolSize: 50,
        })
        countdbnum, err := strconv.Atoi(config["redis_count"]["db"])
        if err != nil {
                fmt.Println("转换失败:", err)
                return
        }
        redisCountClient = redis.NewClient(&redis.Options{
                Addr:     config["redis_count"]["host"] + ":" + config["redis_count"]["port"],
                Password: config["redis_count"]["password"],
                DB:       countdbnum,
                PoolSize: 50,
        })

        // 初始化 Gin 框架
        router := gin.Default()

        // 定义接口路由
        router.POST("/pushData", func(c *gin.Context) {
                pushData(c, config)
        })
        router.GET("/pushData", func(c *gin.Context) {
                pushData(c, config)
        })

        // 启动服务
        router.Run(fmt.Sprintf(":%s", config["server"]["port"]))
}

func pushData(c *gin.Context, config map[string]map[string]string) {
        //defer wg.Done()
        // 获取请求参数
        // 计数器逻辑
        paramsJson, err := c.GetRawData()
        if err != nil {
                log.Println("读取数据错误:", err)
                c.JSON(500, gin.H{"status": 500, "message": "error_data"})
                return
        }
        wg.Add(1)
        go pushtoredis(string(paramsJson), config)
        //mutex.Lock()
        // 存储到 Redis

        //mutex.Unlock()
        // 返回成功响应
        c.JSON(200, gin.H{"Status": 200, "Message": "成功", "Data": map[string]string{"ShotPendingSize": ""}})
}

func pushtoredis(paramsJson string, config map[string]map[string]string) error {
        defer wg.Done()
        now := time.Now()
        month := now.Month()
        day := now.Day()
        hour := now.Hour()
        err := redisClient.LPush(config["redis_mq"]["queue_key_name"], paramsJson).Err()
        if err != nil {
                log.Println("推入redis错误:", err)
                return err
        }
        countKey := fmt.Sprintf("from_data_%d_%d_%d", month, day, hour)
        err = redisCountClient.Incr(countKey).Err()
        if err != nil {
                log.Println("计数器错误:", err)
                // 处理计数器错误情况
                return err
        }
        return nil
}

func loadConfig(filename string) (map[string]map[string]string, error) {
        // 读取配置文件
        data, err := ioutil.ReadFile(filename)
        if err != nil {
                return nil, fmt.Errorf("无法读取配置文件: %s", err)
        }

        // 解析配置文件
        var config map[string]map[string]string
        err = yaml.Unmarshal(data, &config)
        if err != nil {
                return nil, fmt.Errorf("配置文件解析失败: %s", err)
        }

        return config, nil
}

步骤四 项目初始化 进行依赖 命令如下:

go mod init FormData

步骤五  项目所需要的依赖添加到go.mod  命令如下:

 go mod tidy

步骤六 先运行一下  如果不报错 在进行编译

 go run main.go

go build -o for_data # 这里重命名了

步骤七 运行  这里需要主要 端口和redis 相关配置 可以根据实际情况 修改config.yaml 。修改后重新运行即可,无需重新编译。命令如下:

直接在shell 中 运行命令

 ./form_data

 若执行不了  请注意相关权限

chmod + form_data

步骤八 请求接口,验证接口处理是否正常。

打开postman  

请求地址 http://127.0.0.1:8082/pushData

 可以观察go的后台输出 如下图所示:

关注redis  如下图所示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/447846.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

javascript实现解决浮点数加减乘除运算误差丢失精度问题【收藏点赞】

相信程序都会遇到这样的问题,有时需要在js上做运算合计等浮点数加减乘除,但会有些浮点数会有误差问题。下面用js来解决浮点数加减乘除运算误差丢失精度这个请 【收藏点赞】。 是程序都会在浮点数加减乘除上有误差问题,这是计算机二进制生成的…

防御保护--第七次作业

题目 要求 在FW5和FW3之间建立一条IPSEC通道,保证10.0.2.0/24网段可以正常访问到192.168.1.0/24 过程 FW5 FW3

Websocket在Asp.net webApi(.net framework)上的应用

之前在写看板部分的web api的时候,都是通过Ajax在规定时间内轮询调用web api,这样简单省事,但是当看板多了(并发量上来)以后,比较消耗服务器的性能,所以最近研究了websocket,希望使用…

Window10数据库崩溃启动失败,MySQL8.0.30通过data文件夹恢复数据库到Docker

背景: 昨天关机前还在使用mysql,一切正常,但今天打开电脑,发现mysql启动不起来了,老是提示端口占用,但是系统也没有新安装什么软件,而且通过查询nat命令也没发现3306端口占用。而且修改成3307等…

【格与代数系统】格与哈斯图

【格与代数系统】格与代数系统汇总 目录 常见的偏序关系 覆盖 哈斯图 例1 例2 例3 格与哈斯图 例1 例2 常见的偏序关系 偏序关系:自反性反对称性传递性 整数集合上的小于等于(大于等于)关系、幂集中的包含关系 、正整数的整除和整…

网络原理初识(2)

目录 一、协议分层 1、分层的作用 2、OSI七层模型 3、TCP / IP五层(或四层)模型 4、网络设备所在分层 5、网络分层对应 二、封装和分用 发送过程(封装) 1、应用层(应用程序) QQ 2、传输层 3、网络层 4、数据链路层 5、物理…

AI皮肤测试的基本原理

人工智能测试皮肤的实现原理通常涉及计算机视觉和机器学习技术。以下是一般的实现步骤和原理,涉及数据收集、特征提取、模型训练和优化等多个步骤,利用这些步骤中的技术手段来实现对皮肤状况的识别和分类。北京木奇移动技术有限公司,专业的软…

Python 导入Excel三维坐标数据 生成三维曲面地形图(体) 5-2、线条平滑曲面且可通过面观察柱体变化(二)

环境和包: 环境 python:python-3.12.0-amd64包: matplotlib 3.8.2 pandas 2.1.4 openpyxl 3.1.2 scipy 1.12.0 代码: import pandas as pd import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D from scipy.interpolate import griddata fr…

raid0、raid1、raid5、raid10选哪个?一文给你答案!

下午好,我的网工朋友。 关于磁盘阵列的用法,总有朋友对其用途与功能一知半解,很容易弄混。 而我们在做监控项目存储时,经常会用到磁盘阵列。 什么是磁盘阵列?为什么要做磁盘阵列?用什么样的磁盘阵列合适…

阿里云99元服务器和腾讯云99元服务器你选哪个?

99元一年云服务器可以选择阿里云或腾讯云,选择阿里云99元服务器还是腾讯云99元服务器?价格相同,阿腾云建议选择阿里云99元服务器,原因有二,阿里云99元服务器是ECS,腾讯云99元服务器是轻量应用服务器&#x…

【智能算法】蝙蝠算法(BA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.代码实现4.参考文献 1.背景 2010年,Yang受到蝙蝠回声定位的特性启发,提出了蝙蝠算法(Bat Algorithm, BA)。 2.算法原理 2.1算法思想 蝙蝠算法模拟了蝙蝠利用回声定位系统寻找小型昆虫进行捕食的行为&…

ICLR 2024 | Meta AI提出ViT寄存器结构,巧妙消除大型ViT中的伪影以提高性能

论文题目:Vision Transformers Need Registers 论文链接:https://arxiv.org/abs/2309.16588 视觉Transformer(ViT)目前已替代CNN成为研究者们首选的视觉表示backbone,尤其是一些基于监督学习或自监督学习预训练的ViT&a…

Python3虚拟环境之virtualenv

virtualenv 在开发Python应用程序的时候,系统安装的Python3只有一个版本:3.7。所有第三方的包都会被pip安装到Python3的site-packages目录下。 如果要同时开发多个应用程序,这些应用程序都会共用一个Python,就是安装在系统的Pyt…

【力扣100】【好题】322.零钱兑换 || 01背包完全背包

添加链接描述 思路: dp[j]数组表示的是在金额达到 j 的时候所需要的最小硬币数金额:背包容量,每个硬币的个数都为1:背包中物品的价值,硬币面额:物品重量dp[j]min(dp[j],dp[j-coin]1) class Solution:def …

【c语言 】数组入门

🎈个人主页:豌豆射手^ 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:C语言 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进步&…

Redhat Linux(RHEL) - Primavera P6 EPPM 安装及分享

引言 继上一期发布的Oracle Linux版环境发布之后,近日我又制作了基于Redhat Linux 的P6虚拟机环境,同样里面包含了全套P6 最新版应用服务 此虚拟机仅用于演示、培训和测试目的。如您在生产环境中使用此虚拟机,请先与Oracle Primavera销售代表…

什么是农业四情监测设备?

【TH-Q2】智慧农业四情监测设备是一种高科技的农田监测工具,旨在实时监测和管理农田中的土壤墒情、作物生长、病虫害以及气象条件。具体来说,它主要包括以下组成部分: 气象站:用于监测气温、湿度、风速等气象数据,为农…

proxy配置代理

通过代理配置可以实现以下几个作用 跨域请求处理:当前端应用运行在一个域名下,而需要请求的 API 接口位于另一个域名下时,由于浏览器的同源策略限制,会导致跨域请求失败。通过代理配置,可以将前端应用的请求先发送到同…

基于鹦鹉优化算法(Parrot optimizer,PO)的无人机三维路径规划(提供MATLAB代码)

一、无人机路径规划模型介绍 无人机三维路径规划是指在三维空间中为无人机规划一条合理的飞行路径,使其能够安全、高效地完成任务。路径规划是无人机自主飞行的关键技术之一,它可以通过算法和模型来确定无人机的航迹,以避开障碍物、优化飞行…

2024最新最全【网络安全】学习路线,零基础入门到精通

01 什么是网络安全 网络安全可以基于攻击和防御视角来分类,我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术,而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 无论网络、Web、移动、桌面、云等哪个领域,都有攻与防两面…