k8s使用外部mysql做内部服务

创建 mysql-endpoints.yaml

apiVersion: v1
kind: Endpoints
metadata:
  name: mysql-dev
  namespace: default
subsets:
  - addresses:
    - ip: 10.1.0.32
    ports:
      - port: 3306

创建mysql-service.yaml

apiVersion: v1
kind: Service
metadata:
  name: mysql-dev
spec:
  ports:
    - port: 3306
    
apiVersion: v1
kind: Service
metadata:
  name: mysql-dev
  namespace: default
spec:
  clusterIP: 10.1.61.45
  ports:
  - port: 3306
    targetPort: 3306
    protocol: TCP

使用数据库服务

main.go

package main

import (
    "database/sql"
    "fmt"
    _ "github.com/go-sql-driver/mysql"
    "net/http"
)

func IndexHandler(w http.ResponseWriter, r *http.Request) {
    _, _ = fmt.Fprintln(w, "hello rushui")
}

func RowsHandler(w http.ResponseWriter, r *http.Request) {
    //第⼀步:打开数据库,格式是 ⽤户名:密码@/数据库名称?编码⽅式
    db, err := sql.Open("mysql", "root:root@tcp(mysql-dev:3306)/test?charset=utf8")
    if err != nil {
        fmt.Println(err)
    }
    //关闭数据库
    var id int
    var name string
    //查询数据,指定字段名,返回sql.Rows结果集
    rows, err := db.Query("select id,name from user")
    if err != nil {
        fmt.Println(err)
    }
    defer rows.Close()
    for rows.Next() {
        _ = rows.Scan(&id, &name)
        _, _ = fmt.Fprintln(w, name)
    }
}

func main() {
    http.HandleFunc("/", IndexHandler)
    http.HandleFunc("/rows", RowsHandler)
    _ = http.ListenAndServe(":8081", nil)
}
 
 
0人点赞
 
k8s
 
 



作者:如水网

posted @   技术颜良  阅读(665)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
历史上的今天:
2019-08-19 Shell脚本检测文件夹是否已被挂载的方法
2019-08-19 prometheus + influxdb + grafana + mysql
点击右上角即可分享
微信分享提示