 Before You Begin
Before You Begin
              This 45-minute tutorial shows you how to create a stack using Oracle Cloud Infrastructure Container Engine for Kubernetes, Marketplace and Resource Manager, and how to create a domain using the Jenkins CI/CD pipleine job.
Background
Oracle WebLogic Server for Oracle Cloud Infrastructure Container Engine for Kubernetes (OKE) is available as a set of applications in the Oracle Cloud Infrastructure Marketplace. You use an Oracle WebLogic Server for OKE to create a stack with the WebLogic administration server running in different pods in Kubernetes cluster. The application also provisions a private load balancer to provide access to the WebLogic Server administration console and the Jenkins console. Marketplace uses Resource Manager to provision the network, compute instances, load balancers, and Kubernetes components as a single unit called a stack.
Oracle Cloud Infrastructure Marketplace offers separate applications for:
- Oracle WebLogic Server Enterprise Edition
- Oracle WebLogic Suite
This tutorial uses Oracle WebLogic Server for OKE resource manager to create a virtual cloud network (VCN) and subnets in Oracle Cloud Infrastructure to support WebLogic Server, Kubernetes, and the load balancers. But you can also use an existing VCN and existing subnets if desired. Note that Oracle WebLogic Server for OKE creates administration host compute instance, public subnets for the load balancers and the bastion compute instance, and private subnets for the Kubernetes components and file storage. We recommend you follow the same architecture when using existing subnets.
This tutorial uses the Jenkins job to create a WebLogic domain that does not require a database. The job also creates a public load balancer to distribute traffic across the managed servers in your domain.
Provisioning a stack in Oracle WebLogic Server for OKE requires a secret in Oracle Cloud Infrastructure Vault. This secret contains the auth token to access the Oracle Cloud Infrastructure Registry. This tutorial uses a standard vault, which is hosted on a hardware security module (HSM) partition with multiple tenants, and uses a more cost-efficient, key-based metric for billing purposes. A virtual private vault provides greater isolation and performance by allocating a dedicated partition on an HSM. Each type of vault has a separate service limit in your Oracle Cloud Infrastructure tenancy. The limit for secrets spans all vaults. See Service Limits and Oracle Cloud Infrastructure Vault FAQ.
You can estimate the cost of the resources and services that you want to use to provision your instance. See Oracle Cloud Cost Estimator.
What Do You Need?
- Your Oracle Cloud Infrastructure authentication token. See Managing User Credentials.
- An Oracle Cloud Infrastructure compartment. See Managing Compartments.
- An SSH public key and corresponding private key.
- Service limits for the components in your tenancy. See Service Requirements.
 Create
                a Vault
Create
                a Vault
              - Sign in to the Oracle Cloud Infrastructure console.
- Click the navigation menu  , select Identity & Security,
                  and then click Vault. , select Identity & Security,
                  and then click Vault.
- Select your Compartment, if not already selected.
- Click Create Vault.
- Enter WebLogicOKEVaultin the Name field.
- Click Create.
                  Wait for the vault to be created. 
 Create
                Secrets for Registry User
Create
                Secrets for Registry User
              - In the vault, click the vault name.
- Click Secrets, and then click Create Secret.
- Enter TokenSecretin the Name field.
- For Secret Contents, enter your authentication token.
- Click Create Secret.
                  Wait for the secret to be created. 
- Click the secret name.
- Copy the OCID of the secret for the authentication token associated with your Oracle Cloud Infrastructure user name.
 Create
                the Stack
Create
                the Stack
              - Click the navigation menu  , select Marketplace and
                  click All Applications. , select Marketplace and
                  click All Applications.
- Click one of the following Oracle WebLogic applications:
                  - Oracle WebLogic Server Enterprise Edition for OKE BYOL
- Oracle WebLogic Server Enterprise Edition 
                        for OKE UCM
 
- Oracle WebLogic Suite for OKE BYOL
- Oracle WebLogic Suite for OKE UCM
 
 
- Select the Oracle WebLogic Server for OKE release version from the list.
- Select the Compartment in which to create the stack.
- Select the Oracle Standard Terms and Restrictions
                  check box, and then click Launch Stack.
                  The Create Stack page displays. 
- Enter mylwlsokestackin the Name field.
- Click Next.
                  The Configure Variables page displays. 
- Enter mywlsokein the Resource Name Prefix field.You must use lowercase characters for the resource name prefix. 
- For SSH Public Key, browse to select the
                  SSH public key file and upload the file, or paste the contents
                  of the SSH public key file.
                  After creating the stack, you can connect to the administration instance and the virtual machines (VMs) of the non-WebLogic node pools using the SSH key. 
- For Virtual Cloud Network Strategy, select
                  Create New VCN.
                  Oracle WebLogic Server for OKE can create a new network and subnets to support this stack. This tutorial uses the same compartment for Network Compartment.
- For WebLogic Server Network CIDR, enter the network address to assign to the new VCN for the Kubernetes cluster, compute instances, and load balancers.
- For Bastion Host Subnet CIDR, enter the network address of the public subnet for the bastion host.
- For Administration Host Subnet CIDR, enter the network address of the private subnet for the administration host.
- For File System and Mount Target Subnet CIDR, enter the network address of the private subnet for file system and mount target.
- For Kubernetes Cluster Subnet CIDR, enter the network address of the private subnet for the Kubernetes cluster and node pool.
- For Kubernetes API Endpoint Cluster Subnet CIDR, enter the network address of the private subnet.
- For Minimum Bandwidth for Jenkins Load Balancer and for Maximum Bandwidth for Jenkins Load Balancer, retain the default values.
- For Kubernetes Version, enter the version
                  to use. 
                    The latest Kubernetes version is displayed by default. 
- For Non-WebLogic Node Pool Shape, select
                  the shape of the compute instances.
- For Nodes in the Node Pool for Non-WebLogic Pods, select 2.
- For WebLogic Node Pool Shape, select the
                  shape of the compute instances.
- For Nodes in the Node Pool for WebLogic Pods, select 2.
- For network configuration of Kubernetes:
                  - Enter the network address to be used for the Kubernetes pods in Pods CIDR field.
- Enter the network address to be used for the Kubernetes services in Services CIDR field.
 Ensure that the CIDR blocks for pods and services do not overlap with the VCN CIDR block. 
- For Availability Domain for Compute Instances, select the availability domain in which to create the compute instances.
- For Administration
                    Instance Compute Shape and Bastion
                    Instance Shape, select the shape of each instance
                  type.
                  If you select a flexible shape, move the slider to specify the OCPU count and the amount of memory to be allocated to the compute instances. See Compute Shapes. 
- For Availability Domain for File System, select the availability domain in which to create the file system and mount target.
- For Registry User Name, enter your user
                  name, which is used to access repositories in the Oracle Cloud
                  Infrastructure Registry.
                  The registry user name format is tenancy_namespace/<username>. If your tenancy is federated with Oracle Identity Cloud Service, then the registry user name format istenancy_namespace/oracleidentitycloudservice/<username>.You can choose either to include the Note: If you choose to includetenancy_namespaceor remove thetenancy_namespacein the user name format. For example, you can either usetenancy_namespace/<username>or<username>.tenancy_namespacein the user format, ensure that you use the correct namespace for your tenancy..
- For OCIR Auth Token Compartment, select the compartment where you have the OCI Secret that contains the auth token.
- For Validated Secret for OCIR Auth Token, select the secret that contains the authentication token for your user name in Oracle Cloud Infrastructure.
- Click Next.
- Click Create.
                  The Job Details page in Oracle Resource Manager is displayed. An Apply job is started to provision your stack. 
 To return to this page at a later time, click the navigation menu ,
                    select Developer Services. Under the Resource
                      Manager  group, click Jobs. ,
                    select Developer Services. Under the Resource
                      Manager  group, click Jobs.
- Periodically monitor the progress of the Apply job until it
                  is finished.
                  If an email address is associated with your user profile, you will receive an email notification. 
- If the job fails, click the job name to view the logs.
If you select a flexible shape, move the slider to specify the OCPU count and the amount of memory to be allocated to each node in the Non-WebLogic node pool.
If you select a flexible shape, move the slider to specify the OCPU count and the amount of memory to be allocated to each node in the WebLogic node pool.
 Access the Administration Compute Instance
Access the Administration Compute Instance
              - From the stack's Job Details page of the successful apply job, under Resources, click Outputs.
- Copy the values of admin_instance_private_ip and bastion_instance_public_ip.
- From your computer, open an SSH
                  connection to the administration instance's private IP address
                  by specifying the bastion instance's public IP address as a
                  proxy. Connect as the opcuser and provide the path to the private key that corresponds to the public key that you specified when you created the stack.The SSH command format is: ssh -i path_to_private_key -o ProxyCommand="ssh -W %h:%p –i path_to_private_key opc@bastion_public_ip" opc@admin_private_ipFor example: 
 On a Windows platform, you can use Windows PowerShell to run the SSH command.ssh -i ~/.ssh/mykey.openssh -o ProxyCommand="ssh -W %h:%p -i ~/.ssh/mykey.openssh opc@198.51.100.1" opc@10.0.2.3
- If prompted, enter the passphrase for the private key.
- When connected, you'll see the
                  following:
                  [opc@mywlsoke-admin ~]$
 Access the Jenkins Console
Access the Jenkins Console
            - Return to the top of your stack's apply Job Details page in the Oracle Cloud Infrastructure console, and under Resources, click Outputs.
- Copy the value of bastion_instance_public_ip.
- Click Logs, then find and copy the URL value of jenkins_console_url.
- From your computer, open an SSH
                tunnel to use dynamic port forwarding to an unused port on the
                bastion compute instance. Connect as the opcuser and provide the path to the private key that corresponds to the public key that you specified when you created the stack.The SSH command format is: ssh -C -D port_for_socks_proxy -fCqN -i path_to_private_key opc@bastion_public_ipThe following example uses port 1088 for SOCKS proxy: 
 On a Windows platform, you can use Windows PowerShell to run the SSH command.ssh -C -D 1088-fCqN-i ~/.ssh/mykey.openssh opc@198.51.100.1
- In your browser settings, set up the SOCKS (version 5) proxy configuration. Specify your local computer and the same SOCKS port that you used in your SSH command.
- Browse to the Jenkins console URL.
                If you are a first time user, you are prompted to create a new administration user. 
 Create a Domain
Create a Domain
            - Sign in to the Jenkins console for your domain. See Access the Jenkins Console.
- On the Dashboard page, click create domain.
- Click Build with Parameters.
- For Domain_Name,
                enter mylwlsokedomain.
- For Administration_Username, enter the administrator user name for the new WebLogic Server domain
- For Administration_Password, enter the password for the WebLogic Server administrator.
- For Managed_Server_Count, select 2.
- Select Patch_Automatically to subscribe the domain for automatic patching.
- For WebLogic_Node_Pool_Type,
                    select Create_Node_Pool.
 
- For Node_Count, select 2.
- For WebLogic_Node_Pool_Shape, select the shape of the compute instances with 2 or more OPCUs.
- For External_Lb_Shape_Min and for External_Lb_Shape_Max, retain the default values.
- Click Build to run the job.
Note: To view the parameters, you need to approve the scripts. See Approve Scripts.
This tutorial uses the same registry credentials specified when creating a stack to access the container images in the Oracle Cloud Infrastructure Registry (OCIR).
If you select a flexible shape, specify the OCPU count and the amount of memory to be allocated to each node in the WebLogic node pool. The amount of memory allowed is based on the number of OCPUs selected. See Flexible Shapes.
This tutorial uses the same key specified when creating a stack to connect to the virtual machines (VMs) of the WebLogic node pools.
If the job fails, you can view the details in the Console Output.
 Access the WebLogic Server Console
Access the WebLogic Server Console
            - From the stack's Job Details page of the successful apply job, click Application Information.
- Copy the IP value of Bastion
                  Instance Public IP. For example:
                Bastion Instance Public IP: 198.51.100.1
- From your computer, open an SSH
                tunnel to use dynamic port forwarding to an unused port on the
                bastion compute instance. Connect as the opcuser and provide the path to the private key that corresponds to the public key that you specified when you created the stack.The SSH command format is: ssh -C -D port_for_socks_proxy -i path_to_private_key opc@bastion_public_ipThe following example uses port 1088 for SOCKS proxy: 
 On a Windows platform, you can use Windows PowerShell to run the SSH command.ssh -C -D 1088 -i ~/.ssh/mykey.openssh opc@198.51.100.1
- If prompted, enter the passphrase for the private key.
- When connected, you'll see the
                following:
                [opc@mywlsoke-bastion-admin ~]$
- In your browser settings, set up the SOCKS (version 5) proxy configuration. Specify your local computer and the same SOCKS port that you used in your SSH command.
- Browse to the WebLogic Console URL.
 The URL format is: http://<jenkins_lb_IP>/<domainname>/console
              
 For example: http://10.0.2.3/mylwlsokedomain/console
The WebLogic Server Administration Console login page is displayed.
 Delete
              the Stack (Optional)
Delete
              the Stack (Optional)
            - In the Oracle Cloud Infrastructure
                console, click the navigation menu  , select Developer Services.
                Under the Resource Manager  group, click Stacks. , select Developer Services.
                Under the Resource Manager  group, click Stacks.
- Click MyWLStack.
- Click Terraform Actions, and then select Destroy.
- When prompted for confirmation, click Destroy.
- Periodically monitor the progress of
                the Destroy job until it is finished. Ensure that all resources
                of the stack are deleted successfully.If an email address is associated with your user profile, you will receive an email notification. 
- Click Delete Stack.
Make sure you have deleted the resources before you delete the stack. See Terminate a Domain.
 Want to Learn More?
Want to Learn More?
              - Using Oracle WebLogic Server for Oracle Cloud Infrastructure Container Engine
- Overview of Resource Manager
- Overview of the Compute Service
- Overview of Load Balancing
- Overview of Vault
- VCNs and Subnets

 Get
        Started with Oracle WebLogic Server for OKE
Get
        Started with Oracle WebLogic Server for OKE