前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >GoLang 环境变量与配置

GoLang 环境变量与配置

作者头像
闻说社
发布2024-06-12 15:09:58
890
发布2024-06-12 15:09:58

在编程语言中环境变量与配置是相辅相成的。不同环境加载不同的配置成为了必需品。

一、开始

1.1) 为什么需要配置和环境变量?

  • 配置更好的管理项目的,集中式的管理项目,会使得项目更好维护。
  • 环境变量是与代码进行解耦,更好的维护。
  • 项目部署切换环境方便。

1.2) build 会将哪些内容打包到二进制

  • go 文件
  • 依赖的go文件
  • embed 嵌入文件

配置文件不是嵌入的,不会加入配置文件。

1.3) 哪些内容会需要配置

  • 数据库
  • 秘钥
  • 服务器端口
  • 环境变量
  • 路径
  • 特殊标识符(调试标识符)
  • 缓存、消息队列
  • 第三方服务
  • 定时任务
  • 分布式系统配置
  • 监控系统
  • 日志统计
  • ...

二、配置

  • viper 是 go 中出名的配置工具库

三、设置系统环境变量

代码语言:javascript
复制
sh复制代码set GO_ENV=production myapp.exe

#!/bin/bash
export GO_ENV=test && ./myapp

四、环境变量 dotenv

适合在开发环境:

  • 安装
代码语言:javascript
复制
sh复制代码go get -u github.com/joho/godotenv
  • 创建一个配置文件:
代码语言:javascript
复制
sh复制代码touch config.yml # config/config.yml
  • 一个配置文件示例:
代码语言:javascript
复制
yml复制代码server:
  port: 8090
db:
  user: admin
  password: secret
  url: 'https://db'

配置并使用

代码语言:javascript
复制
sh复制代码package main

import (
    "fmt"
    "github.com/spf13/viper"
)

func main() {
    println("hello world!")
    GetConfig()
}

func GetConfig() {
    viper.SetConfigName("config")
    viper.SetConfigType("yml")
    viper.AddConfigPath("./config")

    err := viper.ReadInConfig()

    if err != nil {
            panic(fmt.Errorf("Fatal Error config: file: %w \n", err))
    }

    fmt.Println("Server Port: ", viper.GetInt("server.port"))
    fmt.Println("Database User: ", viper.GetString("db.user"))
}

五、生产环境

systemd

systemd 是一套用于启动和管理系统进程的系统和服务管理器。

systemd 能够通过 systemctl配置文件对服务进行控制:

  • 配置文件位置:/etc/systemd/system/ 目录下。
  • systemctl 命令,以下是一些常用的命令

命令

作用

sudo systemctl start <unit>

启动指定的服务或其他 unit

sudo systemctl stop <unit>

停止指定的服务或其他 unit

sudo systemctl restart <unit>

重启指定的服务或其他 unit

sudo systemctl reload <unit>

重新加载指定的服务配置

sudo systemctl enable <unit>

启用服务开机自启动

sudo systemctl disable <unit>

禁用服务开机自启动

sudo systemctl status <unit>

查看指定服务或其他 unit 的状态

sudo systemctl daemon-reload

重新加载 systemd 管理器配置

  • 配置示例
代码语言:javascript
复制
ini复制代码[Unit]
Description=My App Service
After=network.target

[Service]
ExecStart=/path/to/myapp
ExecReload=/path/to/myapp reload
ExecStop=/path/to/myapp stop
Restart=always
Environment="GO_ENV=production"
EnvironmentFile=-/etc/myapp/env

[Install]
WantedBy=multi-user.target

配置文件是一个 ini 文件。Service 下的 Environment/EnvironmentFile 配置环境变量相关的内容。

六、docker

6.1) dockerfile

代码语言:javascript
复制
Dockerfile复制代码FROM golang:1.16

ENV GO_ENV=production
ENV DATABASE_URL=postgres://user:password@localhost:5432/proddb
WORKDIR /app
COPY . .
RUN go mod download
RUN go build -o myapp .
EXPOSE 8080

CMD ["./myapp"]

6.2) docker-compose

代码语言:javascript
复制
compose复制代码version: '3'
services:
  myapp:
    image: myapp:latest
    environment:
      - GO_ENV=production
      - DATABASE_URL=postgres://user:password@db:5432/proddb
    ports:
      - "8080:8080"

6.3) k8s

  • deployment.yaml
代码语言:javascript
复制
yaml复制代码apiVersion: apps/v1
kind: Deployment
metadata:
  name: myapp
spec:
  replicas: 2
  selector:
    matchLabels:
      app: myapp
  template:
    metadata:
      labels:
        app: myapp
    spec:
      containers:
      - name: myapp
        image: myapp:latest
        env:
        - name: GO_ENV
          value: "production"
        - name: DATABASE_URL
          value: "postgres://user:password@db:5432/proddb"
        ports:
        - containerPort: 8080

七、小结

本文主要介绍 go 中项目环境变量和配置文件处理方式,环境变量可以通过系统级配置,可以通过 env 配置,在环境多采用 docker 等配置进行配置。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、开始
    • 1.1) 为什么需要配置和环境变量?
      • 1.2) build 会将哪些内容打包到二进制
        • 1.3) 哪些内容会需要配置
        • 二、配置
        • 三、设置系统环境变量
        • 四、环境变量 dotenv
        • 五、生产环境
          • systemd
          • 六、docker
            • 6.1) dockerfile
              • 6.2) docker-compose
                • 6.3) k8s
                • 七、小结
                相关产品与服务
                容器服务
                腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档