aws-service-operator

module
v0.0.1-alpha1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 1, 2018 License: Apache-2.0

README

= AWS Service Operator

The AWS Service Operator allows you to manage AWS resources using
Kubernetes Custom Resource Definitions. 

Using the AWS Service Operator enables a `gitops` workflow to drive your infrastructure to the desired state leveraging Kubernetes Custom Resource Definitions (CRD), the Kubernetes internal control loop, and AWS cloudformation orchestration.  Read more about "operators" link:https://coreos.com/operators/[here].

image::aws-service-operator-example.gif[]

== Prerequisites

To get started you will need

- a Kubernetes cluster running in AWS. Check out link:https://docs.aws.amazon.com/eks/latest/userguide/what-is-eks.html[EKS] or link:https://github.com/kubernetes/kops[kops] to get started
- link:https://kubernetes.io/docs/tasks/tools/install-kubectl/[kubectl]
- link:https://docs.aws.amazon.com/cli/latest/userguide/installing.html[awscli]

== Getting Started

Make sure your Kubernetes cluster is up and running and you've configured your awscli for the approriate account and region you'll be working in.

=== IAM permissions management

You will need to install an IAM management layer
such as `kube2iam`. This will allow you to use an AWS IAM role to manage a pod's 
access to AWS resources. 

To get started with `kube2iam` go link:https://github.com/jtblin/kube2iam[here] or check out the 
link:https://github.com/helm/charts/tree/master/stable/kube2iam[helm chart]

The `aws-service-operator` runs as a pod in your Kubernetes cluster and listens for new `aws` type CRDs.  
When a new CRD is created the operator will create the resource in AWS via cloudformation and 
create a Kubernetes `Service` for access within the cluster.

=== Create an IAM role for the `aws-service-operator`
 
 The `K8S_WORKER_NODE_IAM_ROLE` is the IAM role assigned to your kubernetes worker instances.

[source,shell]
aws cloudformation create-stack \
  --stack-name aws-service-operator-role \
  --capabilities CAPABILITY_NAMED_IAM \
  --template-body file://configs/aws-service-operator-role.yaml \
  --parameters \
    ParameterKey=WorkerArn,ParameterValue=<K8S_WORKER_NODE_IAM_ROLE>    

Your resulting IAM role arn should look something like `arn:aws:iam::<ACCOUNT_ID>:role/aws-service-operator`

=== Deploy the aws-service-operator

Before applying these resources make sure to replace the following placeholders with the approriate information in `configs/aws-service-operator.yaml`

- `<ACCOUNT_ID>` - Your AWS Account ID
- `<REGION>` - The AWS Region you're working in 
- `<CLUSTER_NAME>` - The name of your cluster
- `<BUCKET_NAME>` - (optional) The operator stores certain things in s3 create a bucket or provide an existing bucket for the operator to use `i.e. aws s3 mb s3://foobar`


.1. Create the operator
[source,shell]
kubectl apply -f configs/aws-service-operator.yaml

.2. Create the cloudformation templates (cft) used by the operator
[source,shell]
kubectl apply -f examples/cloudformationtemplates

.3. (optional) Follow the operator logs
[source,shell]
kubectl logs -f -n aws-service-operator deploy/aws-service-operator

.4. Create an ecr repository with the operator
[source,yaml]
kubectl apply -f examples/ecrrepository.yaml

The operator will communicate directly with Cloudformation to create the ecr repository using
the parameters you have passed in. If you'd like to see the progress you can
view the status directly via `kubectl`.

.5. Check the ecr resource in Kubernetes
[source,shell]
kubectl describe ecr example-repository-name

== Removing everything

If you would like to tear everything down - run the following commands. 

*IMPORTANT* this will not remove anything you created with the AWS cli (ecr repo for the operator itself, IAM roles etc.)

[source,shell]
kubectl delete ecr example-repository-name
kubectl get crd | grep ".operator.aws" | awk '{print $1}' | xargs kubectl delete crd
kubectl delete -f configs/aws-service-operator.yaml

Directories

Path Synopsis
cmd
code-generation
pkg
apis/service-operator.aws/v1alpha1
Package v1alpha1 is the v1alpha1 version of the API.
Package v1alpha1 is the v1alpha1 version of the API.
client/clientset/versioned
This package has the automatically generated clientset.
This package has the automatically generated clientset.
client/clientset/versioned/fake
This package has the automatically generated fake clientset.
This package has the automatically generated fake clientset.
client/clientset/versioned/scheme
This package contains the scheme of the automatically generated clientset.
This package contains the scheme of the automatically generated clientset.
client/clientset/versioned/typed/service-operator.aws/v1alpha1
This package has the automatically generated typed clients.
This package has the automatically generated typed clients.
client/clientset/versioned/typed/service-operator.aws/v1alpha1/fake
Package fake has the automatically generated clients.
Package fake has the automatically generated clients.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL