Skip to main content
Version: 2.8.x(Latest)

The gcfg component adopts an interface design to achieve high scalability. Through interface design, users can customize configuration retrieval methods, such as etcd, zookeeper, consul, kubernetes configmap, apollo, etc.

Interface Definition

https://github.com/gogf/gf/blob/master/os/gcfg/gcfg_adaper.go

// Adapter is the interface for configuration retrieving.
type Adapter interface {
// Available checks and returns the configuration service is available.
// The optional parameter `resource` specifies certain configuration resource.
//
// It returns true if configuration file is present in default AdapterFile, or else false.
// Note that this function does not return error as it just does simply check for backend configuration service.
Available(ctx context.Context, resource ...string) (ok bool)

// Get retrieves and returns value by specified `pattern`.
Get(ctx context.Context, pattern string) (value interface{}, err error)

// Data retrieves and returns all configuration data as map type.
// Note that this function may lead lots of memory usage if configuration data is too large,
// you can implement this function if necessary.
Data(ctx context.Context) (data map[string]interface{}, err error)
}

Setting Interface Implementation

The configuration object can set the currently used interface implementation through the SetAdapter method.

// SetAdapter sets the adapter of current Config object.
func (c *Config) SetAdapter(adapter Adapter)

Retrieving Interface Implementation

The configuration object can retrieve the currently used interface implementation through the GetAdapter method.

// GetAdapter returns the adapter of current Config object.
func (c *Config) GetAdapter() Adapter

Documentation