6 Quick HA Install with External Load Balancer
Install a Highly Available Oracle Cloud Native Environment on bare metal hosts or virtual machines, including a Kubernetes cluster. This example uses an external load balancer.
This is the fastest method to set up a basic Highly Available deployment of Oracle Cloud Native Environment on bare metal hosts or virtual machines. This method sets up the nodes, installs the Oracle Cloud Native Environment platform and installs a Kubernetes cluster. An external load balancer is used for the Kubernetes cluster.
Security Considerations: Consider the following security settings when you use this installation example:
- 
                        
                        Private CA Certificates are used to secure network communication between the Kubernetes nodes. 
- 
                        
                        SELinux is set to permissivemode on the host OS on each Kubernetes node.
- 
                        
                        The Kubernetes externalIPsservice isn't deployed.
To perform a more complex deployment and change these security settings, use a configuration file as shown in Quick Install using Configuration File.
Nodes Required: As many nodes as required for High Availability. (See Kubernetes High Availability Requirements).
- 
                        
                        Operator Node: One node to use as the operator node, which is used to perform the installation using the Platform CLI ( olcnectl), and to host the Platform API Server.
- 
                        
                        Kubernetes control plane: At least three nodes to use as Kubernetes control plane nodes. 
- 
                        
                        Kubernetes worker: At least two nodes to use as Kubernetes worker nodes. 
Before you begin: Complete the prerequisite set up. See Prerequisites.
- 
                        
                        Set up an external load balancer. The load balancer should be set up with the following configuration: - 
                              
                              The listener listening on TCP port 6443. 
- 
                              
                              The distribution set to round robin. 
- 
                              
                              The target set to TCP port 6443 on the control plane nodes. 
- 
                              
                              The health check set to TCP. 
 
- 
                              
                              
- 
                        
                        On the operator node, use the olcnectl provisioncommand to start the installation. The mandatory syntax is:olcnectl provision --api-server host --control-plane-nodes hosts --master-nodes hosts (Deprecated) --worker-nodes hosts --environment-name name --name name --load-balancer locationUse the --api-serveroption to set the FQDN of the node on which the Platform API Server is to be set up.Use the --control-plane-nodesoption to set the FQDN of the nodes to be set up with the Platform Agent and assigned the role of Kubernetes control plane nodes. This is a comma separated list.Use the --worker-nodesoption to set the FQDN of the nodes to be set up with the Platform Agent and assigned the role of Kubernetes worker nodes. This is a comma separated list.Use the --environment-nameoption to set the name to identify the environment.Use the --nameoption to set the name to identify the Kubernetes module.Use the --load-balanceroption to set the URL to the external load balancer.Several other command options might be required, such as the SSH login credentials, proxy server information, and the option to automatically accept any prompts using the --yesoption. For information on the syntax options for theolcnectl provisioncommand, see Platform Command-Line Interface.For example: olcnectl provision \ --api-server operator.example.com \ --control-plane-nodes control1.example.com,control2.example.com,control3.example.com \ --worker-nodes worker1.example.com,worker2.example.com,worker3.example.com \ --environment-name myenvironment \ --name mycluster \ --load-balancer lb.example.com:6443
- 
                        
                        A list of the steps to be performed on each node is displayed and a prompt is displayed to proceed. For example, on a control plane node, the changes might look similar to: ? Apply control-plane configuration on control1.example.com: * Install oracle-olcne-release ... * Install and enable olcne-agent Proceed? yes/no(default) yesEnter yesto continue. The node is set up.Information about the changes on each node is displayed. You need to confirm the set up steps for each node. Tip: To avoid accepting the changes on each node, use the --yescommand option with theolcnectl provisioncommand.
- 
                        
                        The nodes are set up with the Oracle Cloud Native Environment platform and a Kubernetes module is installed to set up a Kubernetes cluster. You can show information about the environment using the syntax: olcnectl module instances --api-server host_name:8091 --environment-name nameTip: To avoid using the --api-serveroption in futureolcnectlcommands, add the--update-configoption.For example: olcnectl module instances \ --api-server operator.example.com:8091 \ --environment-name myenvironment \ --update-configThe output looks similar to: INFO[...] Global flag configuration for myenvironment has been written to the local Platform config and you don't need to specify them for any future calls INSTANCE MODULE STATE control1.example.com:8090 node installed ... mycluster kubernetes installedTo see more information about the deployment, use the olcnectl module reportcommand. For example:olcnectl module report \ --environment-name myenvironment \ --name mycluster \ --children
- 
                        
                        Set up the Kubernetes CLI ( kubectl) on a control plane node. Thekubectlcommand is installed on each control plane node in the cluster. To use it to access the cluster, you need to configure it using the Kubernetes configuration file.Login to a control plane node and copy and paste these commands to a terminal in the user's home directory: mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config export KUBECONFIG=$HOME/.kube/config echo 'export KUBECONFIG=$HOME/.kube/config' >> $HOME/.bashrcVerify that you can use the kubectlcommand using anykubectlcommand such as:kubectl get deployments --all-namespacesThe output looks similar to: NAMESPACE NAME READY UP-TO-DATE AVAILABLE AGE externalip-validation-system externalip-validation-webhook 1/1 1 1 29m kube-system coredns 2/2 2 2 30m kubernetes-dashboard kubernetes-dashboard 1/1 1 1 29m ocne-modules ocne-module-operator 1/1 1 1 29mNote: After the deployment, a Kubernetes configuration file is created in the local directory of the operator node. The file is named kubeconfig.environment_name.cluster_nameand contains information about the Kubernetes cluster. This file is created for convenience and isn't required to set upkubectlon the control plane nodes.You might want to use this file to add to a larger Kubernetes configuration file if you have multiple clusters. See the upstream Kubernetes documentation for more information on configuring access to multiple clusters. 
Tip:
Adding and Removing Nodes to Scale a Kubernetes Cluster
To change the nodes in the Kubernetes cluster, run the olcnectl
            provision command again with updated control plane and worker node lists: any
          nodes you omit of a new node list are removed from the cluster, whilst any new nodes you
          specify are added to it.
                     
If you're adding nodes, new certificates are automatically generated for you and installed on the new nodes, the Oracle Cloud Native Environment software is installed, and the nodes are added to the Kubernetes cluster. However, you still need to ensure that all new nodes have been set up with the required prerequisites (see Prerequisites), and that any new control plane nodes have been added to the load balancer if you're using an external load balancer.