mirror of
				https://github.com/taigrr/nats.docs
				synced 2025-01-18 04:03:23 -08:00 
			
		
		
		
	Add guide to use Helm and leafnodes from scratch
This commit is contained in:
		
							parent
							
								
									be25e66893
								
							
						
					
					
						commit
						f63e891e43
					
				
							
								
								
									
										78
									
								
								nats-on-kubernetes/from-zero-to-leafnodes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								nats-on-kubernetes/from-zero-to-leafnodes.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | # From zero to communicating across K8S regions using NATS leafnodes | ||||||
|  | 
 | ||||||
|  | First, we need a number of Kubernetes clusters to be setup already. In | ||||||
|  | this case we'll create a few in Digital Ocean using the `doctl` tool but | ||||||
|  | you could use any K8S solution available: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | brew install doctl | ||||||
|  | doctl kubernetes cluster create nats-k8s-nyc1 --count 3 --region nyc1 | ||||||
|  | doctl kubernetes cluster create nats-k8s-sfo2 --count 3 --region sfo2 | ||||||
|  | doctl kubernetes cluster create nats-k8s-ams3 --count 3 --region ams3 | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Next, get your NGS credentials with leafnodes enabled.  For this follow the instructions at: https://synadia.com/ngs/signup | ||||||
|  | Once you got the credentials, upload them as a secret to your K8S clusters: | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | for ctx in do-ams3-nats-k8s-ams3 do-nyc1-nats-k8s-nyc1 do-sfo2-nats-k8s-sfo2; do | ||||||
|  |   kubectl --context $ctx create secret generic ngs-creds --from-file $HOME/.nkeys/creds/synadia/NGS/NGS.creds | ||||||
|  | done | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Install Helm3 and add the NATS helm chart repo: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | brew install helm | ||||||
|  | helm repo add nats https://nats-io.github.io/k8s/helm/charts/ | ||||||
|  | helm repo update | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Create the config that adds the leafnode connection to NGS: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | # nats.yaml | ||||||
|  | leafnodes: | ||||||
|  |   enabled: true | ||||||
|  |   remotes: | ||||||
|  |     - url: tls://connect.ngs.global:7422 | ||||||
|  |       credentials: | ||||||
|  |         secret: | ||||||
|  |           name: ngs-creds | ||||||
|  |           key: NGS.creds | ||||||
|  | natsbox: | ||||||
|  |   enabled: true | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Deploy it to your K8S regions: | ||||||
|  | 
 | ||||||
|  | ```sh | ||||||
|  | for ctx in do-ams3-nats-k8s-ams3 do-nyc1-nats-k8s-nyc1 do-sfo2-nats-k8s-sfo2; do | ||||||
|  |   helm --kube-context $ctx install nats nats/nats -f nats.yaml | ||||||
|  | done | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | To test the multi-region connectivity by using the `nats-box` container that got deployed in each cluster: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | kubectl --context do-ams3-nats-k8s-ams3  exec -it nats-box -- nats-sub -s nats hello | ||||||
|  | Listening on [hello] | ||||||
|  | 
 | ||||||
|  | while true; do | ||||||
|  |   kubectl --context do-sfo2-nats-k8s-sfo2  exec -it nats-box -- nats-pub -s nats hello 'Hello World!' | ||||||
|  | done | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | Results from the subscribe session: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | [#1] Received on [hello]: 'Hello World!' | ||||||
|  | [#2] Received on [hello]: 'Hello World!' | ||||||
|  | [#3] Received on [hello]: 'Hello World!' | ||||||
|  | [#4] Received on [hello]: 'Hello World!' | ||||||
|  | [#5] Received on [hello]: 'Hello World!' | ||||||
|  | [#6] Received on [hello]: 'Hello World!' | ||||||
|  | [#7] Received on [hello]: 'Hello World!' | ||||||
|  | [#8] Received on [hello]: 'Hello World!' | ||||||
|  | [#9] Received on [hello]: 'Hello World!' | ||||||
|  | ``` | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user