atena

package module
v0.0.0-...-36ac410 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 14, 2022 License: CC-BY-SA-4.0 Imports: 8 Imported by: 0

README

Atena Go Driver

docs-source Go Report Card

Getting started

Atena Go driver is a fully fledged tool for a fast and easy management of everything about Atena Db. This library hosts all the necessary to handle requests to Atena Server. Thanks to this package you will be able to completely administer, manage and use Atena DB. We are making updates as a new core version comes out and tag the release according to the core release.

Just a few steps and you are ready to go.

So let's start developing!!!

Step 1. Import the atena-go-driver module

 go get github.com/mchl-labs/atenadb-go-driver

Step 2. Import the Required Namespace

 import (
    "fmt"
    "context"
    "github.com/mchl-labs/atenadb-go-driver"
 )
What provides Atena golang driver?

Atena golang driver provides 2 different classes to manage Atena db:

  • AtenaAdmin - AtenaAdmin provides everything you need for dbs and users management.
  • AtenaDb - In the other hand, AtenaDb features a complete set of features that enable all kind of queries to your db making easier your development experience.

Step 3. Initialize connection

Connection is set up when an AtenaDb or AtenaAdmin object is instantiated. The AtenaDb and the AtenaAdmin are the main arbiters of the connection to Atena, your application should maintain a single instance of these classes throughout its runtime.

In order to initialize the connection you need the following info:

USERNAME, PASSWORD, HOST_NAME:PORT_NUMBER, DBNAME

where USERNAME is your atena username (e.g. default user "Admin"),

PASSWORD is your atena server's password (e.g. default psw user Admin is "Admin", you can change it whenever you want),

HOST_NAME is the host name of your server (e.g. localhost),

PORT_NUMBER is the port number Atena is listening on (usually e.g. 5001)

and DBNAME the DB you want to connect to (e.g. "Atena" our default db which is always available, you don't need to create it. When you turn on Atena, you can just start using it).

HOST_NAME:PORT_NUMBER is optional in both the classes. If you don't need advanced configuration you can just omit it. Atena will connect to localhost:5001 the default AtenaDb endpoint.


// `HOST_NAME:PORT_NUMBER` is optional in both the classes. 
// If you don't need advanced configuration you can just omit it. Atena will connect to localhost:5001 the default AtenaDb endpoint.

atenaAdmin, err := atena.BuildAdmin(username, password)
db, err := atena.BuildDefault(username, password,"Atena")

// OR

atenaAdmin, err := atena.BuildAdmin(username, password, "HOST_NAME:PORT_NUMBER")
db, err := atena.Build(username, password,"HOST_NAME:PORT_NUMBER", "Atena")

AtenaAdmin

Users and dbs management 💼

Now that you've retreived the connection to the database, all that's left is to use it. Here are some simple operations:

Create New User
Naming rules:

Usernames and passwords can contain letters, numbers and the underscore (_).

result := atenaAdmin.CreateUser(username, password)

Returns a bool representing the result of the operation.

Change Password
Naming rules:

Usernames and passwords can contain letters, numbers and the underscore (_).

 result := atenaAdmin.ChangePassword(newpassword)

Returns a bool representing the result of the operation.

Create New DB ( using the default db engine ) ⚙️
This method allow you to create a new db using the default Db engine of Atena Db.

This db is saved persistently on-disk by default and it automatically optimize the usage of your resources to provide the best performance using as few resources as possible.

Stop care about save resources and limit waste. Atena takes care for you.

Unlike all the other K/V stores on the market who work entirely in-memory or on-disk this db optimize the usage of your memory.

It supports data larger than your memory, by leveraging fast external storage. So it is also consistent and you won't lose any data. It uses consistent recovery using a fast non-blocking checkpointing technique, that lets applications trade-off performance for commit latency.

Atena is strongly clound-oriented and memory is very expensive in the cloud, so run a K/V store completely in-memory can be very expensive. Atena doesn't need a lot of memory to works and at the same time doesn't have capacity limits due to the limited memory resources. It's designed for heavy updates and read/write loads as well as top-class performance.

result := atenaAdmin.CreateDB("mynewdbname")

Returns a bool representing the result of the operation.

Create New DB ( using the Atena RBTree Engine ) ⚙️

This db engine is still in beta and we don't recommend use it. However it has already been thoroughly tested and is already stable 🟢

This method allow you to create a new db using the Atena RBTree Engine.

This db is a completely custom db engine realized by Atena. CRUD operations and transactions on DB are made in log time (O(log n)). The engine is based on our RedBlack Tree implementation in C#.

It is meant as an advanced and more complex db engine option. In fact it has got two option in addition to the usual parameters.

These option are:

  • LFU - LFU is an eviction policy which autonomously removes the oldest and least used record from your store ( as cache ), optimizing your db size and resources usage
  • on-disk persistence - Instead on-disk persistence enable the saving on disk of the db to avoid data loss.

💡: We recommend enable this two feature together to get the best experience possible.

⚠️ NOTE: Enabling LFU without on-disk persistence enabled can cause data loss.

result := atenaAdmin.CreateDBRBT("mynewdbname", bool: lfu, bool: on-disk-persistence)

Returns a bool representing the result of the operation.

Create New DB ( using the Atena HT Engine ) ⚙️

This db engine is still in beta and we don't recommend use it. However it has already been thoroughly tested and is already stable 🟢

This method allow you to create a new db using the Atena RBTree Engine.

This db is a completely custom db engine realized by Atena. The engine is based on an hashtable.

It is meant as an advanced and more complex db engine option. In fact it has got two option in addition to the usual parameters.

These option are:

  • LFU - LFU is an eviction policy which autonomously removes the oldest and least used records from your store ( as cache ), optimizing your db size and resources usage
  • on-disk persistence - Instead on-disk persistence enable the saving on disk of the db to avoid data loss.

💡: We recommend enable this two feature together to get the best experience possible.

⚠️ NOTE: Enabling LFU without on-disk persistence enabled can cause data loss.

result := atenaAdmin.CreateDBHT("mynewdbname", bool: lfu, bool: on-disk-persistence);

Returns a bool representing the result of the operation.

Delete DB
result := atenaAdmin.DeleteDB(dbname)

Returns a bool representing the result of the operation.

Logout

💡: We recommend logging out if you finished using AtenaAdmin. This will boost AtenaDb performance.

⚠️ NOTE: One time you Logout you need do reinitialize the connection and Build anothe Admin object ( Step 3.)

result := atenaAdmin.Logout();

Returns a bool representing the result of the operation.

AtenaDb

Db operations 👷

Let's make some operations on our db. Now that you've retreived the connection to the database, all that's left is to use it. Here are some simple operations:

Set K/V record

This command allow you to set a key and a value of type string. You can put practically anything inside this K/V record because everything, from complex object (JSON, Protobuf) to byte[], can be serialized into a string.

result := db.Set("hello", "hi")

Returns a bool representing the result of the operation.

Get Value ( relative to the key we ask for)
value, err := db.Get("hello")
if err != nil {
  		log.Fatal("Error")
  }
  log.Println("GET OP")
  log.Println("KEY: hello VALUE: " + value)

Returns a bool with the status of the current operation and if the operation was successful the value related to the key we asked for.

Modify the value

To modify the value you can simply use the Set method.

Increment

Specifically designed for analytics and counters storage this method allows you to modify the value of your counter adding or substracting directly through one single call.

This feature is designed to optimize performance, reduce latency and minimize pointless DB calls.

To use this feature the value must be an integer


// SET a counter.

result := db.Set("clic", "1")

if result
{
    log.Println("SET clic : 1")
}

// Increment the counter by 11 units
newvalue, err := db.Incr("clic",11)
if err != nil {
  		log.Fatal("Error")
  }
  log.Println("KEY: clic; NEWVALUE: " + newvalue)

Returns a bool with the status of the current operation and, if the operation was successful, the new value related to the counter we wanted to modify.

Delete K/V record
result := atena.Del("hello")

Returns a bool representing the result of the operation.

RemoveAll records

Thanks to this method you are able to completely remove every K/V record from the db.

result := atena.RemoveAll()

Returns a bool representing the result of the operation.

Documentation

Index

Constants

View Source
const Version = "v2.0.0"

Version is the current AtenaDb Go driver's version.

Variables

This section is empty.

Functions

This section is empty.

Types

type Manage

type Manage struct {
	// contains filtered or unexported fields
}

Manage implements atena Db operations

func BuildAdmin

func BuildAdmin(user string, password string, url string) (*Manage, error)

BuildAdmin creates the admin DB client

func BuildAdminDefault

func BuildAdminDefault(user string, password string) (*Manage, error)

BuildAdminDefault creates the admin DB client with default url

func (*Manage) ChangePassword

func (client *Manage) ChangePassword(password string) bool

ChangePassword changes user password

func (*Manage) CreateDB

func (client *Manage) CreateDB(name string) bool

CreateDB creates a new DB

func (*Manage) CreateDBHT

func (client *Manage) CreateDBHT(name string, lfu bool, save bool) bool

CreateDBHT creates a new DB using HT db engine

func (*Manage) CreateDBRBT

func (client *Manage) CreateDBRBT(name string, lfu bool, save bool) bool

CreateDBRBT creates a new DB using RBT db engine

func (*Manage) CreateUser

func (client *Manage) CreateUser(user string, password string) bool

CreateUser creates a new user

func (*Manage) DeleteDB

func (client *Manage) DeleteDB(name string) bool

DeleteDB deletes the selected db

func (*Manage) Dispose

func (client *Manage) Dispose()

Dispose connection

func (*Manage) Logout

func (client *Manage) Logout() bool

Logout closes the current session

type Ops

type Ops struct {

	// DB connection info
	DB string
	// contains filtered or unexported fields
}

Ops implements atena Db operations

func Build

func Build(user string, password string, url string, db string) (*Ops, error)

Build creates the DB client

func BuildDefault

func BuildDefault(user string, password string, db string) (*Ops, error)

BuildDefault creates the DB client with default url

func (*Ops) Del

func (client *Ops) Del(key string) bool

Del operation

func (*Ops) Dispose

func (client *Ops) Dispose()

Dispose connection

func (*Ops) Get

func (client *Ops) Get(key string) (string, error)

Get operation

func (*Ops) Incr

func (client *Ops) Incr(key string, inc int32) (string, error)

Incr operation

func (*Ops) RemoveAll

func (client *Ops) RemoveAll() bool

RemoveAll removes all the K/V records stored

func (*Ops) Set

func (client *Ops) Set(key string, value string) bool

Set operation

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL