redis
Module redis
API
![](https://bcentral-dev-packageicons.azureedge.net/images/ballerinax_redis_2.5.1.png)
ballerinax/redis Ballerina library
Overview
The Ballerina connector for Redis allows you to connect to Redis and manipulate key-value data stored in a Redis database. You can use the connector to manipulate string, hash, list, set, and sorted set data types. The functionality of the Ballerina connector for Redis is limited to the use of Redis as a database and cache. The message broker functionality of Redis is not yet exposed through this module.
Prerequisites
Before using this connector in your Ballerina application, complete the following:
- Make sure Redis cache is running in the local environment or use Redis cache running on the cloud (for example, Redis Enterprise Cloud).
- Configure the connector with details related to redis cache such as hostname, port number and password.
Quickstart
To use the Redis connector in your Ballerina application, update the .bal file as follows:
Step 1: Import connector
Import the ballerinax/redis
module into the Ballerina project as follows..
import ballerinax/redis;
Step 2: Create a new connector instance
To access a Redis datasource, you must first create a client
object. Create a client of the redis client type (i.e. redis:Client
) and provide the necessary connection parameters. This creates a connection/pool of connections to the given Redis database. A method for creating a client with a Redis client can be found below.
redis:ConnectionConfig redisConfig = { host: "localhost", password: "", options: { connectionPooling: true, isClusterConnection: false, ssl: false, startTls: false, verifyPeer: false, connectionTimeout: 500 } }; redis:Client conn = check new (redisConfig);
Step 3: Invoke connector operation
- You can insert a value for a specific key as follows.
string stringSetresult = check connection->set("Project", "Ballerina");
- Use
bal run
command to compile and run the Ballerina program.
Functions![](/images/permalink.svg)
mGet![](/images/permalink.svg)
mSet![](/images/permalink.svg)
mSetNx![](/images/permalink.svg)
Clients![](/images/permalink.svg)
redis: Client![](/images/permalink.svg)
Ballerina Redis connector provides the capability to access Redis cache. This connector lets you to perform operations to access and manipulate key-value data stored in a Redis database.
Constructor![](/images/permalink.svg)
Initializes the connector. During initialization you have to pass needed configurations such as host name, port number and password.
init (ConnectionConfig config)
- config ConnectionConfig - Configuration for the connector
append![](/images/permalink.svg)
Append a value to a key.
bitCount![](/images/permalink.svg)
Count set bits in a string.
Parameters
- key string - Key referring to a value
bitOpAnd![](/images/permalink.svg)
Perform bitwise AND between strings.
Parameters
- destination string - Result key of the operation
- keys string[] - Input keys to perform AND between
Return Type
bitOpOr![](/images/permalink.svg)
Perform bitwise OR between strings.
Parameters
- destination string - Result key of the operation
- keys string[] - Input keys to perform OR between
Return Type
bitOpNot![](/images/permalink.svg)
Perform bitwise NOT on a string.
bitOpXor![](/images/permalink.svg)
Perform bitwise XOR between strings.
Parameters
- destination string - Result key of the operation
- keys string[] - Input keys to perform XOR between
Return Type
decr![](/images/permalink.svg)
Decrement integer value of a key by one.
Parameters
- key string - Key referring to a value
decrBy![](/images/permalink.svg)
Decrement integer value of a key by the given number.
getBit![](/images/permalink.svg)
Returns bit value at offset in the string value stored at key.
getRange![](/images/permalink.svg)
Get substring of string stored at a key.
Parameters
- key string - Key referring to a value
- startPos int - Starting point of substring
- end int - End point of substring
getSet![](/images/permalink.svg)
Set string value of key and return its existing value.
Return Type
get![](/images/permalink.svg)
Get value of key.
Parameters
- key string - Key referring to a value
incr![](/images/permalink.svg)
Increment integer value of a key by one.
Parameters
- key string - Key referring to a value
incrBy![](/images/permalink.svg)
Increment integer value of key by the given amount.
incrByFloat![](/images/permalink.svg)
Increment integer value of key by the given float.
mGet![](/images/permalink.svg)
Get values of all given keys.
Parameters
- keys string[] - Keys of which values need to be retrieved
mSet![](/images/permalink.svg)
Set multiple keys to multiple values.
Parameters
- keyValueMap map<any> - Map of key-value pairs to be set
mSetNx![](/images/permalink.svg)
Set multiple keys to multiple values, only if none of the keys exist.
Parameters
- keyValueMap map<any> - Map of key-value pairs to be set
pSetEx![](/images/permalink.svg)
Set value and expiration in milliseconds of a key.
Parameters
- key string - Key referring to a value
- value string - Value to be set
- expirationTime int - Expiration time in milli seconds
set![](/images/permalink.svg)
Set the value of a key.
setBit![](/images/permalink.svg)
Sets or clears the bit at offset in the string value stored at key.
Parameters
- key string - Key referring to a value
- value int - Value to be set
- offset int - Offset at which the value should be set
setEx![](/images/permalink.svg)
Set the value and expiration of a key.
Parameters
- key string - Key referring to a value
- value string - Value to be set
- expirationPeriodSeconds int - Expiration time to be set, in seconds
setNx![](/images/permalink.svg)
Set value of a key, only if key does not exist.
setRange![](/images/permalink.svg)
Overwrite part of string at key starting at the specified offset.
Parameters
- key string - Key referring to a value
- offset int - Offset at which the value should be set
- value string - Value to be set
strln![](/images/permalink.svg)
Get length of value stored in a key.
Parameters
- key string - Key referring to a value
Return Type
lPush![](/images/permalink.svg)
Prepend one or multiple values to list.
lPop![](/images/permalink.svg)
Remove and get the first element in a list.
Parameters
- key string - Key referring to a value
Return Type
lPushX![](/images/permalink.svg)
Prepend one or multiple values to a list, only if the list exists.
bLPop![](/images/permalink.svg)
Remove and get the first element in a list, or block until one is available.
Return Type
bRPop![](/images/permalink.svg)
Remove and get the last element in a list, or block until one is available.
Return Type
lIndex![](/images/permalink.svg)
Get an element from list by its index.
Parameters
- key string - Key referring to a value
- index int - Index from which the element should be retrieved
lInsert![](/images/permalink.svg)
Insert an element before or after another element in a list.
Parameters
- key string - Key referring to a value
- before boolean - Boolean value representing Whether element should be inserted before or after the pivot
- pivot string - Pivot position
- value string - Value to insert
Return Type
lLen![](/images/permalink.svg)
Get length of a list.
Parameters
- key string - Key referring to a value
lRange![](/images/permalink.svg)
Get a range of elements from a list.
Parameters
- key string - Key referring to a value
- startPos int - Begining index of the range
- stopPos int - Last index of the range
lRem![](/images/permalink.svg)
Remove elements from list.
Parameters
- key string - Key referring to a value
- count int - Number of elements to be removed
- value string - Value which the elements to be removed should be equal to
lSet![](/images/permalink.svg)
Set the value of an element in a list by its index.
Parameters
- key string - Key of the list
- index int - Index of the element of which the value needs to be set
- value string - Value to be set
Return Type
lTrim![](/images/permalink.svg)
Trim list to the specified range.
Parameters
- key string - Key of the list
- startPos int - Starting index of the range
- stopPos int - End index of the range
rPop![](/images/permalink.svg)
Remove and get the last element in a list.
Parameters
- key string - Key of the list
Return Type
rPopLPush![](/images/permalink.svg)
Remove the last element in a list, append it to another list and return it.
rPush![](/images/permalink.svg)
Append one or multiple values to a list.
rPushX![](/images/permalink.svg)
Append one or multiple values to a list, only if the list exists.
sAdd![](/images/permalink.svg)
Add one or more members to a set.
Return Type
sCard![](/images/permalink.svg)
Get the number of members in a set
Parameters
- key string - Key of the set
sDiff![](/images/permalink.svg)
Return set resulting from the difference between the first set and all the successive sets
Parameters
- keys string[] - The keys of the sets
sDiffStore![](/images/permalink.svg)
Obtain the set resulting from the difference between the first set and all the successive. sets and store at the provided destination.
Parameters
- destination string - Destination key of the resulting set
- keys string[] - Keys of the sets to find the difference of
sInter![](/images/permalink.svg)
Return the intersection of the provided sets.
Parameters
- keys string[] - Keys of the sets to be intersected
sInterStore![](/images/permalink.svg)
Obtain the intersection of the provided sets and store at the provided destination.
Parameters
- destination string - Destination key of the resulting set
- keys string[] - Keys of the sets to be intersected
sIsMember![](/images/permalink.svg)
Determine if a given value is a member of a set.
Return Type
sMembers![](/images/permalink.svg)
Get all members in a set.
Parameters
- key string - Key of the set
sMove![](/images/permalink.svg)
Move a member from one set to another.
Parameters
- src string - Source key
- destination string - Destination key
- member string - Member to be moved
Return Type
sPop![](/images/permalink.svg)
Remove and return a random member from a set.
Return Type
sRandMember![](/images/permalink.svg)
Get one or multiple random members from a set.
Return Type
sRem![](/images/permalink.svg)
Remove one or more members from a set.
Return Type
sUnion![](/images/permalink.svg)
Return the union of multiple sets.
Parameters
- keys string[] - Array of keys of sets
sUnionStore![](/images/permalink.svg)
Return the union of multiple sets.
Parameters
- destination string - Destination key of the resulting set
- keys string[] - Array of keys of sets
zAdd![](/images/permalink.svg)
Add one or more members to a sorted set, or update its score if it already exist.
Parameters
- key string - Key of the sorted set
- memberScoreMap map<any> - Map of members and corresponding scores
Return Type
zCard![](/images/permalink.svg)
Get the number of members in a sorted set.
Parameters
- key string - Key of the sorted set
Return Type
zCount![](/images/permalink.svg)
Count the members in a sorted set with scores within the given range.
Parameters
- key string - Key of the sorted set
- min float - Minimum score of the range
- max float - Maximum score of the range
zIncrBy![](/images/permalink.svg)
Increment the score of a member in a sorted set.
Parameters
- key string - Key of the sorted set
- amount float - Amount to increment
- member string - Member whose score to be incremented
zInterStore![](/images/permalink.svg)
Intersect multiple sorted sets and store the resulting sorted set in a new key.
Parameters
- destination string - Destination key of the resulting sorted set
- keys string[] - Keys of the sorted sets to be intersected
zLexCount![](/images/permalink.svg)
Count the members in a sorted set within the given lexicographical range.
Parameters
- key string - Key of the sorted set
- min string - Minimum lexicographical value of the range
- max string - Maximum lexicographical value of the range
Return Type
zRange![](/images/permalink.svg)
Return a range of members in a sorted set, by index.
Parameters
- key string - Key of the sorted set
- min int - Minimum index of the range
- max int - Maximum index of the range
zRangeByLex![](/images/permalink.svg)
Return a range of members in a sorted set, by lexicographical range from lowest to highest.
Parameters
- key string - Key of the sorted set
- min string - Minimum lexicographical value of the range
- max string - Maximum lexicographical value of the range
Return Type
zRevRangeByLex![](/images/permalink.svg)
Return a range of members in a sorted set, by lexicographical range ordered from highest to lowest.
Parameters
- key string - Key of the sorted set
- min string - Lexicographical value of the range
- max string - Maximum lexicographical value of the range
Return Type
zRangeByScore![](/images/permalink.svg)
Return a range of members in a sorted set, by score from lowest to highest.
Parameters
- key string - Key of sorted set
- min float - Minimum score of range
- max float - Maximum score of range
Return Type
zRank![](/images/permalink.svg)
Determine index of a member in a sorted set.
Parameters
- key string - Key of the sorted set
- member string - Member of which the index needs to be obtained
zRem![](/images/permalink.svg)
Remove one or more members from a sorted set
Return Type
zRemRangeByLex![](/images/permalink.svg)
Remove all members in a sorted set between the given lexicographical range.
Parameters
- key string - Key of the sorted set
- min string - Minimum lexicographical value of the range
- max string - Maximum lexicographical value of the range
zRemRangeByRank![](/images/permalink.svg)
Remove all members in a sorted set within the given indices.
Parameters
- key string - Key of the sorted set
- min int - Minimum index of the range
- max int - Maximum index of the range
zRemRangeByScore![](/images/permalink.svg)
Remove all members in a sorted set within the given scores.
Parameters
- key string - Key of the sorted set
- min float - Minimum score of the range
- max float - Maximum score of the range
zRevRange![](/images/permalink.svg)
Return a range of members in a sorted set, by index, ordered highest to lowest.
Parameters
- key string - Key of the sorted set
- min int - Minimum index of the range
- max int - Maximum index of the range
Return Type
zRevRangeByScore![](/images/permalink.svg)
Return a range of members in a sorted set, by score from highest to lowest.
Parameters
- key string - Key of the sorted set
- min float - Minimum score of the range
- max float - Maximum score of the range
Return Type
zRevRank![](/images/permalink.svg)
Determine the index of a member in a sorted set
Parameters
- key string - Key of the sorted set
- member string - Member of which the index needs to be obtained
zScore![](/images/permalink.svg)
Determine the score of a member in a sorted set
Parameters
- key string - Key of the sorted set
- member string - Member of which the score needs to be obtained
zUnionStore![](/images/permalink.svg)
Return the union of multiple sorted sets
Parameters
- destination string - Destination key of the resulting set
- keys string[] - Array of keys of sorted sets
hDel![](/images/permalink.svg)
Delete one or more hash fields.
Return Type
hExists![](/images/permalink.svg)
Determine if a hash field exists.
Return Type
hGet![](/images/permalink.svg)
Get the value of a hash field.
hGetAll![](/images/permalink.svg)
Get the all values of a hash.
Parameters
- key string - Key of the hash
hIncrBy![](/images/permalink.svg)
Increment the integer value of a hash field by the given number.
hIncrByFloat![](/images/permalink.svg)
Increment the float value of a hash field by the given number.
hKeys![](/images/permalink.svg)
Get all the fields in a hash.
Parameters
- key string - Key of the hash
hLen![](/images/permalink.svg)
Get the number of fields in a hash.
Parameters
- key string - Key of the hash
hMGet![](/images/permalink.svg)
Get the values of all the given hash fields.
hMSet![](/images/permalink.svg)
Set multiple hash fields to multiple values.
Return Type
hSet![](/images/permalink.svg)
Set the string value of a hash field.
Return Type
hSetNx![](/images/permalink.svg)
Set the string value of a hash field, only if the field does not exist.
Return Type
hStrln![](/images/permalink.svg)
Get the string length of the field value in a hash.
Return Type
hVals![](/images/permalink.svg)
Get all the values in a hash.
Parameters
- key string - Key of the hash
Return Type
del![](/images/permalink.svg)
Delete one or more keys.
Parameters
- keys string[] - Key to be deleted
exists![](/images/permalink.svg)
Determine how many keys exist.
Parameters
- keys string[] - Keys of which existence to be found out
expire![](/images/permalink.svg)
Set a key's time to live in seconds.
Return Type
keys![](/images/permalink.svg)
Find all keys matching the given pattern.
Parameters
- pattern string - Pattern to match
move![](/images/permalink.svg)
Move a key to another database.
Return Type
persist![](/images/permalink.svg)
Remove the expiration from a key.
Parameters
- key string - Key of which expiry time should be removed
Return Type
pExpire![](/images/permalink.svg)
Set a key's time to live in milliseconds.
Parameters
- key string - Key of which expiry time should be removed
- timeMilliSeconds int - Expiry time in milli seconds
Return Type
pTtl![](/images/permalink.svg)
Get the time to live for a key in milliseconds.
Parameters
- key string - Key of which time-to-live should be obtained
randomKey![](/images/permalink.svg)
Return a random key from the keyspace.
Return Type
rename![](/images/permalink.svg)
Rename a key.
Return Type
renameNx![](/images/permalink.svg)
Rename a key, only if the new key does not exist.
Return Type
sort![](/images/permalink.svg)
Sort elements in a list, set or sorted set.
Parameters
- key string - Key of the data typeure to be sorted
Return Type
ttl![](/images/permalink.svg)
Get the time to live for a key.
Parameters
- key string - Key of which the time to live needs to be obtained
Return Type
redisType![](/images/permalink.svg)
Determine the type stored at key.
Parameters
- key string - Key of which the type needs to be obtained
ping![](/images/permalink.svg)
Ping the server.
auth![](/images/permalink.svg)
Authenticate to the server.
Parameters
- password string - Password to authenticate
Return Type
echo![](/images/permalink.svg)
Echo the given string.
Parameters
- message string - Message to be echo-ed
Return Type
stop![](/images/permalink.svg)
function stop()
Stops the registered service.
Records![](/images/permalink.svg)
redis: ConnectionConfig![](/images/permalink.svg)
The Client endpoint configuration for Redis databases.
Fields
- host string(default "localhost") - The host of the Redis database
- password string(default "") - Password for the database connection
- options Options(default {}) - Properties for the connection configuration
redis: Options![](/images/permalink.svg)
Connection options for Redis Client Endpoint.
Fields
- clientName string(default "") - The clientName of the connection
- connectionPooling boolean(default false) - Boolean value depending on whether the connection pooling is enabled or not
- isClusterConnection boolean(default false) - Whether to enable cluster connection or not
- ssl boolean(default false) - Boolean value depending on whether SSL is enabled or not
- startTls boolean(default false) - Boolean value depending on whether startTLS is enabled or not
- verifyPeer boolean(default false) - Boolean value depending on whether peer verification is enabled or not
- database int(default -1) - The database to be used with the connection
- connectionTimeout int(default -1) - The timeout value for the connection
Errors![](/images/permalink.svg)
redis: Error![](/images/permalink.svg)
Represents a redis generic error
Import
import ballerinax/redis;
Metadata
Released date: 11 months ago
Version: 2.5.1
License: Apache-2.0
Compatibility
Platform: java11
Ballerina version: 2201.7.0
Pull count
Total: 146
Current verison: 4
Weekly downloads
Keywords
IT Operations/Databases
Cost/Freemium
Contributors