OpenShift Service Mesh (Istio)
Introduction
Deployed projects designed and implemented with IBM Industry Solutions Workbench now support OpenShift Service Mesh (Istio). Istio makes it easy to create a network of deployed services with load balancing, service-to-service authentication, monitoring, and more, with few or no code changes in service code. Having Istio enabled the services can communicate secured by mutualTLS.
Prerequisites
OpenShift Service Mesh (version 2.0.2 and above)
Enable OpenShift Service Mesh
The enablement of OpenShift Service Mesh can be set during the creation of a k5-project. The variation in setting up additional steps are described below.
Create an OpenShift project (see Creating new Deployment Targets)
Assign Permissions
Create
service mesh member roll
for the new k5-projectSwitch to
istio-system
project: Home > Projects > istio-systemNavigate to: Operators > Installed Operators > Red Hat OpenShift Service Mesh > Istio Service Mesh Member Roll
Replace
your-project
with the created OpenShift project/s as described below
apiVersion: maistra.io/v1 kind: ServiceMeshMemberRoll metadata: name: default namespace: openshift-operators spec: members: - your-project - another-of-your-projects
Create an instance of the custom resource k5-project
istio: enabled: true strictMtls: true
Attention: While creating a new k5-project using CRD, enable Istio (required) and strictMtls (optional). But we recommend enabling strictMtls mode for security reasons.
Update certificates for Istio Service Mesh
You can either update the certificates manually or use the Cert Manager. See descriptions below.
Using manual way
You need to have certificates for Istio. then using below the command you can apply those certificates:
oc create secret tls istio-ingressgateway-certs --key tls.key --cert tls.crt -n istio-system
Using Cert Manager
Prerequisites:
Cert Manager should be installed and configured
Login to OpenShift Admin Console
Navigate to: Administration > Custom Resource Definitions
Search and select Certificate CRD
Navigate to: Instances
Click on Create Certificate
Use following sample as template and save CRD
Sample Certificate CRD instance
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: <Some-Name>
namespace: istio-system
spec:
dnsNames:
- <k5-project-name>.<your suffix URL>
issuerRef:
kind: ClusterIssuer
name: letsencrypt-clusterissuer-prod
secretName: istio-ingressgateway-certs
Verification:
Select
istio-system
projectNavigate to: Workloads > Secrets
Search and select the secret
istio-ingressgateway-certs
Check for
tls.crt
andtls.key
istio-ingressgateway-<suffix>
from istio-system
namespace