Install Edge Orchestrator#
Download the Installation Script#
Note
EMF is released on a weekly basis. To use a weekly build, refer to the latest weekly tag available here. In the below script, replace v3.1.0 with the appropriate weekly tag. Weekly tags follow the format: v3.1.0-nYYYYMMDD.
- Create the script file on the Edge Orchestrator node using the following command: 
cat <<'EOF' > access_script.sh #!/usr/bin/env bash set -o errexit set -o nounset set -o pipefail REGISTRY_URL='registry-rs.edgeorchestration.intel.com' RS_PATH='edge-orch/common/files/on-prem' ORAS_VERSION='1.1.0' ORCH_VERSION='v3.1.0' # Install oras if not already installed if ! command -v oras &> /dev/null; then echo "Oras not found. Installing..." # Download the specified version of oras curl -LO "https://github.com/oras-project/oras/releases/download/v${ORAS_VERSION}/oras_${ORAS_VERSION}_linux_amd64.tar.gz" # Create a temporary directory for oras installation mkdir -p oras-install/ # Extract the downloaded tarball into the temporary directory tar -zxf oras_${ORAS_VERSION}_*.tar.gz -C oras-install/ # Move the oras binary to a directory in the system PATH sudo mv oras-install/oras /usr/local/bin/ # Clean up the downloaded files and temporary directory rm -rf oras_${ORAS_VERSION}_*.tar.gz oras-install/ else echo "Oras is already installed." fi # Pull the specified artifact from the registry oras pull -v "${REGISTRY_URL}/${RS_PATH}:${ORCH_VERSION}" # Make all shell scripts in the current directory executable chmod +x *.sh EOF
- Make the script executable. - chmod +x access_script.sh 
- Run the script on the Edge Orchestrator node. - ./access_script.sh - The script does the following: - Installs the - orastool
- Downloads the scripts to install and uninstall Edge Orchestrator 
 
Installation Parameters#
Before running the installation script, you can provide some optional configuration parameters.
Optional Parameters#
Some configuration parameters the installer uses have default values that you can set manually. See the following table for more information about each parameter.
| Installation Parameter | Description | Default Value | 
|---|---|---|
| 
 | Sets the profile and artifacts to deploy Edge Orchestrator. This parameter allows the default  | 
 | 
| 
 | Sets the  | 
 | 
| 
 | Sets the  | 
 | 
| 
 | Sets the SRE endpoint URL. | 
 | 
| 
 | Sets the cluster domain name for Edge Orchestrator services, which defines the base for full-service domain names by adding subdomains (not to be confused with the Kubernetes* cluster domain). | 
 | 
| 
 | Sets the URL to the Release Service. | 
 | 
| 
 | Sets the version of the artifacts used to deploy Edge Orchestrator. | 
 | 
Configure SMTP Variables for Notifications#
To enable email notifications for alerts, set the following environmental variables for the external SMTP server. See Configure Email Notifications for more information. If not needed or if the SMTP server is not available, you can disable the SMTP server authentication when installing Edge Orchestrator.
| SMTP Variable | Description | Default Value | 
|---|---|---|
| 
 | Sets the endpoint URL of the SMTP server endpoint. | 
 | 
| 
 | Sets the default port number of the exposed SMTP server endpoint. | 
 | 
| 
 | Sets the default email header for notifications | 
 | 
| 
 | Sets the default username to access the SMTP server endpoint | 
 | 
| 
 | Set the default password to access the SMTP server endpoint | 
 | 
Run Installer#
Note
Add any optional configuration from previous sections if needed. Or check the following for optional arguments.
./onprem_installer.sh
The script does the following:
- Prompts to configure Argo* CD tool, Traefik* application proxy, and NGINX* web server IP addresses, for details see Installer Prompts and Deployment Configuration 
- Prompts to confirm custom configurations to the deployment, for details see Installer Prompts and Deployment Configuration 
- Downloads installation packages for individual component installations 
- Downloads archived Edge Orchestrator’s Git* repositories 
- Installs OS-level prerequisites 
- Installs RKE2 and related components 
- Installs Argo CD tool 
- Installs a Gitea* repository 
- Installs Edge Orchestrator - Creates and populates the Gitea repositories with downloaded archives 
- Starts Edge Orchestrator via Argo CD tool to populate the Gitea repositories 
 
See the following sections for details about the installation process and prompts.
Installer Prompts and Deployment Configuration#
The installer script prompts for configuration input during the installation process.
- The installer prompts you to enter the IP addresses used by the Load Balancer for Argo CD UI, Traefik application proxy, and NGINX web server as follows. There are strict requirements on these IP addresses: - All three IP addresses must be on the same subnet (for example, 10.0.0.1/24) of the Edge Orchestrator node. 
- IP addresses must be unique - you cannot use the same IP address for all three endpoints. The installation will fail, if any IP address is duplicated. 
- These are “Virtual IPs” - you do not have to assign these IPs to any hardware network interface, but you must reserve these IPs within the local subnet. Ensure your DHCP server does not assign conflicting IP addresses. 
 - See Edge Orchestrator Network Topology for details about possible network configurations. - An example of the topology: - Argo IP is the IP for CI/CD automated deployment tool. 
- Traefik IP is the IP for the application API proxy, the entry point to reach the Edge Orchestrator. 
- Nginx IP is the IP for southbound specific tools onboarding and provisioning. 
 - Enter Argo IP: [xx.xx.xx.xx] Enter Traefik IP: [yy.yy.yy.yy] Enter Nginx IP: [zz.zz.zz.zz] 
Configure Custom Settings#
- Create any custom configurations for the Edge Orchestrator deployment before pushing the source code into the local - Gitea repository. See Email notifications to enable email notifications.
- To change the deployment parameters, edit the following files in a separate terminal window. - Note - Do not exit the script. - [path_to_untarred_repo]/orch-configs/clusters/[profile_name].yaml
- [path_to_untarred_repo]/orch-configs/profiles/*.yaml
 
- By default, Edge Orchestrator use the base domain name of cluster.onprem. If you require a custom domain name, edit the cluster domain name in the - [path_to_untarred_repo]/orch-configs/clusters/onprem.yamlfile.- clusterDomain: [customer.cluster.domain] 
- By default, the NTP server (ntpServer) settings uses the public NTP time server pool at pool.ntp.org. If the customer network requires any other servers, edit the ntpServer settings in the - [path_to_untarred_repo]/orch-configs/profiles/profile-onprem.yamlfile.- ntpServer: ["time.google.com"] 
- By default, Edge Orchestrator uses a self-signed TLS certificate to serve requests. This works for test deployments, however, Intel recommends using a TLS certificate obtained from a trusted CA for product deployments. - Note - To use a custom TLS certificate, edit the following: - Ensure that the cluster domain name matches the Common Name or ensure that the DNS names are valid for the custom TLS certificate in the - [path_to_untarred_repo]/orch-configs/clusters/onprem.yamlfile:- clusterDomain: [customer.cluster.domain] 
- Disable the self-signed certificate creation in the - [path_to_untarred_repo]/orch-configs/profiles/profile-onprem.yamlfile:- self-signed-cert: generateOrchCert: false 
 
- If Edge Orchestrator or the edge nodes requires a proxy to access the Internet, update the proxy configuration in the - [path_to_untarred_repo]/orch-configs/profiles/proxy-none.yamlfile, then rename the file to- [path_to_untarred_repo]/orch-configs/profiles/proxy.yaml. If no proxy is required for a specific protocol, leave the field empty:- argo: proxy: httpProxy: [HTTP proxy URL] httpsProxy: [HTTPS proxy URL] noProxy: [Comma separated list of hosts and domains for which proxy settings should be bypassed] enHttpProxy: [HTTP proxy URL for the Edge Node] enHttpsProxy: [HTTPS proxy URL for the Edge Node] enFtpProxy: [FTP proxy URL for the Edge Node] enSocksProxy: [SOCKS proxy URL for the Edge Node] enNoProxy: [Comma separated list of hosts and domains for which proxy settings should be bypassed in the Edge Node] git: gitProxy: [HTTPS proxy URL] - Then change the proxy profile in the - [path_to_untarred_repo]/orch-configs/clusters/onprem.yamlfile:- - - profiles/proxy-none.yaml + - profiles/proxy.yaml 
- Edge Orchestrator detects the latest compatible versions of the Edge Microvisor Toolkit for update of edge nodes deployed with an immutable OS. By default, manual association of the Edge Microvisor Toolkit version with edge nodes is required. Alternatively, select custom Edge Microvisor Toolkit version from the Release Service and link it to edge nodes. For more information, see Update an Edge Node’s Immutable OS Software. - To allow Edge Orchestrator to automatically associate the latest available Edge Microvisor Toolkit version with all edge nodes, enable automatic mode for the Edge Infrastructure Manager’s OS Resource Manager in the relevant profile file. 
- To enable automatic mode, edit the - [path_to_untarred_repo]/orch-configs/profiles/enable-osrm-manual-mode.yamlfile and set:- argo: infra-managers: os-resource-manager-manual-mode: false 
 
- When deploying Edge Orchestrator with an optional proxy for Edge Nodes without direct Internet access, set both - enHttpProxyand- enHttpsProxyvariables to resolve to the Edge Orchestrator’s Traefik* IP endpoint using port 8080. Intel recommends adding an entry for the Traefik endpoint to the DNS server. The following are examples of entries for proxy and- enNoProxyvariables:- enHttpProxy: http://<Traefik-IP-endpoint>:8080 enHttpsProxy: http://< Traefik-IP-endpoint>:8080 enNoProxy: localhost,127.0.0.1,<Traefik-IP-endpoint-or-subnet-of-Edge-Orchestrator>,.internal,.cluster.local,<domain-of-orchestrator> 
- You can edit the near Zero-Touch Provisioning (nZTP) configuration by modifying the values in - [path_to_untarred_repo]/orch-configs/profiles/enable-autoprovision.yamland include in the cluster definition- autoProvision: enabled: true # enabled/disabled near Zero Touch Provisioning defaultProfile: ubuntu-22.04-lts-generic # OS to be provisioned when autoProvision is enabled - This configuration applies for every organization and project by default when they are created, but you can edit the nZTP configuration for each project at a later time. To learn more about the nZTP feature, see the Near Zero-Touch Provisioning (nZTP) section in the User Guide. 
- You can configure a custom Traefik rate limit. See Configure Traefik* Rate Limit. - Configure the Traefik rate limit in the - [path_to_untarred_repo]/orch-configs/profiles/default-traefik-rate-limit.yamlfile and add the profile in the- [path_to_untarred_repo]/orch-configs/clusters/onprem.yamlfile:- + - profiles/default-traefik-rate-limit.yaml 
Disable SRE (Optional)#
It is possible to configure or fully disable SRE during the next step by doing the following:
- To enable or disable the SRE Exporter service, include or exclude - [path_to_untarred_repo]/orch-configs/profiles/enable-sre.yamlin the cluster definition YAML file under- root.clusterValues.
- Optionally, the default values for SRE can be overridden in the cluster definition YAML file under - .argo.o11y.sre.
See Configure SRE Exporter Service for more information.
Enable TLS for SRE Exporter endpoint (Optional)#
To enable Transport Layer Security (TLS) authentication between an SRE
exporter and SRE endpoint, use the -s flag:
./onprem_installer.sh -s
Note
The -s flag is optional. If omitted, the SRE exporter will deploy with the TLS authentication option turned off.
Optionally, a private TLS CA certificate of the destination SRE server may be provided by passing an absolute
path to the file containing the certificate after -s flag:
./onprem_installer.sh -s [path_to_SRE_Endpoint_TLS_CA_Cert]
If you want to disable SRE functionality fully, see the Disable SRE section above.
Disable SMTP Server Authentication (Optional)#
Use the -d option to turn off the TLS authentication between the SMTP server and alert monitor:
./onprem_installer.sh -d
Prepare TLS Certificate Secret#
Obtain the previously prepared TLS certificate bundle and TLS key and create a Kubernetes* secret file tls-secret.yaml using the information from the certificate and key.
Execute the following command to create the Kubernetes secret file tls-secret.yaml that contains the TLS certificate and key if you manually generate the certificate:
cat <<EOF > tls-secret.yaml
apiVersion: v1
data:
   tls.crt: $(cat cert-bundle.crt | base64 -w 0)
   tls.key: $(cat key.key | base64 -w 0)
kind: Secret
metadata:
   creationTimestamp: null
   name: tls-orch
   namespace: orch-gateway
type: kubernetes.io/tls
EOF
If you instead used Certbot to generate the certificate, replace the clusterDomain value with your domain name and execute the following command:
clusterDomain=[on.prem.domain.name]
certchain=/etc/letsencrypt/live/${clusterDomain}/fullchain.pem
privkey=/etc/letsencrypt/live/${clusterDomain}/privkey.pem
cat <<EOF > tls-secret.yaml
apiVersion: v1
data:
tls.crt: $(sudo cat ${certchain} | base64 -w 0)
tls.key: $(sudo cat ${privkey} | base64 -w 0)
kind: Secret
metadata:
creationTimestamp: null
name: tls-orch
namespace: orch-gateway
type: kubernetes.io/tls
EOF
Start the Deployment Process#
- Make all changes, or if no changes are needed, type - yesand press the Enter key to complete the installation.
- When using a custom non self-signed certificate, apply the previously prepared secret containing the TLS certificate: - kubectl apply -f tls-secret.yaml 
This process can take up to an hour to complete.
Argo CD Root Application Deployment#
Argo CD tool begins the deployment of the Edge Orchestrator software from the edge-manageability-framework repository pushed to the Gitea repository.
Sub-applications continue to deploy in the syncwave order until all the applications are deployed.
View Application Deployment#
To see the deployment progress, run the following:
watch kubectl get applications -A
This process can take up to an hour to complete.
DNS Configuration#
After Edge Orchestrator is deployed successfully, configure the Domain Name System (DNS) to access the applications in the browser.
When using self-signed certificate:
- To access the applications only on a specific node, run the - generate_fqdncommand on Edge Orchestrator, and configure the output in the local DNS resolver settings of that node.
- To access the applications from multiple hosts in the network, add the output of the - generate_fqdncommand to the corresponding DNS configuration file on the DNS server.
When using custom non-self signed certificate:
Find the external IPs allocated to services reachable from outside of the cluster (see the EXTERNAL-IP in the output):
kubectl get services argocd-server -n argocd
NAME            TYPE           CLUSTER-IP     EXTERNAL-IP
argocd-server   LoadBalancer   [clusterIP]    [argo-cd-external-ip]
kubectl get services traefik -n orch-gateway
NAME            TYPE           CLUSTER-IP     EXTERNAL-IP
argocd-server   LoadBalancer   [clusterIP]    [traefik-external-ip]
kubectl get services ingress-nginx-controller -n orch-boots
NAME            TYPE           CLUSTER-IP     EXTERNAL-IP
argocd-server   LoadBalancer   [clusterIP]    [ingress-nginx-external-ip]
Map the IP addresses obtained above to the domain names that need to be reachable through DNS, and add to DNS record used in the on-premises environment.
An example of the dnsmasq config file:
address=/argocd.[on.prem.domain.name]/[argo-cd-external-ip]
address=/[on.prem.domain.name]/[traefik-external-ip]
address=/alerting-monitor.[on.prem.domain.name]/[traefik-external-ip]
address=/api.[on.prem.domain.name]/[traefik-external-ip]
address=/app-orch.[on.prem.domain.name]/[traefik-external-ip]
address=/app-service-proxy.[on.prem.domain.name]/[traefik-external-ip]
address=/attest-node.[on.prem.domain.name]/[traefik-external-ip]
address=/cluster-orch-edge-node.[on.prem.domain.name]/[traefik-external-ip]
address=/cluster-orch-node.[on.prem.domain.name]/[traefik-external-ip]
address=/cluster-orch.[on.prem.domain.name]/[traefik-external-ip]
address=/connect-gateway.[on.prem.domain.name]/[traefik-external-ip]
address=/fleet.[on.prem.domain.name]/[traefik-external-ip]
address=/gitea.[on.prem.domain.name]/[traefik-external-ip]
address=/infra-node.[on.prem.domain.name]/[traefik-external-ip]
address=/keycloak.[on.prem.domain.name]/[traefik-external-ip]
address=/log-query.[on.prem.domain.name]/[traefik-external-ip]
address=/logs-node.[on.prem.domain.name]/[traefik-external-ip]
address=/metadata.[on.prem.domain.name]/[traefik-external-ip]
address=/metrics-node.[on.prem.domain.name]/[traefik-external-ip]
address=/observability-admin.[on.prem.domain.name]/[traefik-external-ip]
address=/observability-ui.[on.prem.domain.name]/[traefik-external-ip]
address=/onboarding-node.[on.prem.domain.name]/[traefik-external-ip]
address=/onboarding-stream.[on.prem.domain.name]/[traefik-external-ip]
address=/registry.[on.prem.domain.name]/[traefik-external-ip]
address=/registry-oci.[on.prem.domain.name]/[traefik-external-ip]
address=/release.[on.prem.domain.name]/[traefik-external-ip]
address=/telemetry-node.[on.prem.domain.name]/[traefik-external-ip]
address=/tinkerbell-server.[on.prem.domain.name]/[traefik-external-ip]
address=/update-node.[on.prem.domain.name]/[traefik-external-ip]
address=/vault.[on.prem.domain.name]/[traefik-external-ip]
address=/vnc.[on.prem.domain.name]/[traefik-external-ip]
address=/web-ui.[on.prem.domain.name]/[traefik-external-ip]
address=/ws-app-service-proxy.[on.prem.domain.name]/[traefik-external-ip]
address=/tinkerbell-nginx.[on.prem.domain.name]/[ingress-nginx-external-ip]
address=/mps.[on.prem.domain.name]/[traefik-external-ip]
address=/rps.[on.prem.domain.name]/[traefik-external-ip]
address=/mps-wss.[on.prem.domain.name]/[traefik-external-ip]
address=/rps-wss.[on.prem.domain.name]/[traefik-external-ip]
address=/device-manager-node.[on.prem.domain.name]/[traefik-external-ip]
Add Exceptions to the Browser or Import Self-Signed Certificate (Optional)#
Add exceptions to your browser for the following Edge Orchestrator domains,
replacing CLUSTER_FQDN with domain that you used during installation when
using self-signed certificates:
- https://keycloak.CLUSTER_FQDN 
- https://web-ui.CLUSTER_FQDN 
- https://argocd.CLUSTER_FQDN 
- https://vnc.CLUSTER_FQDN 
- https://CLUSTER_FQDN 
You can also retrieve the self-signed certificate from the Kubernetes cluster:
kubectl get secret -n orch-gateway tls-orch -o jsonpath='{.data.ca\.crt}' | base64 --decode > orch.crt
Otherwise, use opensssl, if you do not have access to kubectl:
openssl s_client -connect web-ui.CLUSTER_FQDN:443
# Copy Server Certificate from the output and paste to orch.crt file
Copy the orch.crt file to your local machine and import it to your system trust store.
Limit Exposure of Argo CD Endpoint#
Intel recommends restricting the Argo CD UI endpoint to a known subnet of safe IP addresses.
Edge Orchestrator Restart#
Restarting Edge Orchestrator will seal the HashiCorp Vault* system. See Troubleshooting Vault Server for more information about the HashiCorp Vault used with Edge Orchestrator.