Read Write Splitting Connection Args
data class ReadWriteSplittingConnectionArgs(val connectionPrefix: Output<String>? = null, val distributionType: Output<String>? = null, val instanceId: Output<String>? = null, val maxDelayTime: Output<Int>? = null, val port: Output<Int>? = null, val weight: Output<Map<String, Any>>? = null) : ConvertibleToJava<ReadWriteSplittingConnectionArgs>
Provides an RDS read write splitting connection resource to allocate an Intranet connection string for RDS instance.
Example Usage
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.alicloud.AlicloudFunctions;
import com.pulumi.alicloud.inputs.GetZonesArgs;
import com.pulumi.alicloud.vpc.Network;
import com.pulumi.alicloud.vpc.NetworkArgs;
import com.pulumi.alicloud.vpc.Switch;
import com.pulumi.alicloud.vpc.SwitchArgs;
import com.pulumi.alicloud.rds.Instance;
import com.pulumi.alicloud.rds.InstanceArgs;
import com.pulumi.alicloud.rds.ReadOnlyInstance;
import com.pulumi.alicloud.rds.ReadOnlyInstanceArgs;
import com.pulumi.alicloud.rds.ReadWriteSplittingConnection;
import com.pulumi.alicloud.rds.ReadWriteSplittingConnectionArgs;
import com.pulumi.resources.CustomResourceOptions;
import java.util.List;
import java.util.ArrayList;
import java.util.Map;
import java.io.File;
import java.nio.file.Files;
import java.nio.file.Paths;
public class App {
public static void main(String[] args) {
Pulumi.run(App::stack);
}
public static void stack(Context ctx) {
final var config = ctx.config();
final var creation = config.get("creation").orElse("Rds");
final var name = config.get("name").orElse("dbInstancevpc");
final var defaultZones = AlicloudFunctions.getZones(GetZonesArgs.builder()
.availableResourceCreation(creation)
.build());
var defaultNetwork = new Network("defaultNetwork", NetworkArgs.builder()
.vpcName(name)
.cidrBlock("172.16.0.0/16")
.build());
var defaultSwitch = new Switch("defaultSwitch", SwitchArgs.builder()
.vpcId(defaultNetwork.id())
.cidrBlock("172.16.0.0/24")
.zoneId(defaultZones.applyValue(getZonesResult -> getZonesResult.zones()[0].id()))
.vswitchName(name)
.build());
var defaultInstance = new Instance("defaultInstance", InstanceArgs.builder()
.engine("MySQL")
.engineVersion("5.6")
.instanceType("rds.mysql.t1.small")
.instanceStorage("20")
.instanceChargeType("Postpaid")
.instanceName(name)
.vswitchId(defaultSwitch.id())
.securityIps(
"10.168.1.12",
"100.69.7.112")
.build());
var defaultReadOnlyInstance = new ReadOnlyInstance("defaultReadOnlyInstance", ReadOnlyInstanceArgs.builder()
.masterDbInstanceId(defaultInstance.id())
.zoneId(defaultInstance.zoneId())
.engineVersion(defaultInstance.engineVersion())
.instanceType(defaultInstance.instanceType())
.instanceStorage("30")
.instanceName(String.format("%sro", name))
.vswitchId(defaultSwitch.id())
.build());
var defaultReadWriteSplittingConnection = new ReadWriteSplittingConnection("defaultReadWriteSplittingConnection", ReadWriteSplittingConnectionArgs.builder()
.instanceId(defaultInstance.id())
.connectionPrefix("t-con-123")
.distributionType("Standard")
.build(), CustomResourceOptions.builder()
.dependsOn(defaultReadOnlyInstance)
.build());
}
}
Content copied to clipboard
Import
RDS read write splitting connection can be imported using the id, e.g.
$ pulumi import alicloud:rds/readWriteSplittingConnection:ReadWriteSplittingConnection example abc12345678
Content copied to clipboard