Atena Go Driver
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.