golang實現一個mysql中隨機獲取cookies的API

之前用FASTAPI寫了一個隨機cookies請求的接口,現在嘗試用golang實現同樣的效果

1.編寫go代碼

package mainimport ("database/sql""encoding/json""fmt"_ "github.com/go-sql-driver/mysql""log""net/http""os""time"
)// 獲取環境變量(優先使用環境變量,不存在則使用默認值)
func getEnv(key, defaultValue string) string {if value, exists := os.LookupEnv(key); exists {return value}return defaultValue
}// 數據庫配置
const (dbDriver   = "mysql"dbUser     = "nobuy"      // 替換為實際用戶名dbPassword = "@zzwl" // 替換為實際密碼dbHost     = "192.168.1.1" // 替換為實際主機dbPort     = "3306"      // 替換為實際端口dbName     = "nobuy"   // 替換為實際數據庫名
)// CookieResponse API響應結構
type CookieResponse struct {Status      string `json:"status"`Cookie      string `json:"cookie,omitempty"`Error       string `json:"error,omitempty"`UserAccount string `string:"user_account,omitempty"`
}var db *sql.DBfunc main() {initDB()defer db.Close()// 注冊路由apihttp.HandleFunc("/randomcookie", randomCookieHandler)// 啟動HTTP服務器port := ":8081"log.Printf("Server started at http://localhost%s", port)log.Fatal(http.ListenAndServe(port, nil))
}func initDB() {dsn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?parseTime=true",getEnv("DB_USER", dbUser),getEnv("DB_PASSWORD", dbPassword),getEnv("DB_HOST", dbHost),getEnv("DB_PORT", dbPort),getEnv("DB_NAME", dbName))var err errordb, err = sql.Open(dbDriver, dsn)if err != nil {log.Fatalf("Database connection failed: %v", err)}// 設置連接池參數db.SetMaxOpenConns(25)db.SetMaxIdleConns(25)db.SetConnMaxLifetime(5 * time.Minute)// 驗證數據庫連接if err = db.Ping(); err != nil {log.Fatalf("Database ping failed: %v", err)}log.Println("Database connected successfully")
}
func randomCookieHandler(w http.ResponseWriter, r *http.Request) {w.Header().Set("Content-Type", "application/json")response := CookieResponse{}var cookie stringvar user_account stringerr := db.QueryRow(`SELECT cookies,user_accountFROM external_accountWHERE account_type_id=2 AND is_deleted=0 AND account_status=0ORDER BY RAND()LIMIT 1`).Scan(&cookie, &user_account)switch {case err == sql.ErrNoRows:response.Status = "error"response.Error = "No cookies avaiable"w.WriteHeader(http.StatusNotFound)case err != nil:response.Status = "error"response.Error = fmt.Sprintf("Database error: %v", err)w.WriteHeader(http.StatusInternalServerError)default:response.Status = "success"response.Cookie = cookieresponse.UserAccount = user_accountlog.Printf(response.Status, response.Cookie, response.UserAccount)}json.NewEncoder(w).Encode(response)}

2.docker打包golang鏡像(直接運行.go文件)

打包的Dockerfile如下所示

FROM alibaba-cloud-linux-3-registry.cn-hangzhou.cr.aliyuncs.com/alinux3/golang AS builder# 設置工作目錄
WORKDIR /app
# 設置國內鏡像源
ENV GOPROXY=https://goproxy.cn,direct
# 復制 Go 源代碼到工作目錄
COPY . .# 構建你的 Go 程序
# RUN go build go_code/hello/demo.go# 暴露端口 8888
EXPOSE 8081# 設置容器啟動時執行的命令
CMD go run "cookie_api.go"

打包成docker鏡像

docker build -f Dockerfile3 -t cookieapi:1 .

3.docker打包golang鏡像

將golang打包成可執行程序,然后打包docker鏡像

FROM registry.cn-hangzhou.aliyuncs.com/devops_de/golang:1.21-alpine AS builder# 設置工作目錄
WORKDIR /app
# 設置國內鏡像源
ENV GOPROXY=https://goproxy.cn,direct
# 復制 Go 源代碼到工作目錄
COPY . .# 復制源代碼并編譯
RUN CGO_ENABLED=0 GOOS=linux go build -ldflags="-s -w" -o nobuy-app# 運行階段
FROM registry.cn-hangzhou.aliyuncs.com/devops_de/alpine:3.18
WORKDIR /app
# 從構建階段復制二進制文件
COPY --from=builder /app/nobuy-app /app/nobuy-app
# 設置可執行權限
RUN chmod +x /app/nobuy-app
# 暴露端口 8888
EXPOSE 8081# 設置啟動命令
CMD ["/app/nobuy-app"]

4.運行效果對比

運行效果差異如下所示

[root@centos-1 cookies]# docker ps
CONTAINER ID   IMAGE                                                                                                    COMMAND                  CREATED        STATUS                 PORTS                                                                                            NAMES
adc6c31adf23   cookieapi:1                                                                                              "/app/nobuy-app"         2 hours ago    Up 2 hours             0.0.0.0:8181->8081/tcp, :::8181->8081/tcp                                                        romantic_bohr
f6023569cc62   cookies_api:0625                                                                                         "/bin/sh -c 'go run …"   3 hours ago    Up 3 hours             0.0.0.0:8089->8081/tcp, :::8089->8081/tcp     

在這里插入圖片描述

上述結果可以看到,直接運行cookie_api.go和運行打包可執行的go程序,內存差了兩倍

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/86976.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/86976.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/86976.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

[Vue2組件]三角形角標

[Vue2組件]三角形角標 <template><div class"ys-subscript" :style"svgStyle"><svg width"200" height"200" viewBox"0 0 200 200" xmlns"http://www.w3.org/2000/svg"><!-- 三角形背景 - 右…

洛谷刷題4

B4354 [GESP202506 一級] 假期閱讀 題目傳送門 B4354 難度&#xff1a;入門 很簡單的題&#xff0c;如果小A看的頁數≤這本書的頁數&#xff0c;輸出他看的頁數 否則&#xff0c;輸出這本書的頁數 AC代碼&#xff1a; #include <iostream> using namespace std; in…

【基于Echarts的地圖可視化】

<!DOCTYPE html> <html> <head><meta charset"utf-8"><title>中國牛只分布可視化</title><script src"https://cdn.jsdelivr.net/npm/echarts5.4.3/dist/echarts.min.js"></script><script src"h…

系統架構設計師備考之架構設計基礎

1.計算機系統基礎知識 1.1.計算機系統概述 計算機系統的定義與組成 計算機系統是指用于數據管理的計算機硬件、軟件及網絡組成的系統。 計算機系統可劃分為硬件和軟件兩部分。硬件由機械、電子元器件、磁介質和光介質等物理實體構成&#xff1b; 軟件是一系列按照特定順序組織…

針對華為云服務器使用率過大

從這兩張監控圖可以看出&#xff0c;服務器在大約上午 10:30 前后經歷了一次明顯的負載變化&#xff1a; 1. 圖表解讀 CPU 使用率 從凌晨到上午約 10:00 前&#xff0c;CPU 基本處于 0–2% 的閑置狀態。10:00–14:00 之間&#xff0c;CPU 利用率逐步攀升&#xff0c;多次沖擊 3…

記dwz(JUI)前端框架使用之--服務端響應提示框

目錄 前言 一、DWZ服務器端響應種類 二、如何增加info級別的消息提示 1.打開項目的BaseController.java類 2.打開項目的dwz.min.js文件 3.最后在前端DWZ的主加載頁面或者js文件中添加如下代碼&#xff1a; 前言 本篇文章沒有講太多東西&#xff0c;主要是個人工作記錄保…

leetcode 295. 數據流的中位數

時間復雜度分析&#xff1a;為什么你的中位數查找方案會超時&#xff1f; 分析你提供的MedianFinder實現&#xff0c;其時間復雜度較高的原因主要在于findMedian函數的實現方式。讓我詳細解釋&#xff1a; 代碼時間復雜度分析 你的代碼中兩個主要函數的時間復雜度如下&#…

大語言模型介紹

隨著2022年底 ChatGPT 再一次刷新 NLP 的能力上限&#xff0c;大語言模型&#xff08;Large Language Model&#xff0c;LLM&#xff09;開始接替傳統的預訓練語言模型&#xff08;Pre-trained Language Model&#xff0c;PLM&#xff09; 成為 NLP 的主流方向&#xff0c;基于…

STM32 CCR寄存器

?1. CCR寄存器在輸入捕獲模式下的特性? ?只讀屬性?&#xff1a; 當定時器通道配置為輸入捕獲模式&#xff08;如捕獲上升沿/下降沿&#xff09;時&#xff0c;CCR寄存器硬件自動變為只讀?。軟件寫入操作無效&#xff0c;只能在捕獲事件發生時由硬件自動更新為當前CNT值。…

【JS-6-ES6中的let和const】深入理解ES6中的let和const:塊級作用域與變量聲明的新范式

在ES6(ECMAScript 2015)之前&#xff0c;JavaScript中只有var一種變量聲明方式&#xff0c;這導致了許多作用域相關的問題。ES6引入了let和const兩種新的變量聲明方式&#xff0c;徹底改變了JavaScript的作用域規則。本文將深入探討let和const的特性、優勢以及它們與var的區別。…

[C語言]數據類型關鍵字詳解

基本數據類型 關鍵字說明存儲大小(通常)取值范圍(通常)示例int聲明整型變量4字節(32位系統)-2,147,483,648 到 2,147,483,647int count 100;char聲明字符型變量1字節-128 到 127 或 0 到 255char grade ‘A’;float聲明單精度浮點數4字節1.2e-38 到 3.4e38 (約6-7位有效數字…

黑馬python(二十二)

目錄&#xff1a; 1.Python操作Mysql基礎使用 2.Python操作Mysql數據插入 3.綜合案例 1.Python操作Mysql基礎使用 2.Python操作Mysql數據插入 3.綜合案例 代碼復用 黑馬python&#xff08;二十一&#xff09;章節的的代碼&#xff0c;讀取文件內容

課堂筆記:吳恩達的AI課(AI FOR EVERYONE)-W1 深度學習的非技術性解釋

深度學習的非技術性解釋 &#xff08;1&#xff09;示例1&#xff1a;以商場為主買T恤為例&#xff0c;價格和需求的關系怎么樣&#xff1f; 一般來說&#xff0c;價格越高&#xff0c;需求越少 這里輸入A是 價格&#xff0c;輸出B是需求&#xff0c;其中的映射關系是神經元&a…

dlib檢測視頻中的人臉并裁剪為圖片保存

環境要求 找個帶有基本cv配置的虛擬環境安裝上dlib依賴的人臉檢測的基礎環境即可&#xff0c;主要是&#xff1a; pip install boost dlib opencv-python缺的按提示安裝。 demo 設置好視頻路徑和圖像保存路徑&#xff0c;裁剪尺寸&#xff08;默認256&#xff09;以及裁剪幀…

真的!ToDesk遠程控制已上線原生鴻蒙系統!

2025年5月&#xff0c;ToDesk遠程控制正式宣布完成對PC鴻蒙系統的適配&#xff0c;成為業界首批原生支持HarmonyOS OS的跨端遠控工具。 作為國內支持上億設備的遠程控制軟件&#xff0c;ToDesk以無縫互聯、快速響應、安全無界為核心&#xff0c;重新定義了跨設備遠程協作的界限…

Java-58 深入淺出 分布式服務 ACID 三階段提交3PC 對比2PC

點一下關注吧&#xff01;&#xff01;&#xff01;非常感謝&#xff01;&#xff01;持續更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持續更新中&#xff01;&#xff08;長期更新&#xff09; 目前2025年06月16日更新到&#xff1a; AI煉丹日志-29 - 字節…

matplotlib 繪制餅圖

1、功能介紹&#xff1a; 使用 python 的 matplotlib 庫來創建一個簡單的餅圖。 2、代碼部分&#xff1a; import matplotlib.pyplot as plt# 示例數據 labels [A, B, C, D, E] # 類別標簽 sizes [15, 30, 45, 5, 5] # 每個類別對應的數值&#xff08;百分比&#xff09…

用Rust寫平衡三進制除法器

1、除法的本質 除法的本質是減法&#xff0c;也就是一個大的數減去一個小的數&#xff0c;比如:10/2&#xff0c;也就是10-2-2-2-2-20&#xff0c;所以商5余0&#xff0c;10/3&#xff0c;也就是10-3-3-31&#xff0c;所以商3余1&#xff0c;這也是很常見的方法&#xff0c;但如…

深入探索WordPress Multisite:構建與管理多站點網絡

隨著互聯網的快速發展&#xff0c;越來越多的企業和個人開始使用內容管理系統來搭建和維護自己的網站。WordPress作為全球最受歡迎的CMS之一&#xff0c;因其強大的功能和靈活性&#xff0c;成為了許多網站管理員的首選平臺。而在一些特定需求的場景下&#xff0c;WordPress Mu…

.Net Core 獲取文件路徑

在 .NET Core 中獲取文件路徑的方法取決于你要獲取的文件的位置和上下文。這里將介紹幾種常見的方式來獲取文件路徑。 1. 獲取當前工作目錄 你可以使用 Directory.GetCurrentDirectory() 方法來獲取當前工作目錄的路徑&#xff1a; using System; using System.IO; class P…