mirror of
https://github.com/nabbar/golib.git
synced 2025-10-11 18:50:08 +08:00

Package Monitoring : - use packag dedicated to monitor component - each monitor work as standalone server to monitor health - collect metrics to export them to prometheus exporter Package Prometheus : - review to simplify use for API and not API metrics - optimize code Package Status : - Rework to use Monitor package - Rework to use native json / text Marshaller interface Context : - rework context config (context var) to use sync map and sync RWMutex (WORM) - move gin context to dedicated sub package (dependancies of logger make circular dependencies) - optimize code Config : - rework to optimize sync / collect of component - rework status to monitor - remove monitor managment from config to each component - add a func to set default logger to implement inherit default logger options - optimize code IOUtils : - isolate logger / closer interface as a usable & public interface & instance - this interface / instance allow to collect io.closer over a context to close all if context is done Logger : - rework to use context.config map - rework to use ioutils closer - rework to allow options to inherit a default options, or the last version of options - optimize code Size : - Add package Size to calculate and manipulate size Byte or bit - Add encoding : Text/JSON/Yaml/Toml... - Add option to défine default unit : Byte or bit Other : - adjust following code - optimize code - limit use of atomic value - rework to use RWMutex instead of sync.Mutex to maximize capabilities of read instead of write - remove 32bit build for CI/CD - add darwin/arm64 build for CI/CD Bump Dependencies
Version package
Help manage package, version, build hash, tag ....
Example of implement
Create a package release :
/
...
release/
release.go
version.go
In release.go
file, we will create the public variable to be overwrite in build :
package release
type EmptyStruct struct{}
var (
// Release the git tag of the current build, used with -X release.Release=$(git describe --tags HEAD || git describe --all HEAD)
Release = "0.0"
// Build the git commit of the current build, used with -X release.Build=$(git rev-parse --short HEAD)
Build = "00000"
// Date the current datetime RFC like for the build, used with -X release.Date=$(date +%FT%T%z)
Date = "2017-10-21T00:00:00+0200"
// Package the current package name of the build directory, used with -X release.Package=$(basename $(pwd))
Package = ""
// Package the current package name of the build directory, used with -X release.Description=...
Description = "example of dexscription ..."
// Author the name of the author for the current package, used with -X release.Author=...
Author = "placeholder"
// Prefix the package prefix could be used example for env var, used with -X config.Prefix=...
Prefix = "EXPL"
)
In version.go
file, we will implement the call to package golib/version
:
package release
import "github.com/nabbar/golib/version"
var (
vers version.Version
)
func init() {
vers = version.NewVersion(version.License_MIT, release.Package, release.Description, release.Date, release.Build, release.Release, release.Author, release.Prefix, release.EmptyStruct{}, 1)
}
func GetVersion() version.Version {
return vers
}