Go项目多测试环境的配置管理

一个项目能够快速迭代上线,肯定少不了测试环境。而开发如果要在本地切换使用测试环境的配置,一般是手动修改,还可能提交到生产环境,会非常繁琐。 因此一个“伟大”的工具诞生了:easyconf。

Go项目多测试环境的配置管理

一个项目能够快速迭代上线,肯定少不了测试环境。而开发如果要在本地切换使用测试环境的配置,一般是手动修改,还可能提交到生产环境,会非常繁琐。

因此一个“伟大”的工具诞生了:easyconf

GitHub - nixihz/easyconf: Allow to generate config file from template and data.
Allow to generate config file from template and data. - nixihz/easyconf

我们需要准备两个物料:一个是模板文件,一个是配置文件。

  1. configmap_tpl.yaml
---
apiVersion: v1
kind: ConfigMap
metadata:
  name: demp
  namespace: dev
data:
  config.yaml: |
    server:
      http:
        name: demo
        addr: ":8080"
        server_config:
          read_timeout: 10
          write_timeout: 15
          read_header_timeout: 12
          idle_timeout: 8
    mysql:
      default:
        dsn: "{{ .mysql__default__dsn }}"
        is_debug: "{{ .mysql__default__is_debug }}"
        
  1. config-dev.yaml
local:
  mysql__default__dsn: "username@tcp(127.0.0.1:3306)/dev?charset=utf8"
  mysql__default__is_debug: true

k8s:
  mysql__default__dsn: "username@tcp(demo.com:3306)/prod?charset=utf8"
  mysql__default__is_debug: false

执行一下命令即可生成本地配置文件和 测试文件的 yaml文件。

easyconf -r local -t ./configmap_tpl.yaml -f ./config-dev.yaml -o ./configs/

easyconf -r k8s -t ./configmap_tpl.yaml -f ./config-dev.yaml -o ./configs/configmap.yaml

输出文件:

configs/config.yaml

server:
  http:
    name: demo
    addr: ":8080"
    server_config:
      read_timeout: 10
      write_timeout: 15
      read_header_timeout: 12
      idle_timeout: 8
mysql:
  default:
    dsn: "username@tcp(127.0.0.1:3306)/dev?charset=utf8"
    is_debug: "true"
            

configs/configmap.yaml

apiVersion: v1
kind: ConfigMap
metadata:
  name: demp
  namespace: dev
data:
  config.yaml: |
    server:
      http:
        name: demo
        addr: ":8080"
        server_config:
          read_timeout: 10
          write_timeout: 15
          read_header_timeout: 12
          idle_timeout: 8
    mysql:
      default:
        dsn: "username@tcp(demo.com:3306)/prod?charset=utf8"
        is_debug: "false"

Read more

golang proto api 校验国际化 protovalidate

golang proto api 校验国际化 protovalidate

众所周知,protobuf 原型文件扩展很多功能,比如生成 http 接口层代码,顺势就有了生成接口参数校验代码的需求。 早期可以使用https://github.com/bufbuild/protoc-gen-validate 来实现,通过生成特定的 go 代码的方式来实现校验。 github 中也提到目前趋于稳定,不会有更多新特性的支持,推荐大家使用新的版本 protovalidate,https://github.com/bufbuild/protovalidate 。该版本是protoc-gen-validate 的“精神继承者”。它不需要任何代码生成并支持自定义约束。 现在我们尝试新版本,并且增加国际化支持。 go get github.com/bufbuild/protovalidate-go import "github.com/bufbuild/protovalidate-go" syntax = "proto3"; package

By brian
git clone 复制一个整个仓库并推送到新地址

git clone 复制一个整个仓库并推送到新地址

要使用 git clone --bare 复制一个新的仓库并推送到远程仓库,可以按照以下步骤操作: 1. 克隆一个裸仓库 首先,使用 git clone --bare 命令克隆源仓库。假设源仓库的 URL 是 https://github.com/user/source-repo.git,你可以执行以下命令: bash复制 git clone --bare https://github.com/user/source-repo.git 这将创建一个新的裸仓库(没有工作区),通常会创建一个名为 source-repo.git 的目录。 2. 进入裸仓库目录 进入刚刚克隆的裸仓库目录: bash复制 cd source-repo.git 3. 添加新的远程仓库 接下来,

By brian
搜索引擎技巧不用多,学会 3 个加速 100% 找到目标

搜索引擎技巧不用多,学会 3 个加速 100% 找到目标

在搜索时使用英文关键词,提高结果质量。尽量使用 google.com 以下搜索引擎技巧在 google.com 进行测试,效果都很好,前三个非常常用且强烈推荐。 使用精确搜索 * 建议: 使用双引号 "" 搜索完全匹配的短语,避免无关结果。 * 示例: * "Java NullPointerException" fix * 场景: 找到错误信息的精确解决方案。 利用站内搜索 * 建议: 使用 site: 限制搜索范围到特定网站。 * 示例: * site:stackoverflow.com "TypeError: undefined is not a function" * 场景: 搜索 Stack Overflow、官方文档或技术博客的特定内容。 一些关键词 * 建议:

By brian
沪ICP备2022013452号-1