diff --git a/docs/data-sources/lb_certificate.md b/docs/data-sources/lb_certificate.md
new file mode 100644
index 00000000..0fd1ab16
--- /dev/null
+++ b/docs/data-sources/lb_certificate.md
@@ -0,0 +1,46 @@
+---
+subcategory: "Elastic Load Balance (ELB)"
+---
+
+# flexibleengine_lb_certificate
+
+Use this data source to get the certificates in FlexibleEngine Elastic Load Balance (ELB).
+
+## Example Usage
+
+```hcl
+variable "certificate_name" {}
+
+data "flexibleengine_lb_certificate" "test" {
+ name = var.certificate_name
+ type = "server"
+}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String) The region in which to obtain the ELB certificate. If omitted, the provider-level region
+ will be used.
+
+* `type` - (Optional, String) Specifies the certificate type. The default value is `server`. The value can be one of the
+ following:
+ + `server`: indicates the server certificate.
+ + `client`: indicates the CA certificate.
+
+* `name` - (Required, String) The name of certificate. The value is case sensitive and does not supports fuzzy matching.
+
+ -> **NOTE:** The certificate name is not unique. Only returns the last created one when matched multiple certificates.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The certificate ID in UUID format.
+
+* `domain` - The domain of the Certificate. This parameter is valid only when `type` is "server".
+
+* `description` - Human-readable description for the Certificate.
+
+* `expiration` - Indicates the time when the certificate expires.
diff --git a/docs/data-sources/lb_listeners.md b/docs/data-sources/lb_listeners.md
new file mode 100644
index 00000000..7a37cec6
--- /dev/null
+++ b/docs/data-sources/lb_listeners.md
@@ -0,0 +1,72 @@
+---
+subcategory: "Elastic Load Balance (ELB)"
+---
+
+# flexibleengine_lb_listeners
+
+Use this data source to query the list of ELB listeners.
+
+## Example Usage
+
+```
+variable "protocol" {}
+
+data "flexibleengine_lb_listeners" "test" {
+ protocol = var.protocol
+}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String) Specifies the region in which to query the data source.
+ If omitted, the provider-level region will be used.
+
+* `name` - (Optional, String) The listener name.
+
+* `protocol` - (Optional, String) The listener protocol.
+ The valid values are **TCP**, **UDP**, **HTTP** and **TERMINATED_HTTPS**.
+
+* `protocol_port` - (Optional, String) The front-end listening port of the listener.
+ The valid value is range from `1` to `65535`.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The resource ID.
+
+* `listeners` - Listener list.
+The [object](#listeners_listeners) structure is documented below.
+
+
+The `listeners` block supports:
+
+* `id` - The ELB listener ID.
+
+* `name` - The listener name.
+
+* `protocol` - The listener protocol.
+
+* `protocol_port` - The front-end listening port of the listener.
+
+* `default_pool_id` - The ID of the default pool with which the ELB listener is associated.
+
+* `description` - The description of the ELB listener.
+
+* `connection_limit` - The maximum number of connections allowed for the listener.
+
+* `http2_enable` - Whether the ELB listener uses HTTP/2.
+
+* `default_tls_container_ref` - The ID of the server certificate used by the listener.
+
+* `sni_container_refs` - List of the SNI certificate (server certificates with a domain name) IDs used by the listener.
+
+* `loadbalancers` - Listener list.
+The [object](#listeners_loadbalancers) structure is documented below.
+
+
+The `loadbalancers` block supports:
+
+* `id` - The ELB loadbalancer ID.
diff --git a/docs/resources/elb_logtank.md b/docs/resources/elb_logtank.md
new file mode 100644
index 00000000..4835130e
--- /dev/null
+++ b/docs/resources/elb_logtank.md
@@ -0,0 +1,49 @@
+---
+subcategory: "Dedicated Load Balance (Dedicated ELB)"
+---
+
+# flexibleengine_elb_logtank
+
+Manage an ELB logtank resource within FlexibleEngine.
+
+## Example Usage
+
+```hcl
+variable "loadbalancer_id" {}
+variable "group_id" {}
+variable "topic_id" {}
+
+resource "flexibleengine_elb_logtank" "test" {
+ loadbalancer_id = var.loadbalancer_id
+ log_group_id = var.group_id
+ log_topic_id = var.topic_id
+}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String, ForceNew) The region in which to create the logtank resource.
+ If omitted, the provider-level region will be used. Changing this creates a new logtank.
+
+* `loadbalancer_id` - (Required, String, ForceNew) Specifies the ID of a loadbalancer. Changing this
+ creates a new logtank
+
+* `log_group_id` - (Required, String) Specifies the ID of a log group. It is provided by other service.
+
+* `log_topic_id` - (Required, String) Specifies the ID of the subscribe topic.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The logtank ID.
+
+## Import
+
+ELB logtank can be imported using the logtank ID, e.g.
+
+```
+$ terraform import flexibleengine_elb_logtank.test 2f148a75-acd3-4ce7-8f63-d5c9fadab3a0
+```
diff --git a/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_test.go b/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_test.go
new file mode 100644
index 00000000..fb6a3051
--- /dev/null
+++ b/flexibleengine/acceptance/data_source_flexibleengine_lb_certificate_test.go
@@ -0,0 +1,108 @@
+/*
+ Copyright (c) Huawei Technologies Co., Ltd. 2021. All rights reserved.
+*/
+
+package acceptance
+
+import (
+ "fmt"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/acctest"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/services/acceptance"
+)
+
+func TestAccDataSourceLBCertificateV2_basic(t *testing.T) {
+ name := fmt.Sprintf("cert-%s", acctest.RandString(6))
+ dataSourceName := "data.flexibleengine_lb_certificate_v2.cert_1"
+ dc := acceptance.InitDataSourceCheck(dataSourceName)
+
+ resource.Test(t, resource.TestCase{
+ PreCheck: func() { testAccPreCheck(t) },
+ ProviderFactories: TestAccProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ Config: testAccLBCertificateSourceV2_conf(name),
+ Check: resource.ComposeTestCheckFunc(
+ dc.CheckResourceExists(),
+ resource.TestCheckResourceAttr(dataSourceName, "name", name),
+ resource.TestCheckResourceAttr(dataSourceName, "type", "server"),
+ resource.TestCheckResourceAttrSet(dataSourceName, "domain"),
+ resource.TestCheckResourceAttrSet(dataSourceName, "description"),
+ ),
+ },
+ },
+ })
+}
+
+func testAccLBCertificateSourceV2_conf(name string) string {
+ return fmt.Sprintf(`
+data "flexibleengine_lb_certificate_v2" "cert_1" {
+ name = flexibleengine_elb_certificate.certificate_1.name
+
+ depends_on = [flexibleengine_elb_certificate.certificate_1]
+}
+
+resource "flexibleengine_elb_certificate" "certificate_1" {
+ name = "%s"
+ description = "terraform test certificate"
+ domain = "www.elb.com"
+ type = "server"
+ private_key = <