Deployment
Provisioning
Deploying the full application requires cloud backing services from Oracle Cloud Infrastructure. Provisioning these services may be done manually of course, but can also be done automatically through the use of OCI Service Broker. You are encouraged to explore each approach.
In all cases, begin by adding tenancy credentials to manage and connect services from within the cluster. Create a secret containing these values:
kubectl create secret generic oci-credentials \
  --namespace mushop \
  --from-literal=tenancy=<TENANCY_OCID> \
  --from-literal=user=<USER_OCID> \
  --from-literal=region=<USER_OCI_REGION> \
  --from-literal=fingerprint=<PUBLIC_API_KEY_FINGERPRINT> \
  --from-literal=passphrase=<PRIVATE_API_KEY_PASSPHRASE> \
  --from-file=privatekey=<PATH_OF_PRIVATE_API_KEY>
NOTE: The passphrase entry is required. If you do not have passphrase for your key, just leave empty.
| Manual | Automated | 
|---|---|
| Provides steps for provisioning and connecting cloud services to the application | Uses OCI Service Broker to provision and connect the Autonomous Transaction Processing database | 
- 
Follow the steps outlined below to provision and configure the cluster with cloud service connection details. ATP Database- 
Provision an Autonomous Transaction Processing (ATP) database. The default options will work well, as will an Always Free shape if available. Once RUNNING download the DB Connection Wallet and configure secrets as follows: - 
Create oadb-adminsecret containing the database administrator password. Used once for schema initializations.kubectl create secret generic oadb-admin \ --namespace mushop \ --from-literal=oadb_admin_pw='<DB_ADMIN_PASSWORD>'
- 
Create oadb-walletsecret with the Wallet contents using the downloadedWallet_*.zip. The extractedWallet_*directory is specified as the secret file path. Each file will become a key name in the secret data.kubectl create secret generic oadb-wallet \ --namespace mushop \ --from-file=<PATH_TO_EXTRACTED_WALLET_FOLDER>
- 
Create oadb-connectionsecret with the Wallet password and the service TNS name to use for connections.kubectl create secret generic oadb-connection \ --namespace mushop \ --from-literal=oadb_wallet_pw='<DB_WALLET_PASSWORD>' \ --from-literal=oadb_service='<DB_TNS_NAME>'Each database has 5 unique TNS Names displayed when the Wallet is downloaded. For a database named mushopdban example would bemushopdb_TP.
 
- 
- 
Optional: Instead of creating a shared database for the entire application, you may establish full separation of services by provisioning individual ATP instances for each service that requires a database. To do so, repeat the previous steps for each database,and give each secret a unique name, for example: carts-oadb-admin,carts-oadb-connection,carts-oadb-wallet.- carts
- catalogue
- orders
- user
 
 Streaming Service- 
Provision a Streaming instance from the Oracle Cloud Infrastructure Console, and make note of the created Stream OCIDvalue. Then create anoss-connectionsecret containing the Stream connection details.kubectl create secret generic oss-connection \ --namespace mushop \ --from-literal=streamId='<STREAM_OCID>' \ --from-literal=messageEndpoint='<MESSAGE_ENDPOINT_URL>'
 Object Storage- 
Optional: Provision a Public Object Storage Bucket, and create a Pre-Authenticated Request for the bucket. With the information, create a secret called oos-bucketas follows:kubectl create secret generic oos-bucket \ --namespace mushop \ --from-literal=region=<BUCKET_REGION> \ --from-literal=name=<BUCKET_NAME> \ --from-literal=namespace=<OBJECT_STORAGE_NAMESPACE> \ --from-literal=parUrl=<PRE_AUTHENTICATED_REQUEST_URL>Object Storage Namespace may be found with the CLI oci os ns getor from the tenancy information page
 Verify- 
Verify the secrets are created and available in the mushopnamespace:kubectl get secret --namespace mushopNAME TYPE DATA AGE oadb-admin Opaque 1 3m oadb-connection Opaque 2 3m oadb-wallet Opaque 7 3m oci-credentials Opaque 6 3m oos-bucket Opaque 4 3m oss-connection Opaque 2 3m
 
- 
- 
As an alternative to manually provisioning, the included provisionchart is an application of the open-source OCI Service Broker for provisioning Oracle Cloud Infrastructure services. This implementation utilizes Open Service Broker in Oracle Container Engine for Kubernetes or in other Kubernetes clusters.Note: The OCI Service Broker depends on the Service Catalog, so make sure that you run the setup chart with the catalog.enabled=true.cd deploy/complete/helm-chartdir deploy/complete/helm-chart- 
The Service Broker for Kubernetes requires access credentials to provision and manage services from within the cluster. Create a secret containing these values as described above. Alternatively, copy the oci-credentialssecret to themushop-utilitiesnamespace:kubectl get secret oci-credentials \ --namespace=mushop \ --export \ -o yaml | kubectl apply \ --namespace=mushop-utilities -f -
- 
Deploy the OCI service broker on your cluster. This is done with the Oracle OCI Service Broker helm chart: helm install \ https://github.com/oracle/oci-service-broker/releases/download/v1.6.0/oci-service-broker-1.6.0.tgz \ --namespace mushop-utilities \ --name oci-broker \ --set ociCredentials.secretName=oci-credentials \ --set storage.etcd.useEmbedded=true \ --set tls.enabled=falsehelm install oci-broker \ https://github.com/oracle/oci-service-broker/releases/download/v1.6.0/oci-service-broker-1.6.0.tgz \ --namespace mushop-utilities \ --set ociCredentials.secretName=oci-credentials \ --set storage.etcd.useEmbedded=true \ --set tls.enabled=falseThe above command will deploy the OCI Service Broker using an embedded etcd instance. It is not recommended to deploy the OCI Service Broker using an embedded etcd instance and tls disabled in production environments, instead a separate etcd cluster should be setup and used by the OCI Service Broker. Note: For the mushop helmdeployment, the OCI Service Broker MUST be installed on the same namespace used by thesetupchart. For convenience, the documentation commands defaults both thesetupand OCI Service Broker charts to use themushop-utilitiesnamespace.
- 
Next utilize the OCI Service Broker implementation to provision services by installing the included provisionchart:helm install provision \ --namespace mushop \ --name mushop-provision \ --set global.osb.compartmentId=<COMPARTMENT_ID> \ --set global.osb.objectstoragenamespace=<OBJECT_STORAGE_NAMESPACE>helm install mushop-provision provision \ --namespace mushop \ --set global.osb.compartmentId=<COMPARTMENT_ID> \ --set global.osb.objectstoragenamespace=<OBJECT_STORAGE_NAMESPACE>Object Storage Namespace may be found with the CLI oci os ns getor from the tenancy information page
- 
It will take a few minutes for the services database to provision, and the respective bindings to become available. Verify serviceinstancesandservicebindingsare READY:kubectl get serviceinstances -ANAME CLASS PLAN STATUS AGE mushop-atp ClusterServiceClass/atp-service standard Ready 1d mushop-objectstorage ClusterServiceClass/object-store-service standard Ready 1d mushop-oss ClusterServiceClass/oss-service standard Ready 1dkubectl get servicebindings -ANAME SERVICE-INSTANCE SECRET-NAME STATUS AGE mushop-bucket-par-binding mushop-objectstorage mushop-bucket-par-binding Ready 1d mushop-oadb-wallet-binding mushop-atp mushop-oadb-wallet-binding Ready 1d mushop-oss-binding mushop-oss mushop-oss-binding Ready 1d
 
- 
API Gateway, OCI Functions and Email Delivery
Configure Email Delivery
If you are planning to use the API gateway and Oracle Functions, to send emails using OCI Email Delivery you need to configure an approved sender first.
- From the OCI console, click Email Delivery -> Email Approved Sender
- Click the Create Approved Sender
- Enter the email address, for example: mushop@example.com
- Click Create Approved Sender
Note: if you have your own domain, you can enter a different address (e.g.
mushop@[yourdomain.com]) and also configure SPF record for the sender. This involves adding a DNS record to your domain. You can follow these instructions to set up SPF.
Next, you need to generate the SMTP credentials that will allow you to log in to the SMTP server and send the email. Follow the Generate SMTP Credentails for a User to get the SMTP host, port, username and password.
The SMTP credentails (host, port, username and password) and the approved sender email address (e.g. mushop@example.com) will be provided to the function as configuration values later, so make sure you save these values somewhere.
Configure function application
Each function needs to live inside of an application. You can create a new application either through the console, API or the Fn CLI. An application has a name (e.g. mushop-app) and the VCN and a subnet in which to run the functions. The one guideline here is to pick the subnets that are in the same region as the Docker registry you specified in your context YAML earlier - check these docs for more information.
The first step you need to do is to ensure your tenancy is configured for function development. You can follow the Configuring Your Tenancy for Function Development documentation.
As a next step you will need to install the Fn CLI. If on a Mac and you’re using Brew, you can run:
brew install fn
Finally, you will need configure the Fn CLI - you can follow these instructions that will guide you through creating a context file and configuring it with an image registry.
To create an application using Fn CLI, run:
 fn create app [APP_NAME] --annotation oracle.com/oci/subnetIds='["ocid1.subnet.oc1.iad...."]'
Note: make sure you replace
APP_NAMEand theocid1.subnetwith actual values
Deploy and configure the function
To deploy a function to an app, you can run the following command within the function folder (/src/functions/newsletter-subscription):
fn deploy --app [APP_NAME]
Note: use
fn -v deploy --app [APP_NAME]to get verbose output in case you’re running into issues.
In the remainder of the document, we will use mushop-app for the application name.
You need to provide additional configuration (SMTP credentails) for the function to work properly and be able to send emails.
Once you’ve successfully deployed the function, you can use the Fn CLI to add configuration values (note that you can also do the same through the Console UI).
Run the following commands to configure SMTP settings and the approved sender (replace the values):
fn config function mushop-app newsletter-subscription SMTP_USER <smtp_username>
fn config function mushop-app newsletter-subscription SMTP_PASSWORD <smtp_password>
fn config function mushop-app newsletter-subscription SMTP_HOST <smtp_host>
fn config function mushop-app newsletter-subscription SMTP_PORT <smtp_port>
fn config function mushop-app newsletter-subscription APPROVED_SENDER_EMAIL <approved_sender_email>
Creating an API gateway
You will be using an API Gateway to access the functions. To prepare your tenancy for using the gateway, check the Preparing for API Gateway documentation.
The quickest way to create a gateway is through the OCI console:
- Click Developer Services -> API Gateway from the sidebar on the left
- Click the Create Gateway button
- Enter the following values (you can use a different name if you’d like):
- Name: mushop-gateway
- Type: Public
- Virtual Cloud Network: Pick one from the dropdown
- Subnet: Pick the subnet from the dropdown
 
- Click Create
- When gateway is created, click the Deployments link from the sidebar on the left
- Under the Deployments, click the Create Deployment button
- Make sure From Scratch option is selected at the top and enter the following values (you can leave the other values as they are - i.e. no need to enable CORS, Authentication or Rate Limiting):
- Name: newsletter-subscription
- Path prefix: /newsletter
- Compartment: < Pick your compartment >
- Execution log: Enabled
- Log level: Error
 
- Click Next to define the route
- Enter the following values for Route 1:
- Path: /subscribe
- Methods: POST
- Type: Oracle Functions
- Application: mushop-app (or other, if you used a different name)
- Function name: newsletter-subscription
 
- Click the Show Route Logging Policies link and enable Execution Log
- Click Next and review the deployment
- Click Create to create the gateway deployment
When deployment completes, navigate to it to get the URL for the gateway. Click the Show link next to the Endpoint label to reveal the full URL for the deployment. It should look like this:
https://aaaaaaaaa.apigateway.us-ashburn-1.oci.customer-oci.com/newsletter/subscribe
You will use this URL in values-dev.yaml when creating the deployment.
Deployment
Having completed the provisioning steps above, the mushop deployment
helm chart is installed using settings to leverage cloud backing services.
Configuration
- 
Make a copy of the values-dev.yamlfile and store somewhere on your machine asmyvalues.yaml. Then complete the missing values (e.g. secret names) like the following:global: ociAuthSecret: oci-credentials # OCI authentication credentials secret ossStreamSecret: oss-connection # Name of Stream connection secret oadbAdminSecret: oadb-admin # Name of DB Admin secret oadbWalletSecret: oadb-wallet # Name of Wallet secret oadbConnectionSecret: oadb-connection # Name of DB Connection secret oosBucketSecret: oos-bucket # Object storage bucket secret name (optional)NOTE: If it’s desired to connect a separate databases for a given service, you can specify values specific for each service, such as carts.oadbAdminSecret,carts.oadbWalletSecret…
- 
Optional: If an Object Storage bucket is provisioned, you can configure the apienvironment to use the object URL prefix inmyvalues.yaml:api: env: mediaUrl: # https://objectstorage.[REGION].oraclecloud.com/n/[NAMESPACE]/b/[BUCKET_NAME]/o/
- 
Optional: If you configured the Email Delivery, API gateway and the function, add the following snippet to your myvalues.yamlfile:api: env: mediaUrl: # ... newsletterSubscribeUrl: https://[API_GATEWAY_URL]
Installation
- 
Install the mushopapplication helm chart using themyvalues.yamlcreated above:- 
OPTION 1: With cloud services provisioned manually: helm install ./mushop \ --name mushop \ --namespace mushop \ --values myvalues.yamlhelm upgrade --install mushop ./mushop \ --namespace mushop \ --create-namespace \ --values myvalues.yaml
- 
OPTION 2: When using OCI Service Broker ( provisionchart):helm install ./mushop \ --name mushop \ --namespace mushop \ --set global.osb.atp=true \ --set global.osb.oss=true \ --set global.osb.objectstorage=true \ --values myvalues.yamlhelm install mushop ./mushop \ --namespace mushop \ --set global.osb.atp=true \ --set global.osb.oss=true \ --set global.osb.objectstorage=true \ --values myvalues.yaml
 
- 
- 
Wait for deployment pods to be RUNNING and init pods to show COMPLETED: kubectl get pods --namespace mushop --watchNAME READY STATUS RESTARTS AGE mushop-api-769c4d9fd8-hp7mc 1/1 Running 0 31s mushop-assets-dd5756599-pxngg 1/1 Running 0 33s mushop-assets-deploy-1-n2bk6 0/1 Completed 0 33s mushop-carts-6f5db9565f-4w65t 1/1 Running 0 33s mushop-carts-init-1-dcs82 0/1 Completed 0 33s mushop-catalogue-76977479fd-thdq4 1/1 Running 0 32s mushop-catalogue-init-1-twx9x 0/1 Completed 0 33s mushop-edge-648c989cd4-6g9dk 1/1 Running 0 32s mushop-events-569f4744c9-l7pqt 1/1 Running 0 30s mushop-fulfillment-85489cd99b-lzwqp 1/1 Running 0 30s mushop-nats-84dc5db659-7rpbl 1/1 Running 0 32s mushop-orders-6dcc7bbbb6-658tq 1/1 Running 0 33s mushop-orders-init-1-tm8ls 0/1 Completed 0 33s mushop-payment-c7dccd8cc-t9wmj 1/1 Running 0 33s mushop-session-5ff4c9557f-dmbq8 1/1 Running 0 33s mushop-storefront-8656597656-lgdlk 1/1 Running 0 33s mushop-user-54f4978d68-qhr7n 0/1 Running 0 31s mushop-user-init-1-8k62c 0/1 Completed 0 33sNote: if you installed Istio service mesh, you should see 2/2in theREADYcolumn and1/2for the init pods and the assets deploy pod. The reason you see2/2is because Istio injects a sidecar proxy container into each pod.
- 
Open a browser with the EXTERNAL-IPcreated during setup, ORport-forwarddirectly to theedgeservice resource:kubectl port-forward \ --namespace mushop \ svc/edge 8000:80Using port-forwardconnecting localhost:8000 to theedgeservicekubectl get svc mushop-utils-ingress-nginx-controller \ --namespace mushop-utilitiesLocating EXTERNAL-IPfor Ingress Controller. NOTE this will be localhost on local clusters.kubectl get svc istio-ingressgateway \ --namespace istio-systemLocating EXTERNAL-IPfor Istio Ingress Gateway. NOTE this will be localhost on local clusters.