You're viewing Apigee
and Apigee hybrid
documentation.
There is no equivalent Apigee Edge
documentation for this topic.
Symptom
An ApigeeIssue
with Reason
AIS_INGRESS_CERT_EXPIREY
is
shown when viewing resources in the apigee
namespace.
Error messages
After running kubectl -n apigee get apigeeissues
, an error like the following is
displayed:
NAME SEVERITY REASON DOCUMENTATION AGE ingress-cert-expired-my-org-my-virtualhost ERROR AIS_INGRESS_CERT_EXPIREY https://cloud.google.com/apigee/docs/hybrid/troubleshooting/AIS_INGRESS_CERT_EXPIREY 5h18m
Possible causes
| Cause | Description |
|---|---|
| Ingress certificate is expiring soon | The configured ingress certificate is expiring within 14 days. |
| Ingress certificate is expired | The configured ingress certificate is expired. |
Cause: Ingress certificate is expiring soon
The ingress certificate stored in the Kubernetes secret referenced by an ApigeeRouteConfig
is expiring within the next 14 days.
Diagnosis
Run the following command:
kubectl -n apigee describe apigeeissue ISSUE_NAME
Where ISSUE_NAME
is the name of the issue. For example, ingress-cert-expiring-soon-my-org-my-virtualhost
.
The output should look similar to the following:
Name : ingress - cert - expiring - soon - my - org - my - virtualhost Namespace : apigee Labels : ais - reason = AIS_INGRESS_CERT_EXPIREY Annotations : < none > API Version : apigee . cloud . google . com / v1alpha1 Kind : ApigeeIssue Metadata : Creation Timestamp : 2023 - 06 - 12 T17 : 03 : 43 Z Generation : 1 Owner References : API Version : apigee . cloud . google . com / v1alpha2 Kind : ApigeeOrganization Name : my - org UID : 7 e83a52c - ce00 - 4 bed - 98 be - 55835 ada1817 Resource Version : 3281563 UID : adc775c2 - 376d - 4 bf9 - 9860 - 500 b2b2b8273 Spec : Details : Ingress certificate in secret "my-org-my-virtualhost" for ApigeeRouteConfig "my-org-my-virtualhost" is expiring in 5.409373245 s at 2024 - 03 - 11 19 : 04 : 12 + 0000 UTC Documentation : https : // cloud . google . com / apigee / docs / hybrid / troubleshooting / AIS_INGRESS_CERT_EXPIREY Reason : AIS_INGRESS_CERT_EXPIREY Severity : WARNING Events : < none >
Spec : Details : Ingress certificate in secret "my-org-my-virtualhost" for ApigeeRouteConfig "my-org-my-virtualhost" is expiring in 5.409373245 s at 2024 - 03 - 11 19 : 04 : 12 + 0000 UTC
The contents of Spec.Details
explains the name of the ApigeeRouteConfig
that refers to the Kubernetes secret containing the ingress
certificate which is expiring soon.
Resolution
-
Use
kubectl describeto display the name of theApigeeRouteConfigwhich has the ingress cert which is expiring soon:kubectl -n apigee describe apigeeissue ISSUE_NAMEWhere ISSUE_NAME is the name of the issue. For example,
ingress-cert-expiring-soon-my-org-my-virtualhost.In this example, the
ApigeeRouteConfigmy-org-my-virtualhostis referencing the secretmy-org-my-virtualhost. -
Determine the
virtualhostname from theApigeeRouteConfig.The
ApigeeRouteConfig's name is in the format:<Apigee organization>-<virtualhost name>.In this example,
my-orgis the Apigee organization and the virtualhost name ismy-virtualhost. -
Find the corresponding virtualhost in your
overrides.yaml.virtualhosts: ... - name: my-virtualhost selector: app: apigee-ingressgateway sslCertPath: ./certs/vhost.pem sslKeyPath: ./certs/vhost.key ... -
Update the certificate and key listed in the
sslCertPathandsslKeyPathfiles. -
Apply the changes to the virtualhost:
helm upgrade ENV_GROUP_NAME apigee-virtualhost/ \ --namespace apigee \ --set envgroup= ENV_GROUP_NAME \ -f overrides.yaml
Cause: Ingress certificate is expired
The ingress certificate stored in the Kubernetes secret referenced by an ApigeeRouteConfig
has expired.
Diagnosis
Run the following command:
kubectl -n apigee describe apigeeissue ISSUE_NAME
Where ISSUE_NAME
is the name of the issue. For example, ingress-cert-expired-my-org-my-virtualhost
.
Something similar to the following is returned:
Name : ingress - cert - expired - my - org - my - virtualhost Namespace : apigee Labels : ais - reason = AIS_INGRESS_CERT_EXPIREY Annotations : < none > API Version : apigee . cloud . google . com / v1alpha1 Kind : ApigeeIssue Metadata : Creation Timestamp : 2023 - 06 - 12 T17 : 03 : 43 Z Generation : 1 Owner References : API Version : apigee . cloud . google . com / v1alpha2 Kind : ApigeeOrganization Name : my - org UID : 7 e83a52c - ce00 - 4 bed - 98 be - 55835 ada1817 Resource Version : 3281563 UID : adc775c2 - 376d - 4 bf9 - 9860 - 500 b2b2b8273 Spec : Details : Ingress certificate in secret "my-org-my-virtualhost" for ApigeeRouteConfig "my-org-my-virtualhost" expired at : 2024 - 03 - 11 19 : 12 : 10 + 0000 UTC Documentation : https : // cloud . google . com / apigee / docs / hybrid / troubleshooting / AIS_INGRESS_CERT_EXPIREY Reason : AIS_INGRESS_CERT_EXPIREY Severity : ERROR Events : < none >
Spec : Details : Ingress certificate in secret "my-org-my-virtualhost" for ApigeeRouteConfig "my-org-my-virtualhost" expired at : 2024 - 03 - 11 19 : 12 : 10 + 0000 UTC
The contents of Spec.Details
explains the name of the ApigeeRouteConfig
that refers to the Kubernetes secret containing the ingress
certificate which has expired.
Resolution
-
Use
kubectl describeto display the name of theApigeeRouteConfigwhich has the expired ingress cert:kubectl -n apigee describe apigeeissue ISSUE_NAMEWhere ISSUE_NAME is the name of the issue. For example,
ingress-cert-expired-my-org-my-virtualhost.In this example, the
ApigeeRouteConfigmy-org-my-virtualhostis referencing the secretmy-org-my-virtualhost. -
Determine the
virtualhostname from theApigeeRouteConfig.The
ApigeeRouteConfig's name is in the format:<Apigee organization>-<virtualhost name>.In this example,
my-orgis the Apigee organization and the virtualhost name ismy-virtualhost. -
Find the corresponding virtualhost in your
overrides.yaml.virtualhosts: ... - name: my-virtualhost selector: app: apigee-ingressgateway sslCertPath: ./certs/vhost.pem sslKeyPath: ./certs/vhost.key ... -
Update the certificate and key listed in the
sslCertPathandsslKeyPathfiles. -
Apply the changes to the virtualhost:
helm upgrade ENV_GROUP_NAME apigee-virtualhost/ \ --namespace apigee \ --set envgroup= ENV_GROUP_NAME \ -f overrides.yaml
Must gather diagnostic information
If the problem persists even after following the above instructions, gather the following diagnostic information and then contact Google Cloud Customer Care :
- The Google Cloud Project ID.
- The name of the Apigee hybrid organization.
- The
Spec.Detailsfield of theApigeeIssue. - (optional) Files referenced by
sslCertPathandsslKeyPathfor the affected virtualhost.

