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)
}
作者:如水网
分类:
kubernetes
· 浏览器原生「磁吸」效果!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