Provision a Tessell Database Service
What is a Tessell Database Service?
Tessell Database Service is a fully managed cloud database service that offers support for a variety of database engines such as Oracle, MySQL, PostgreSQL, SQL Server, MongoDB, and Milvus on your choice of cloud including AWS and Azure. It simplifies the process of setting up, managing, securing, and scaling databases in the cloud. With Tessell, you can enjoy features like high performance, data browsing and consumption, granular level control for governance, usage-based billing, and unparalleled security. It provides a multi-cloud architecture that is both high-performing and secure, while also being user-friendly. It offers scalable and cost-effective database solutions with customisations for provisioning databases, backups, snapshots, SLAs, Schedules, etc.
Prerequisite APIs
- Get Access Token
- Returns details about the Tessell Subscriptions
- Get a list of all software images. Using the name filter, a software image can be found using name.
- Get a list of Compute Profiles.
- Get a list of VPCs
- View a list of available Compute Resources that can be used for newer provisioning
- Get a list of Availability Machine SLAs
- Get a list of available Parameter Profiles
Provisioning API
Provision a Simple MySQL DB Service
Here is a simple request in Python to provision a MySQL Server
Python Code For MySQL DB Service
import requests
url = "https://api.{your_tenant_server}/services"
data = '''
{
"name": "my-service-90f0fac8",
"description": "",
"subscription": "default",
"edition": "COMMUNITY",
"engineType": "MYSQL",
"topology": "single_instance",
"softwareImage": "MySQL 8.0",
"softwareImageVersion": "MySQL 8.0.34 (RHEL)",
"autoMinorVersionUpdate": true,
"enableDeletionProtection": false,
"enableStopProtection": false,
"infrastructure": {
"cloud": "aws",
"region": "ap-south-1",
"availabilityZone": "ap-south-1a",
"vpc": "example_vpc",
"computeType": "tesl_2_a",
"enableEncryption": true,
"encryptionKey": "default-encryption-key",
"additionalStorage": 0
},
"serviceConnectivity": {
"servicePort": "3306",
"enablePublicAccess": true,
"allowedIpAddresses": [
"49.924.357.563"
],
"enableSSL": false
},
"creds": {
"masterUser": "master",
"masterPassword": "Tessell123"
},
"maintenanceWindow": {
"day": "Sunday",
"time": "02:00",
"duration": 30
},
"snapshotConfiguration": {
"sla": "DWMY",
"schedule": {
"backupStartTime": {
"hour": 19,
"minute": 30
},
"dailySchedule": {
"backupsPerDay": 1
},
"weeklySchedule": {
"days": [
"Sunday"
]
},
"monthlySchedule": {
"commonSchedule": {
"dates": [
1
],
"lastDayOfMonth": false
}
},
"yearlySchedule": {
"commonSchedule": {
"dates": [
15
],
"months": [
"January"
],
"lastDayOfMonth": false
}
}
}
},
"engineConfiguration": {
"mysqlConfig": {
"parameterProfileId": "1482dbc2-0897-402a-bb0a-f878b241878a"
}
},
"databases": [
{
"databaseName": "db1",
"databaseConfiguration": {
"mysqlConfig": {
"parameterProfileId": "1482dbc2-0897-402a-bb0a-f878b241878a"
}
}
}
],
"tags": []
}
'''
headers = {
"Content-Type": "application/json",
"Authorization": "eyJhbGciOiJSUzUxMiJ9.eyJwcnZsZyI6IlBBWU1FTlRTO1NFQ1VSSVRZO1NFUlZFUlM7U0NSSVBUX0xJQlJBUlk7UFJPVklTSU9OSU5HO1NVQlNDUklQVElPTlM7SU5URUdSQVRJT05TO01ZX1NFUlZJQ0VTO0NPTVBVVEU7VElDS0VUUztVVElMSVpBVElPTjtBVkFJTEFCSUxJVFlfTUFDSElORVM7QkVOQ0hNQVJLUztBRE1JTjtEQl9HT1ZFUk5BTkNFO0lBTTtCSUxMSU5HO05FVFdPUktTO0RBVEFGTElYIiwic3ViIjoic29udS52ZXJtYUB0ZXNzZWxsLmNvbSIsInNjb3BlIjoiYWNjZXNzIiwiaXNzIjoidGVzc2VsbCIsImV4cCI6MTcwOTE4NDg1NywiaWF0IjoxNzA5MDk4NDYwLCJlbWFpbCI6InNvbnUudmVybWFAdGVzc2VsbC5jb20iLCJ0aWQiOiIwODY5ZjZkYS1jYTcyLTQyMmYtOWIzYy0wMTNmNzBjOWNmZTUifQ.IpRy2YP8PF4nVNRccVkPHBOtYh4bG8kAxoVdc93quO3iI9GcproG4xEJ5d9_LKXXuXdcP_za2JLqb2Ia_69QRi6q88RzXBr1l49eKSTR5TrT_lR2IzryOrMX3ACMkxesi-1beaRD9I4YmIcOcxE9lFb-9L-ppcyylOEJht9wt1z5qtuUdiRNUVpr43D-VOAHXgusqAy1LdUdH-jrEjnc9qjTZEaJapMqeivKTeGVU2axeDkdpzKD93pggBtLHMzK6L01tIxH4iElwouKnoUPttJ5-nJdPMae8sK0cCq1LLY8hMQzSkANqc42r570FrxkPmXqo89S4WRsLfa_xuVe8A",
"tenant-id": "0869f6da-ca72-422f-9b3c-013f70c9cfe5"
}
requests.packages.urllib3.disable_warnings()
response = requests.request("POST", url, data=data, headers=headers, verify=False)
print(response.status_code)
print(response.text)
Let's look into this in detail
-
Headers
-
tenant-id: You will get tenant-id while getting onboarded to Tessell.
-
Authorization: Guide to generate Authorization token
-
-
Request body:
-
"name": "your-service-name", "description": "description", "subscription": "default", // point b "edition": "COMMUNITY", // point c "engineType": "MYSQL", // point c "topology": "single_instance", // point d "softwareImage": "MySQL 8.0", // point b "softwareImageVersion": "MySQL 8.0.34 (RHEL)", // point b "autoMinorVersionUpdate": true, // true or false "enableDeletionProtection": false, // true or false "enableStopProtection": false, // true or false
- Subscription: You can get details of available subscriptions using API mentioned here: Returns details about the Tessell Subscriptions
- You can get Database software related information from here: Get a list of all software images. Using the name filter, a software image can be found using name.
topology
can be eithersingle_instance
orhigh_availability
-
infrastructure
"infrastructure": { "cloud": "aws", "region": "ap-south-1", "availabilityZone": "ap-south-1a", "vpc": "example_vpc", "computeType": "tesl_2_a", "enableEncryption": true, // either true or false "encryptionKey": "default-encryption-key", "additionalStorage": 0 }
cloud
can beaws
orazure
region
,computeType
: Get a list of Compute Profiles.vpc
: Get a list of VPCs- availabilityZone, encryptionKey: View a list of Available Compute Resources
-
Service Connectivity
-
"serviceConnectivity": { "servicePort": "3306", "enablePublicAccess": true, "allowedIpAddresses": [ "49.834.563.972" ], "enableSSL": false }
-
-
Credentials
-
"creds": { "masterUser": "myuser", "masterPassword": "MyPassword123" },
- Choose your own credentials
-
-
Maintenance Window
-
"maintenanceWindow": { "day": "Sunday", "time": "02:00", "duration": 30 },
day
: Day from the week, i.e. Sunday, Monday, Tuesday, Wednesday…time
: In the hh:mm format between 00:00 to 23:59.duration
: Minute required for maintenance window, should be in the multiple of 30, minimum is 30.
-
-
Snapshot Configuration
-
"snapshotConfiguration": { "sla": "DWMY", "schedule": { "backupStartTime": { "hour": 19, "minute": 30 }, "dailySchedule": { "backupsPerDay": 1 }, "weeklySchedule": { "days": [ "Sunday" ] }, "monthlySchedule": { "commonSchedule": { "dates": [ 1 ], "lastDayOfMonth": false } }, "yearlySchedule": { "commonSchedule": { "dates": [ 15 ], "months": [ "January" ], "lastDayOfMonth": false } } } }
sla
: Get a list of Availability Machine SLAsschedule
: schedule should be configured according to the chosensla
- note: if
sla
is not provided, then by default2-days-pits
SLA is chosen, and ifschedule
is not provided then by defaultbackupTime 1:00 AM
is considered. Ifsla
andschedule
does not match, then error is thrown.
-
-
Engine Configuration
-
"engineConfiguration": { "mysqlConfig": { "parameterProfileId": "abcdfe-0897-402a-bb0a-fghshgshs" } }
parameterProfileId
: You can get a list of available parameter profiles from Get a list of Available Parameter Profiles api and select parameter profile id based on the engine.
-
-
Databases
-
"databases": [ { "databaseName": "db1", "databaseConfiguration": { "mysqlConfig": { "parameterProfileId": "abcdfe-0897-402a-bb0a-fghshgshs" } } } ]
databaseName
: user definedparameterProfileId
: You can get a list of available parameter profiles from Get a list of Available Parameter Profiles api and select parameter profile id based on the engine.
-
-
Updated 8 months ago