本文整理汇总了Golang中github.com/vito/cloudformer.CloudFormer.LoadBalancer方法的典型用法代码示例。如果您正苦于以下问题:Golang CloudFormer.LoadBalancer方法的具体用法?Golang CloudFormer.LoadBalancer怎么用?Golang CloudFormer.LoadBalancer使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/vito/cloudformer.CloudFormer
的用法示例。
在下文中一共展示了CloudFormer.LoadBalancer方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: buildLoadBalancers
func (builder *Builder) buildLoadBalancers(former cloudformer.CloudFormer) error {
for _, x := range builder.spec.LoadBalancers {
balancer := former.LoadBalancer(x.Name)
for _, name := range x.Subnets {
subnet, found := builder.subnets[name]
if !found {
return fmt.Errorf("unknown subnet: %s", name)
}
balancer.Subnet(subnet)
}
for _, listener := range x.Listeners {
destinationPort := listener.Port
if listener.DestinationPort != nil {
destinationPort = *listener.DestinationPort
}
destinationProtocol := listener.Protocol
if listener.DestinationProtocol != nil {
destinationProtocol = *listener.DestinationProtocol
}
balancer.Listener(
cloudformer.ProtocolType(listener.Protocol),
listener.Port,
cloudformer.ProtocolType(destinationProtocol),
destinationPort,
listener.SSLCertificateId,
)
}
for _, name := range x.SecurityGroups {
securityGroup, found := builder.securityGroups[name]
if !found {
return fmt.Errorf("unknown security group: %s", name)
}
balancer.SecurityGroup(securityGroup)
}
balancer.HealthCheck(cloudformer.HealthCheck{
Protocol: cloudformer.ProtocolType(x.HealthCheck.Target.Protocol),
Port: x.HealthCheck.Target.Port,
Path: x.HealthCheck.Target.Path,
Interval: time.Duration(x.HealthCheck.Interval) * time.Second,
Timeout: time.Duration(x.HealthCheck.Timeout) * time.Second,
HealthyThreshold: x.HealthCheck.HealthyThreshold,
UnhealthyThreshold: x.HealthCheck.UnhealthyThreshold,
})
if x.DNSRecord != "" {
balancer.RecordSet(x.DNSRecord, builder.spec.Domain)
}
if x.Scheme != "" {
balancer.Scheme(x.Scheme)
}
balancer.CrossZone(x.CrossZone)
}
return nil
}
示例2: Form
func Form(f cloudformer.CloudFormer) {
zone1 := "us-east-1a"
vpc := f.VPC("Drone")
vpc.Network(cloudformer.CIDR("10.10.0.0/16"))
vpcGateway := f.InternetGateway("Drone")
vpc.AttachInternetGateway(vpcGateway)
openSecurityGroup := vpc.SecurityGroup("Open")
boshSecurityGroup := vpc.SecurityGroup("BOSH")
internalSecurityGroup := vpc.SecurityGroup("Internal")
webSecurityGroup := vpc.SecurityGroup("Web")
for _, group := range []cloudformer.SecurityGroup{
openSecurityGroup,
boshSecurityGroup,
internalSecurityGroup,
} {
group.Ingress(cloudformer.TCP, cloudformer.CIDR("0.0.0.0/0"), 0, 65535)
group.Ingress(cloudformer.UDP, cloudformer.CIDR("0.0.0.0/0"), 0, 65535)
}
webSecurityGroup.Ingress(cloudformer.TCP, cloudformer.CIDR("0.0.0.0/0"), 80, 80)
webSecurityGroup.Ingress(cloudformer.TCP, cloudformer.CIDR("0.0.0.0/0"), 8080, 8080)
boshSubnet := vpc.Subnet("BOSH")
boshSubnet.Network(cloudformer.CIDR("10.10.0.0/24"))
boshSubnet.AvailabilityZone(zone1)
boshSubnet.RouteTable().InternetGateway(vpcGateway)
droneELBSubnet := vpc.Subnet("DroneELB")
droneELBSubnet.Network(cloudformer.CIDR("10.10.2.0/24"))
droneELBSubnet.AvailabilityZone(zone1)
droneELBSubnet.RouteTable().InternetGateway(vpcGateway)
droneSubnet := vpc.Subnet("Drone")
droneSubnet.Network(cloudformer.CIDR("10.10.16.0/20"))
droneSubnet.AvailabilityZone(zone1)
boshNAT := boshSubnet.Instance("NAT")
boshNAT.Type("m1.small")
boshNAT.Image("ami-something")
boshNAT.PrivateIP(cloudformer.IP("10.10.0.10"))
boshNAT.KeyPair("bosh")
boshNAT.SecurityGroup(openSecurityGroup)
droneSubnet.RouteTable().Instance(boshNAT)
balancer := f.LoadBalancer("Drone")
balancer.Listener(cloudformer.TCP, 80, cloudformer.TCP, 80, "")
balancer.Listener(cloudformer.TCP, 8080, cloudformer.TCP, 8080, "")
balancer.HealthCheck(cloudformer.HealthCheck{
Protocol: cloudformer.TCP,
Port: 80,
Timeout: 5 * time.Second,
Interval: 30 * time.Second,
HealthyThreshold: 10,
UnhealthyThreshold: 2,
})
balancer.Subnet(droneELBSubnet)
balancer.SecurityGroup(webSecurityGroup)
}